nginx網站架構優化思路(原)

来源:http://www.cnblogs.com/dragonflyer/archive/2017/01/08/6261957.html
-Advertisement-
Play Games

本人接觸的優化主要分為三大類 黑體的為本模塊下的重點 安全優化 安全在生產場景中是第一位的 1.1 站點目錄許可權的優化 (修改許可權755 644 所屬用戶root,需要上傳的目錄給予nginx許可權) 1.2 防盜連接的優化(通過$http_referer實現判斷用戶來源,對非法的referer 返回 ...


本人接觸的優化主要分為三大類 黑體的為本模塊下的重點

 ---------------安全優化

安全在生產場景中是第一位的

1.1 站點目錄許可權的優化 (修改許可權755 644 所屬用戶root,需要上傳的目錄給予nginx許可權

1.2 防盜連接的優化(通過$http_referer實現判斷用戶來源,對非法的referer 返回錯誤代碼)這一點如果沒做 站點流量會上升(幫別人做廣告),可能會給公司造成而外的經濟損失

1.3 日誌許可權的優化,日誌許可權不要給nginx用戶,日誌是分析問題和數據的重要文件,安全必須考慮

1.4 重要目錄遷移或者用目錄訪問控制用(allow,deny實現)例如配置文件或者程式安裝目錄

1.5 上傳目錄下禁止動態程式的解析(例如static目錄下禁止運行擴展名為php py pl sh的文件)防止木馬程式上傳之後運行

1.6 防止功能變數名稱惡意解析(建立預設ip訪問規則),即當用戶直接用ip訪問的時候 我們返回501錯誤  類似jd taobao(實現方法建立一個default.conf 配置預設返回501

1.7 為nginx降權 實現普通用戶啟動管理nginx服務

1.8 隱藏nginx版本 通過server_tokens off實現 很基本

1.9 站點防止爬蟲優化 可以在站點 根目錄下建立robots.txt 告知相應的防止爬蟲優化,然後通過nginx的http_user_agent 參數實現訪問控制

 

 -----------------性能優化

性能和安全是互為負相關的方面 最好取其平衡

 

2.1    日誌優化 在真是rs伺服器上關閉靜態資源日誌記錄的功能(l例如jpg css js等)如果併發很大的情況下 要關閉真實伺服器的日誌記錄功能 ,因為日誌記錄消耗資源io很明顯 在負載均衡上開啟日誌記錄即可。

2.2    配置主要標簽的worker_processes數量 根據cpu核數 確定一般是1:1 對多不超過二倍

2.3    配置cpu親和力worker_cpu_affinity 平均分配cpu資源

2.4    配置worker打開的文件數量 worker_rlimit_nofile

2.5    配置event 標簽 調整連接數worker_connections 生產場景一般為4096

2.6    開啟高效傳輸模式 sendfile on

2.7    開啟資源壓縮 gzip on (gzip_comp_level 6 gzip_min_length gzip_types gzip_http_version gzip_buffers )可以通過yslow 瀏覽器插件檢查站點是否啟用壓縮

2.8    開啟緩存 expires 一般在靜態資源下開啟緩存功能 例如圖片 css (expires 365d,經常變換的圖片或者資源要儘量改的時間短一點,因為有些東西不希望到的是未更新的 例如廣告

2.9    fastcgi相關參數的優化,以及基於內核的參數優化 sysctl.conf

 

  -------------------架構優化

架構優化的目的是綜合提升性能和安全

實現原理是把不同的資源(通過擴展名實現)進行拆分,不同的訪問進行拆分(通過url實現)也可以叫做解耦,通過這樣操作可以提升靜態資源的訪問效率

 

3.1通過nginx的代理功能對有固定功能變數名稱的資源 進行不同伺服器的指向 把動態靜態資源分不同的upstream訪問 這樣靜態資源伺服器上不用安裝相應的動態資源解析程式 例如tomcat 和php  一般大公司會選擇這樣的方案 例如淘寶圖片伺服器 static.taobao.com等等

配置案例

server {

        listen       80;

        server_name  dynamic.wanda.cn;

        location / {

                proxy_pass http://dynamic_pool;

           

        }

}

 

server {

        listen       80;

        server_name  static.wanda.cn;

        location / {

                proxy_pass http://static_pool;

        }

}

3.2如果站點沒有實現動靜資源功能變數名稱獨立 那麼可以通過nginx的基於目錄和擴展名的的proxy_pass 進行動態靜態 資源的不同伺服器rs節點的指向 。這一點是中小企業方案

server {

           listen 80;

           server_name www.wanda.cn;

location /static {

        proxy_pass http://image_pool;

        }

           location / {  #預設包含了動態和靜態

                    proxy_pass http://dynamic_pool;

}

}

3.3 如果條件准許,最好在nginx代理上面加上proxy_cache的功能 緩存rs節點的靜態資源,減少對rs後端的請求,相同的資源 減少請求 就提升了性能

   簡單介紹一下nginx_cache的實現思路:

 

   首先在nginx代理伺服器上 建立一個目錄 (掛載到記憶體下麵的 tmpfs格式文件系統)

   mount -t tmpfs tmpfs /tmp

   然後,在nginx的http標簽內 添加以下參數 告知nginx代理 緩存的路徑在哪 緩存的zone名稱是什麼 我們的名字就叫cache 大小為64m緩存

proxy_cache_path /tmp levels=1:2 keys_zone=cache:64m;

在server標簽下  加入以下紅色內容

    server {

        listen       80;

        server_name  www.wanda.cn;

        location / {

                proxy_pass http://dynamic_pool;

                proxy_cache cache;

        }

}

重啟nginx -s reload

 

重新訪問以下站點目錄 帶有圖片的網頁 然後可以看到/tmp目錄下生成了緩存文件  ,通過配置 日誌參數 添加 $upstream_cache_status 再次訪問 可以檢測是否去使用了緩存 如果狀態為hit說明命中 配置成功

 

 

好了 總結了一個多小時 關於nginx優化如果大家有更好的方法 歡迎一起探討

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 自增和自減運算 自增和自減運算 比較運算符與比較表達式 比較運算符與比較表達式 邏輯運算符與邏輯表達式 邏輯運算符與邏輯表達式 IF結構 IF結構 變數的作用域 變數的作用域 ...
  • 當應用伺服器受到攻擊,我們採取的措施大致分為以下幾個步驟: 1、伺服器隔離 檢查埠,禁掉網卡 2、修改賬號、密碼,防火牆策略等 3、殺毒 4、應用重新部署 當然,這些工作大部分是由伺服器維護人員來做,對於我們開發人員來說,也是可以貢獻自己一份力量的, 比如部署應用配置項的時候資料庫連接採用加密手段 ...
  • twemproxy概述 twemproxy是搭建分散式緩存集群的重要組件之一。他能將來自客戶端的redis包通過key分片發送到不同的redis伺服器,而不是發到單個redis伺服器上。因此,可以使本來集中到一個redis上的信息被分流到幾個redis上,這就使得 twemproxy能支持redis ...
  • 本文地址 分享提綱: 1. 概述 2. 詳解配置文件 3. 詳解日誌 1.概述 MySQL配置文件在Windows下叫my.ini,在MySQL的安裝根目錄下;在Linux下叫my.cnf,該文件位於/etc/my.cnf。 2. 詳解配置文件 basedir = path 使用給定目錄作為根目錄( ...
  • MySQL 約束 作用:保證數據的完整性和一致性按照約束的作用範圍分為:表級約束和行級約束。常見的約束類型包括: Not null(非空約束) Primary key (主鍵約束) Unique key(唯一約束) Default (預設約束) foreign key(外鍵約束) 外鍵約束 1.父表 ...
  • 最近在學習linux,在某個用戶(xxx)下使用sudo的時候,提示以下錯誤:xxx is not in the sudoers file. This incident will be reported。 百度了下,究其原因是用戶沒有加入到sudo的配置文件里。 解決方法如下: 1、切換到root用 ...
  • 第八節 Linux 文件的屬性(下半部分) 標簽(空格分隔): Linux教學筆記 [更多相關資料請點我查看][1] 第1章 鏈接的概念 在linux系統中,鏈接可分為兩種:一種為硬鏈接(Hard Link),另一種為軟連接或符號鏈接(Symbolic Link or Soft link)。我們在前 ...
  • 一.以查詢方式實現 1.寫出驅動框架 1.1 仿照其他程式加一些必要的頭文件 1.2 構造一個結構體file_operations 1.3 根據file_operations的所選項寫出所需的函數,並構建出來 1.4 入口函數、出口函數的註冊和卸載 1.5 修飾入口函數和出口函數 1.6 給sysf ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...