nginx(tengine)的一些小優化(持續更新)

来源:http://www.cnblogs.com/liujian001/archive/2016/01/07/5108797.html
-Advertisement-
Play Games

對nginx的一些小優化的記錄,例如日誌的切割,日誌的分析,以及參數的配置等等,會持續的進行更新。


1、nginx日誌切割腳本

需求來源:nginx本身並沒有日誌切割的功能,由訪問產生的大日誌很難進行分析。

實現目的:每天對nginx日誌進行切割,並備份至指定文件夾。

 

簡要指令:

mv /usr/local/tengine/logs/access.log /usr/local/tengine/logs/access-date.log kill -USER1 Nginx主進程號。   解釋:      通過mv命令重命名日誌,並且通過kill -USER1 nginx-id的命令,告訴nginx需要寫新的日誌。   我們可以通過nginx.pid文件來獲取nginx的主進程號。   kill -USER1`cat /usr/local/tengine/logs/nginx.pid`   PS:如果不知道nginx.pid文件在哪的話,可以直接在nginx目錄,或者伺服器根目錄搜索:find / -name nginx.pid   詳細腳本如下: ####################################################################### #!/bin/bash logs_bak_path="/usr/local/tengine/logs/nginx_log" logs_path="/usr/local/tengine/logs" TIME=`date "+%Y-%m-%d"`   mv $logs_path/access.log $logs_bak_path/access.$TIME.log kill -USER1`cat /usr/local/tengine/logs/nginx.pid` ####################################################################### 將腳本保存至nginx的sbin目錄,與nginx主程式同級。   然後使用crontab -e打開linux的定時執行編輯,增加如下配置: 59 23 * * * . /root/.bash_profile; /usr/local/tengine/sbin/cut_nginx_log.sh >/dev/null 2>&1   如果要分析日誌的話,大家可以使用:goaccess 這個工具對日誌進行分析,稍後會單開一個隨筆,單獨介紹nginx的日誌分析。
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 背景 在程式中,我們調試運行時信息,Log4Net是一個不錯的解決方案。不知道是我用的不好,用到最後反而都不想看日誌了。原因是因為我n個功能使用的預設的Logger來記錄日誌,這樣以來,所有功能記錄的信息都依賴同一個配置,於是所有的信息都在一個文件中,有時候查找起來,極其不方便。 我想,能不能按.....
  • C#中的很多關鍵詞用法比較容易混淆,var和dynamic就是其中一組,他們都可以申明動態類型的變數,但是本質上他們還是有不少區別的。var 在編譯階段已經確定類型,在初始化時候,必須提供初始化的值,而dynamic則可以不提供,它是在運行時才確定類型。
  • 前提linux環境下,當使用umount命令卸載掛載點時,會遇到“device is busy”提示,這時fuser就能查出誰在使用這個資源;當然umount –lf [掛載點] 也可以強制卸載功能fuser 可以顯示出當前哪個程式在使用磁碟上的某個文件、掛載點、甚至網路埠,並給出程式進程的詳細信...
  • [root@linux ~]# history [n][root@linux ~]# history [-c][root@linux ~]# history [-raw] histfiles參數:n :數字,意思是『要列出最近的 n 筆命令列表』的意思!-c :將目前的 shell 中的所有 his...
  • 1、查看有沒有安裝過: yum list installed mysql* rpm -qa | grep mysql*2.查看有沒有安裝包: yum list mysql*3.安裝mysql客戶端: yum install mysql4.安裝mysql 伺服器端: ...
  • 在Windows Server 2012 上遇到了“The Recycle Bin On E:\ is corrupted。 Do you want to empty the Recycle Bin for this drive?" . 一般對應的中文提示為”E:\上的回收站已經損壞。是否清空該.....
  • 一、cmd命令行---進行Windows服務操作 1、安裝服務 sc create 服務名 binPath= "C:\Users\Administrator\Desktop\win32srvDemo\win32srvdemo\Debug\win32srvDemo.exe" 註:服務名:指創建的Win...
  • 1、使用expect前,需要先安裝兩個rpm包,下載:http://download.csdn.net/detail/wang7dao/4416172# rpm -ihv expect-5.43.0-8.el5.i386.rpm# rpm -ihv expect-devel-5.43.0-8.el5...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...