Nginx動靜分離介紹
Nginx的靜態處理能力很強,但是動態處理能力不足,因此,在企業中常用動靜分離技術
針對PHP的動靜分離
- 靜態頁面交給Nginx處理
- 動態頁面交給PHP-FPM模塊或Apache處理
在Nginx的配置中,是通過location配置段配合正則匹配實現靜態與動態頁面的不同處理方式
反向代理原理
Nginx不僅能作爲Web服務器,還具有反向代理、負載均衡和緩存的功能
Nginx通過proxy模塊實現將客戶端的請求代理至上游服務器,此時nginx與上游服務器的連接是通過http協議進行的
Nginx在實現反向代理功能時的最重要指令爲proxy_ pass,它能夠並能夠根據URI、客戶端參數或其它的處理邏輯將用戶請求調度至上游服務器。
本案例根據企業需要,將配置Nginx實現動靜分離,對php頁面的請求轉發給LAMP處理,而靜態頁面交給Nginx處理,以實現動靜分離
架構如圖所示:
實驗環境
部署好的LAMP架構、部署好的LNMP架構
具體搭建架構的過程詳情可查看博客:
https://blog.51cto.com/14557905/category5.html
實驗過程
一、
1.架設並調試後端LAMP環境
安裝Apache服務
yum install httpd httpd-devel -y
2.在防火牆設置http服務的權限
[root@localhost ~]# firewall-cmd --permanent --zone=public --add-service=http
success #允許http、https服務開啓,允許通過防火牆
[root@localhost ~]# firewall-cmd --permanent --zone=public --add-service=https
success
[root@localhost ~]# firewall-cmd --reload
success #重新加載防火牆
[root@localhost ~]# systemctl start httpd
3.安裝mariadb數據庫
mariadb數據庫管理系統是MySQL的一個分支,主要由開源社區在維護,採用GPL授權許可 mariadb的目的是完全兼容MySQL,包括API和命令行,使之能輕鬆成爲MySQL的代替品
[root@localhost ~]# yum install mariadb mariadb-server mariadb-libs mariadb-devel -y
[root@localhost ~]# systemctl start mariadb.service
4.mysql安全配置嚮導
[root@localhost ~]# mysql_secure_installation
5.安裝php及支持的軟件
[root@localhost ~]# yum install php -y
[root@localhost ~]# yum install php-mysql -y
[root@localhost ~]# yum install php-gd php-ldap php-odbc php-pear php-xml php-xmlrpc php-mbstring php-snmp php-soap curl curl-devel php-bcmath -y
6.修改網頁主頁面
[root@localhost ~]# cd /var/www/html
[root@localhost html]# vim index.php
<?php
echo "this is apache test web";
?>
[root@localhost html]# systemctl restart httpd
訪問測試:
二、編譯安裝nginx
手工編譯安裝nginx過程可查看:
https://blog.51cto.com/14557905/2460945
1.部署nginx服務管理控制
[root@localhost ~]# vim /etc/init.d/nginx
#!/bin/bash
# chkconfig: - 99 20
# description: Ngins Service Control Script
PROG="/usr/local/nginx/sbin/nginx"
PIDF="/usr/local/nginx/logs/nginx.pid"
case "$1" in
start)
$PROG
;;
stop)
kill -s QUIT $(cat $PIDF)
;;
restart)
$0 stop
$0 start
;;
reload)
kill -s HUP $(cat $PIDF)
;;
*)
echo "Usage: $0 {start|stop|restart|reload}"
exit 1
esac
exit 0
[root@localhost ~]# chmod +x /etc/init.d/nginx #提權
[root@localhost ~]# chkconfig --add nginx #指定用戶
[root@localhost ~]# service nginx start #開啓服務
2.啓動服務,關閉防火牆
[root@nginx ~]# systemctl stop firewalld.service
[root@nginx ~]# setenforce 0
[root@nginx ~]# service nginx start
訪問測試