目錄
- 一.什么是nginx?
- 二.nginx能干什么?
- 2.1 什么是正向代理?
- 2.2 什么是反向代理?
- 2.3負載均衡
- 2.4 動靜分離
- 三.nginx基本操作
- 3.1 nginx配置文件 nginx/conf/nginx.conf
- 3.2 防火墻設定
- 四.反向代理實現(xiàn)案例
- 4.1.Nginx反向代理的實現(xiàn)案例1
- 1.hosts 文件域名配置
- 2.nginx里進行請求轉發(fā)的配置(反向代理配置) nginx.conf
- 4.2Nginx反向代理的實現(xiàn)案例2
- 五.負載均衡實現(xiàn)案例
- 六、nginx動靜分離
- 七、Nginx配置高可用
- 7.1 什么是Nginx的高可用?
- 7.2、nginx配置高可用準備
- 7.3、高可用配置
- 7.4、測試
- 八、nginx工作原理
- 8.1、一個 master 和多個 woker 有好處
- 8.2 、設置多少個 woker 合適
- 8.3、連接數 worker_connection
一.什么是nginx?
nginx是一個高性能的http和反向代理的web服務器,占內存少,并發(fā)力強。有報告顯示nginx可以高達50000個并發(fā)連接數。
二.nginx能干什么?
2.1 什么是正向代理?
客戶端(瀏覽器)配置代理服務器,通過代理服務器進行互聯(lián)網之間的訪問。
2.2 什么是反向代理?
客戶端將請求發(fā)送到反向代理服務器,由反向代理服務器去獲取數據后,再返回給客戶端。
2.3負載均衡
客戶端發(fā)送多個請求到服務器,服務器處理請求,由一些數據需要和數據庫進行交互,服務器處理完畢后,再將結果返回給客戶端。
如果單個服務器解決不,就搭建服務器集群實現(xiàn)
2.4 動靜分離
為了提高網站的解析速度,將動態(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服務器與用戶的網絡連接,worker connections 1024 支持的最大連接數
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反向代理,根據訪問的路徑跳轉到不用的服務端口中,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代表權重,默認為1,權重越高分配的客戶端越多
使用:
upstreat myserver{
//添加服務器名
server 192.168.17.129;8080 weight =10;
server 192.168.17.129;8081 weight = 20;
}
每個請求按訪問IP的hash結果分配,這樣后續(xù)就可固定 訪問一個后端服務器
根據響應時間來進行分配,響應時間的長短來分配
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參數的配置,可以設定一個瀏覽器緩存過期時間,減少與服務器之間的請求和流量。
6.2、案例
1.準備靜態(tài)資源
2.具體的配置
- 1.在nginx配置文件中配置 nginx/conf
七、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安裝
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 //網卡
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 數和服務器的 cpu 數相等是最為適宜的。(比如說: 你的電腦是4核,設置4個worker就足矣,如果是八核,設置8個worker足矣)
8.3、連接數 worker_connection
第一個:發(fā)送請求,占用了 woker 的幾個連接數?
答案: 2 或者 4 個
第二個: nginx 有一個 master,有四個 woker,每個 woker 支持最大的連接數 1024,支持的最大并發(fā)數是多少?
- 普通的靜態(tài)訪問最大并發(fā)數是: worker_connections * worker_processes /2,
- 而如果是 HTTP 作 為反向代理來說,最大并發(fā)數量應該是 worker_connections *worker_processes/4。
到此這篇關于學習nginx基礎知識的文章就介紹到這了,更多相關nginx基礎內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!