學習nginx基礎知識
一.什么是nginx?
nginx是一個高性能的http和反向代理的web服務器,占內存少,并發(fā)力強。有報告顯示nginx可以高達50000個并發(fā)連接數(shù)。
二.nginx能干什么?
- 反向代理
- 負載均衡
- 動靜分離
- 高可用集群
2.1 什么是正向代理?
客戶端(瀏覽器)配置代理服務器,通過代理服務器進行互聯(lián)網(wǎng)之間的訪問。
2.2 什么是反向代理?
客戶端將請求發(fā)送到反向代理服務器,由反向代理服務器去獲取數(shù)據(jù)后,再返回給客戶端。
2.3負載均衡
客戶端發(fā)送多個請求到服務器,服務器處理請求,由一些數(shù)據(jù)需要和數(shù)據(jù)庫進行交互,服務器處理完畢后,再將結果返回給客戶端。
如果單個服務器解決不,就搭建服務器集群實現(xiàn)
2.4 動靜分離
為了提高網(wǎng)站的解析速度,將動態(tài)頁面和靜態(tài)頁面由不同的服務器來解析,降低原來單個服務器的壓力。
三.nginx基本操作
1.使用之前,先進入nginx目錄
2.查看nginx的版本號
./nginx -v
3.啟動nginx
./nginx
4.關閉nginx
./nginx -s stop
5.重新加載nginx
./nginx -s reload
6.查看nginx的狀態(tài)
ps -ef | grep nginx
3.1 nginx配置文件 nginx/conf/nginx.conf
1.全局塊
從配置文件到events塊之間的內容。
2.events塊
events塊指令主要影響nginx服務器與用戶的網(wǎng)絡連接,worker connections 1024 支持的最大連接數(shù)
3.http塊
3.2 防火墻設定
// 查看開放的端口號 firewall-cmd --list-all // 設置開放的端口號 firewall-cmd --add-service=http –permanent // 在防火墻中永久開啟 http 服務 firewall-cmd --add-port=80/tcp --permanent // 在防火墻中永久開啟 80 端口 // 重啟防火墻 firewall-cmd –reload
四.反向代理實現(xiàn)案例
4.1.Nginx反向代理的實現(xiàn)案例1
效果:輸入一個地址,跳轉到tomcat首頁
nginx 配置反向代理,主要是通過 proxy_pass 配置進行請求的轉發(fā)
1.hosts 文件域名配置
在windows系統(tǒng)的host文件(C盤Windods/System32/driver/etc/hosts)進行域名和ip對應關系的配置
2.nginx里進行請求轉發(fā)的配置(反向代理配置) nginx.conf
主要修改 server_name、proxy_pass 兩個配置:
- server_name:主機IP
- proxy_pass:nginx 代理地址
測試成功
4.2Nginx反向代理的實現(xiàn)案例2
使用nginx反向代理,根據(jù)訪問的路徑跳轉到不用的服務端口中,nginx監(jiān)聽端口是9001
1.準備工作
部署tomcat 8080
部署tomcat8081
因為tomcat默認的端口號是8080,所以要設定tomcat的端口號時,需要修改server.xml中的部分端口,啟動tomcat
在兩個tomcat文件中找到webapps,在其目錄下建立兩個文件edu,vod,里面放入里那個html頁面,并測試頁面可成功訪問。
2.找到nginx配置文件 nginx.conf
server { listen 9001; server_name 192.168.25.101; location ~ /edu/ { proxy_pass http://127.0.0.1:8080; } location ~ /vod/ { proxy_pass http://127.0.0.1:8081; } }
3.開放訪問端口 8080 8081 9001,否則訪問不到
4.重啟nginx,測試
五.負載均衡實現(xiàn)案例
1.實現(xiàn)效果
瀏覽器地址中輸入一個地址http://192.168.17.129/edu/a.html,負載均衡效果,平均分配到8080和8081端口中
2.準備工作
1.部署tomcat 8080,部署tomcat 8081
2.在兩臺tomcat里面webapps目錄中,創(chuàng)建名稱為edu文件夾,在文件夾里面創(chuàng)建兩個頁面a.html,用于測試
3.在nginx的配置文件里做出相應的配置,在http下做配置
upstreat myserver{ //添加服務器名 server 192.168.17.129;8080; server 192.168.17.129;8081; }
然后再servers和Locationa下做配置
server_name 192.168.17.129: location /{ proxy_pass http://myserver; }
5.1nginx負載均衡的策略
- 輪詢(默認)
每個請求按時間順序注意分配的不同的后端服務器,如果后端服務器宕機,就能自動剔除
- weight
weight代表權重,默認為1,權重越高分配的客戶端越多
使用:
upstreat myserver{ //添加服務器名 server 192.168.17.129;8080 weight =10; server 192.168.17.129;8081 weight = 20; }
- ip_hash
每個請求按訪問IP的hash結果分配,這樣后續(xù)就可固定 訪問一個后端服務器
- fair
根據(jù)響應時間來進行分配,響應時間的長短來分配
upstreat myserver{ //添加服務器名 server 192.168.17.129;8080 ; server 192.168.17.129;8081; fair; }
六、nginx動靜分離
6.1、實現(xiàn)過程
通過location指定不同的后綴實現(xiàn)不同的請求轉發(fā)。通過expires參數(shù)的配置,可以設定一個瀏覽器緩存過期時間,減少與服務器之間的請求和流量。
6.2、案例
1.準備靜態(tài)資源
2.具體的配置
- 1.在nginx配置文件中配置 nginx/conf
- 2.輸入網(wǎng)址進行訪問
七、Nginx配置高可用
7.1 什么是Nginx的高可用?
由圖可知,對于之前操作模式來說,只有一臺nginx時,將用戶的請求通過nginx進行轉發(fā)到不同的tomcat之中,當其中的nginx宕機時,就會造成服務的轉發(fā)失敗,因此通過搭建nginx集群,當主服務器nginx宕機時,備份服務器的ngnix會將用戶的請求重新轉發(fā)tomcat中,從而保證了高可用。
7.2、nginx配置高可用準備
- 準備兩臺服務器 192.168.17.129 和 192.268.17.131
- 兩臺服務器都安裝nginx
- 配置一個虛擬地址
- 在兩臺服務器安裝keepalived 直接通過yum安裝
yum install keepalive -y
7.3、高可用配置
完成keepalive的配置,找到keeplive配置文件keepalive.conf
(1)修改/etc/keepalived/keepalivec.conf 配置文件
global_defs { notification_email { acassen@firewall.loc failover@firewall.loc sysadmin@firewall.loc } notification_email_from Alexandre.Cassen@firewall.loc smtp_server 192.168.17.129 smtp_connect_timeout 30 router_id LVS_DEVEL } vrrp_script chk_http_port { script "/usr/local/src/nginx_check.sh" interval 2 #(檢測腳本執(zhí)行的間隔) weight 2 } vrrp_instance VI_1 { state BACKUP # 備份服務器上將 MASTER 改為 BACKUP interface ens33 //網(wǎng)卡 virtual_router_id 51 # 主、備機的 virtual_router_id 必須相同 priority 90 # 主、備機取不同的優(yōu)先級,主機值較大,備份機值較小 advert_int 1 authentication { auth_type PASS auth_pass 1111 } virtual_ipaddress { 192.168.17.50 // VRRP H 虛擬地址 } }
(2)在/usr/local/src 添加檢測腳本
A=`ps -C nginx – no-header |wc -l` if [ $A -eq 0 ];then /usr/local/nginx/sbin/nginx sleep 2 if [ `ps -C nginx --no-header |wc -l` -eq 0 ];then killall keepalived fi fi
(3)把兩臺服務器上 nginx 和 keepalived 啟動
啟動 nginx: ./nginx
啟動 keepalived: systemctl start keepalived.service
7.4、測試
1).在瀏覽器地址輸入虛擬ip地址:192.168.17.50
既可以直接訪問
2)當把主服務器nginx和keepalived停止,在次輸入虛擬地址的時候,頁面依舊可以訪問
八、nginx工作原理
master & worker
8.1、一個 master 和多個 woker 有好處
- 對于每個 worker 進程來說,獨立的進程,不需要加鎖,所以省掉了鎖帶來的開銷,同時在編程以及問題查找時,也會方便很多,可以使用 nginx –s reload 熱部署,利用 nginx 進行熱部署操作
- 每個 woker 是獨立的進程,如果有其中的一個 woker 出現(xiàn)問題,其他 woker 獨立的,繼續(xù)進行爭搶,實現(xiàn)請求過程,不會造成服務中斷。
8.2 、設置多少個 woker 合適
- worker 數(shù)和服務器的 cpu 數(shù)相等是最為適宜的。(比如說: 你的電腦是4核,設置4個worker就足矣,如果是八核,設置8個worker足矣)
8.3、連接數(shù) worker_connection
第一個:發(fā)送請求,占用了 woker 的幾個連接數(shù)?
答案: 2 或者 4 個
第二個: nginx 有一個 master,有四個 woker,每個 woker 支持最大的連接數(shù) 1024,支持的最大并發(fā)數(shù)是多少?
- 普通的靜態(tài)訪問最大并發(fā)數(shù)是: worker_connections * worker_processes /2,
- 而如果是 HTTP 作 為反向代理來說,最大并發(fā)數(shù)量應該是 worker_connections *worker_processes/4。
到此這篇關于學習nginx基礎知識的文章就介紹到這了,更多相關nginx基礎內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Nginx設置目錄的訪問權限實現(xiàn)訪問靜態(tài)資源
遇到Permission denied錯誤,通常是Nginx用戶權限不足,本文就來介紹一下Nginx設置目錄的訪問權限實現(xiàn)訪問靜態(tài)資源2024-10-10nginx php-fpm中啟用慢日志配置(用于檢測執(zhí)行較慢的PHP腳本)
這篇文章主要介紹了nginx php-fpm中啟用慢日志配置,php-fpm慢日志slowlog設置可以讓我們很好的看見哪些php進程速度太慢而導致的網(wǎng)站問題,可以讓我們方便的找到問題的所在,需要的朋友可以參考下2014-05-05解析prometheus+grafana監(jiān)控nginx的方法
?在prometheus需要向ngxin中打入探針,通過探針獲取ngxin信息,并通過接口輸出。下文將講述如何監(jiān)控ngxin,感興趣的朋友跟隨小編一起看看吧2021-11-11解決nginx 503 Service Temporarily Unavailable方法示例
這篇文章主要介紹了解決nginx 503 Service Temporarily Unavailable方法示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-12-12