Nginx架構的企業級應用php
====================================================
css
實現HA高可用集羣html
實現LB負載均衡集羣node
Nginx實現反向代理python
Nginx實現動靜分離mysql
==================================================nginx
需求:web
客戶端訪問靜態的請求,由nginx反向代理給後端的Apache服務器;sql
客戶端訪問動態的請求,由nginx反向代理給後端的php-fpm(fastCGI)服務器,並且作負載均衡,若是須要訪問數據庫,則由php-fpm鏈接mysql;數據庫
若是nginx主服務器宕機以後,nginx備服務器立刻頂替主服務器,提供服務;
服務器IP規劃和所需軟件安裝:
IP地址 |
軟件 |
|
nginx主 |
172.16.22.1 (VIP 172.16.22.10) |
nginx+heartbeat |
nginx備 |
172.16.22.2 (VIP 172.16.22.10) |
nginx+heartbeat |
Apache |
172.16.22.3 |
httpd |
php-fpm1 |
172.16.22.4 |
php(提供fastCGI服務器) |
php-fpm2 |
172.16.22.5 |
php(提供fastCGI服務器) |
mysql |
172.16.22.6 |
mysql |
heartbeat軟件包,已經以附件的形式上傳了nginx、php、mysql的軟件包在網上都很好下載
需解決的問題:
1)、怎麼實現HA高可用集羣
思路:安裝heartbeat軟件,把nginx主服務器和nginx備服務器這兩個節點都加入到heartbeat中,用heartbeat的crm管理資源,定義高可用集羣
2)、怎麼實現LB負載均衡集羣
思路:利用nginx的upstream模塊,配置實現應用層的負載均衡
3)、nginx怎麼把客戶的靜態請求提交給後端的Apache服務器聯繫
思路:利用nginx的反向代理給後端的Apache服務器
4)、nginx怎麼把客戶的動態請求提交給後端的php-fpm服務器聯繫
思路:首先nginx支持fastCGI,而後利用nginx的反向代理給php-fpm服務器
5)、php-fpm服務器怎麼和mysql服務器聯繫
思路:mysql受權能讓php-fpm服務器鏈接數據庫
1、先安裝每一個服務器所需的軟件
nginx主服務器的配置:
1)、編譯安裝nginx
[root@jie1 ~]# ifconfig | grep "inet addr" | grep -v "127.0.0.1" | awk -F: '{print $2}' | cut -d' ' -f1 查看ip地址 172.16.22.1 [root@jie1 ~]#tar xf nginx-1.4.2.tar.gz [root@jie1 ~]# yum -y groupinstall "Development tools" "Server Platform Development" 安裝開發包 [root@jie1 ~]#yum -y install pcre-devel 安裝依賴性包 [root@jie1 ~]# cd nginx-1.4.2 [root@jie1 nginx-1.4.2]# groupadd nginx [root@jie1 nginx-1.4.2]# useradd -r -g nginx nginx [root@jie1 nginx-1.4.2]#./configure \ --prefix=/usr \ --sbin-path=/usr/sbin/nginx \ --conf-path=/etc/nginx/nginx.conf \ --error-log-path=/var/log/nginx/error.log \ --http-log-path=/var/log/nginx/access.log \ --pid-path=/var/run/nginx/nginx.pid \ --lock-path=/var/lock/nginx.lock \ --user=nginx \ --group=nginx \ --with-http_ssl_module \ --with-http_flv_module \ --with-http_stub_status_module \ --with-http_gzip_static_module \ --http-client-body-temp-path=/var/tmp/nginx/client/ \ --http-proxy-temp-path=/var/tmp/nginx/proxy/ \ --http-fastcgi-temp-path=/var/tmp/nginx/fcgi/ \ --http-uwsgi-temp-path=/var/tmp/nginx/uwsgi \ --http-scgi-temp-path=/var/tmp/nginx/scgi \ --with-pcre [root@jie1 nginx-1.4.2]# make && make install
2)、提供System V腳本
[root@jie1 nginx-1.4.2]# vim /etc/rc.d/init.d/nginx #!/bin/sh # # nginx - this script starts and stops the nginx daemon # # chkconfig: - 85 15 # description: Nginx is an HTTP(S) server, HTTP(S) reverse \ # proxy and IMAP/POP3 proxy server # processname: nginx # config: /etc/nginx/nginx.conf # config: /etc/sysconfig/nginx # pidfile: /var/run/nginx.pid # Source function library. . /etc/rc.d/init.d/functions # Source networking configuration. . /etc/sysconfig/network # Check that networking is up. [ "$NETWORKING" = "no" ] && exit 0 nginx="/usr/sbin/nginx" prog=$(basename $nginx) NGINX_CONF_FILE="/etc/nginx/nginx.conf" [ -f /etc/sysconfig/nginx ] && . /etc/sysconfig/nginx lockfile=/var/lock/subsys/nginx make_dirs() { # make required directories user=`nginx -V 2>&1 | grep "configure arguments:" | sed 's/[^*]*--user=\([^ ]*\).*/\1/g' -` options=`$nginx -V 2>&1 | grep 'configure arguments:'` for opt in $options; do if [ `echo $opt | grep '.*-temp-path'` ]; then value=`echo $opt | cut -d "=" -f 2` if [ ! -d "$value" ]; then # echo "creating" $value mkdir -p $value && chown -R $user $value fi fi done } start() { [ -x $nginx ] || exit 5 [ -f $NGINX_CONF_FILE ] || exit 6 make_dirs echo -n $"Starting $prog: " daemon $nginx -c $NGINX_CONF_FILE retval=$? echo [ $retval -eq 0 ] && touch $lockfile return $retval } stop() { echo -n $"Stopping $prog: " killproc $prog -QUIT retval=$? echo [ $retval -eq 0 ] && rm -f $lockfile return $retval } restart() { configtest || return $? stop sleep 1 start } reload() { configtest || return $? echo -n $"Reloading $prog: " killproc $nginx -HUP RETVAL=$? echo } force_reload() { restart } configtest() { $nginx -t -c $NGINX_CONF_FILE } rh_status() { status $prog } rh_status_q() { rh_status >/dev/null 2>&1 } case "$1" in start) rh_status_q && exit 0 $1 ;; stop) rh_status_q || exit 0 $1 ;; restart|configtest) $1 ;; reload) rh_status_q || exit 7 $1 ;; force-reload) force_reload ;; status) rh_status ;; condrestart|try-restart) rh_status_q || exit 0 ;; *) echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart|reload|force-reload|configtest}" exit 2 esac [root@jie1 nginx-1.4.2]# chmod +x /etc/rc.d/init.d/nginx [root@jie1 nginx-1.4.2]# service nginx start Starting nginx: [ OK ] [root@jie1 nginx-1.4.2]#
3)、編譯安裝src格式的heartbeat的源碼包
[root@jie1 ~]# useradd mockbuild 建立此用戶用於編譯src的源碼包 [root@jie1 ~]# rpm -ivh heartbeat-2.1.4-12.el6.src.rpm 1:heartbeat ################################### [100%] [root@jie1 ~]# yum -y install rpm-build [root@jie1 ~]#cd rpmbuild/ [root@jie1 rpmbuild]# cd SPECS/ [root@jie1 rpmbuild]# yum -y install glib2-devel libnet-devel libtool-ltdl-devel net-snmp-devel openhpi-libs gnutls-devel python-devel [root@jie1 rpmbuild]# rpmbuild -ba heartbeat.spec [root@jie1 x86_64# pwd /root/rpmbuild/RPMS/x86_64 [root@jie1 x86_64#ls 生成的全部軟件包 heartbeat-2.1.4-12.el6.x86_64.rpm heartbeat-ldirectord-2.1.4-12.el6.x86_64.rpm heartbeat-debuginfo-2.1.4-12.el6.x86_64.rpm heartbeat-pils-2.1.4-12.el6.x86_64.rpm heartbeat-devel-2.1.4-12.el6.x86_64.rpm heartbeat-stonith-2.1.4-12.el6.x86_64.rpm heartbeat-gui-2.1.4-12.el6.x86_64.rpm [root@jie1 x86_64]#mv heartbeat-debuginfo-2.1.4-12.el6.x86_64.rpm heartbeat-ldirectord-2.1.4-12.el6.x86_64.rpm heartbeat-devel-2.1.4-12.el6.x86_64.rpm /root 有些軟件包沒必要安裝,因此移動到別的目錄下 [root@jie1 x86_64]#ls heartbeat-2.1.4-12.el6.x86_64.rpm heartbeat-pils-2.1.4-12.el6.x86_64.rpm heartbeat-gui-2.1.4-12.el6.x86_64.rpm heartbeat-stonith-2.1.4-12.el6.x86_64.rpm [root@jie1 x86_64]#yum -y install PyXML 安裝依賴性包 [root@jie1 x86_64]# rpm -ivh *.rpm 直接安裝此目錄下的全部rpm包 Preparing... ################################# [100%] 1:heartbeat-pils ################################# [ 25%] 2:heartbeat-stonith ################################# [ 50%] 3:heartbeat ################################# [ 75%] 4:heartbeat-gui ################################# [100%] [root@jie1 x86_64]#
4)、建立heartbeat的配置文件和認證文件,以及修改hosts文件,使HA的節點能用主機名進行通訊
[root@jie1 ~]# cd /usr/share/doc/heartbeat-2.1.4/ [root@jie1 heartbeat-2.1.4]# cp authkeys ha.cf /etc/ha.d/ [root@jie1 heartbeat-2.1.4]# vim /etc/hosts 172.16.22.1 jie1.com jie1 172.16.22.2 jie2.com jie2
5)、修改heartbeat的配置文件和認證文件
[root@jie1 heartbeat-2.1.4]# cd /etc/ha.d/ [root@jie1 ha.d]# openssl rand -hex 8 #生成隨機數 29c59aeaf3109993 [root@jie1 ha.d]# sed -e '/^#/d' authkeys auth 3 3 md5 29c59aeaf3109993 #把生成的隨機數 [root@jie1 ha.d]# chmod 600 authkeys [root@jie1 ha.d]# grep -v "^#" ha.cf | grep -v "^$" logfile /var/log/ha-log #日誌存放位置 keepalive 2 #心跳的時間間隔,默認時間單位爲秒 deadtime 3 # 超出該時間間隔未收到對方節點的心跳,則認 爲對方已經死亡 warntime 10 #超出該時間間隔未收到對方節點的心跳,則發出警告並記錄到日誌中,但此時不會切換 initdead 60 #在某些系統上,系統啓動或重啓以後須要通過一段時間網絡才能正常工做,該選項用於解決這種狀況產生的時間間隔。 udpport 694 #設置廣播通訊使用的端口,694爲默認使用的端口號 mcast eth0 225.23.32.1 694 1 0 #多播地址 auto_failback on #用於定義當主節點恢復後,是否將服務自動切回 node jie1.com #必須寫hostname顯示的主機名,節點一的主機名 node jie2.com ping 172.16.0.1 #用ping網關,來驗證節點是否宕機 crm on [root@jie1 ha.d]#
6)、把nginx的服務腳本加入到heartbeat的資源目錄下,讓heartbeat的crm(資源管理層)來管理nginx服務。
[root@jie1 heartbeat-2.1.4]# cd /etc/ha.d/ [root@jie1 ha.d]# cd resource.d/ [root@jie1 resource.d]# cp /etc/rc.d/init.d/nginx ./ [root@jie1 resource.d]# service nginx stop 關閉nginx服務,讓heartbeat來管理 Stopping nginx: [ OK ] [root@jie1 resource.d]#passwd hacluster 爲hacluster用戶建立密碼
nginx備服務器的配置:
1)、編譯安裝nginx
[root@jie2 ~]# ifconfig | grep "inet addr" | grep -v "127.0.0.1" | awk -F: '{print $2}' | cut -d' ' -f1 查看ip地址 172.16.22.2 [root@jie2 ~]#tar xf nginx-1.4.2.tar.gz [root@jie2 ~]# yum -y groupinstall "Development tools" "Server Platform Development" 安裝開發包 [root@jie2 ~]#yum -y install pcre-devel 安裝依賴性包 [root@jie2 ~]# cd nginx-1.4.2 [root@jie2 nginx-1.4.2]# groupadd nginx [root@jie2 nginx-1.4.2]# useradd -r -g nginx nginx [root@jie2 nginx-1.4.2]#./configure \ --prefix=/usr\ --sbin-path=/usr/sbin/nginx\ --conf-path=/etc/nginx/nginx.conf \ --error-log-path=/var/log/nginx/error.log \ --http-log-path=/var/log/nginx/access.log \ --pid-path=/var/run/nginx/nginx.pid \ --lock-path=/var/lock/nginx.lock \ --user=nginx \ --group=nginx \ --with-http_ssl_module \ --with-http_flv_module \ --with-http_stub_status_module \ --with-http_gzip_static_module \ --http-client-body-temp-path=/var/tmp/nginx/client/\ --http-proxy-temp-path=/var/tmp/nginx/proxy/\ --http-fastcgi-temp-path=/var/tmp/nginx/fcgi/\ --http-uwsgi-temp-path=/var/tmp/nginx/uwsgi\ --http-scgi-temp-path=/var/tmp/nginx/scgi\ --with-pcre [root@jie2 nginx-1.4.2]# make && make install
2)、複製nginx主服務器的System V腳本文件和heartbeat所需的軟件包
[root@jie2 ~]# scp 172.16.22.1:/etc/rc.d/init.d/nginx /etc/rc.d/init.d/ [root@jie2 ~]#scp 172.16.22.1:/root/rpmbuild/RPMS/x86_64/* /root [root@jie2 ~]# ls anaconda-ks.cfg install.log heartbeat-2.1.4-12.el6.x86_64.rpm install.log.syslog heartbeat-gui-2.1.4-12.el6.x86_64.rpm heartbeat-pils-2.1.4-12.el6.x86_64.rpm heartbeat-stonith-2.1.4-12.el6.x86_64.rpm [root@jie2 ~]#
3)、安裝從nginx主服務器copy過來的heartbeat軟件
[root@jie2 ~]# yum -y install PyXML libnet-devel net-snmp-libs [root@jie2 ~]# rpm -ivh *.rpm Preparing... ################################### [100%] 1:heartbeat-pils ################################### [ 25%] 2:heartbeat-stonith ################################### [ 50%] 3:heartbeat ################################### [ 75%] 4:heartbeat-gui ################################### [100%] [root@jie2 ~]#
4)、因爲是HA集羣,HA集羣必須保證節點的配置文件徹底同樣,在這裏咱們直接把nginx主服務器的heartbeat的配置文件copy過來。
[root@jie2 ~] scp 172.16.22.1:/etc/ha.d/{ha.cf,authkeys} /etc/ha.d/ root@172.16.22.1's password: ha.cf 100% 10KB 10.3KB/s 00:00 root@172.16.22.1's password: authkeys 100% 653 0.6KB/s 00:00 [root@jie2 ~] scp 172.16.22.1:/etc/hosts /etc/ root@172.16.22.1's password: hosts 100% 250 0.2KB/s 00:00
5)、把nginx的服務腳本加入到heartbeat的資源目錄下,讓heartbeat的crm(資源管理層)來管理nginx服務。
[root@jie2 ~]# cd /etc/ha.d/ [root@jie2 ha.d]# cd resource.d/ [root@jie2 resource.d]# cp /etc/rc.d/init.d/nginx ./ [root@jie2 resource.d]# service nginx stop 關閉nginx服務,讓heartbeat來管理 Stopping nginx: [ OK ] [root@jie2 resource.d]#passwd hacluster 爲hacluster用戶建立密碼
Apache服務器的配置:
apache博主採用rpm包安裝,各位博友能夠採用源碼包編譯安裝
[root@jie3 ~]# ifconfig | grep "inet addr" | grep -v "127.0.0.1" | awk -F: '{print $2}' | cut -d' ' -f1 查看ip地址 172.16.22.3 [root@jie3 ~]# yum -y install httpd [root@jie3 ~]# service httpd start
php-fpm1服務器的配置:
1)、安裝php,編譯支持fpm
[root@jie4 ~]# ifconfig | grep "inet addr" | grep -v "127.0.0.1" | awk -F: '{print $2}' | cut -d' ' -f1 查看ip地址 172.16.22.4 [root@jie4 ~]# tar xf php-5.4.19.tar.bz2 [root@jie4 ~]# yum -y groupinstall "Development tools" "Server Platform Development" 安裝開發包組 [root@jie4 ~]# yum -y install libmcrypt-devel mhash-devel bzip2-devel libxml2-devel 安裝依賴性包 [root@jie4 ~]# cd php-5.4.19 [root@jie4 php-5.4.19]# ./configure --prefix=/usr/local/php --enable-fpm --with-openssl --enable-mbstring \ --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib --with-libxml-dir=/usr --enable-xml \ --enable-sockets --with-mcrypt --with-bz2 --with-config-file-path=/etc --with-config-file-scan-dir=/etc/php.d \ --with-mysql=mysqlnd --with-pdo-mysql=mysqlnd --with-mysqli=mysqlnd [root@jie4 php-5.4.19]# make && make install
2)、提供php的配置文件,php-fpm的System V腳本和php-fpm的配置文件,啓動php-fpm服務
[root@jie4 php-5.4.19]# cp php.ini-production /etc/php.ini [root@jie4 php-5.4.19]# cp sapi/fpm/init.d.php-fpm /etc/rc.d/init.d/php-fpm [root@jie4 php-5.4.19]# chmod +x /etc/rc.d/init.d/php-fpm [root@jie4 php-5.4.19]# chkconfig --add php-fpm [root@jie4 php-5.4.19]# chkconfig php-fpm on [root@jie4 php-5.4.19]# cd /usr/local/php/etc/ [root@jie4 etc]# cp php-fpm.conf.default php-fpm.conf [root@jie4 etc]# vim php-fpm.conf listen = 172.16.22.4:9000 #把監聽的127.0.0.1改爲本機網卡的IP [root@jie4 etc]# service php-fpm start
php-fpm2服務器的配置(和php-fpm1服務器的安裝配置同樣):
1)、安裝php,編譯支持fpm
[root@jie5 ~]# ifconfig | grep "inet addr" | grep -v "127.0.0.1" | awk -F: '{print $2}' | cut -d' ' -f1 查看ip地址 172.16.22.5 [root@jie5 ~]# tar xf php-5.4.19.tar.bz2 [root@jie5 ~]# yum -y groupinstall "Development tools" "Server Platform Development" 安裝開發包組 [root@jie5 ~]# yum -y install libmcrypt-devel mhash-devel bzip2-devel libxml2-devel 安裝依賴性包 [root@jie5 ~]# cd php-5.4.19 [root@jie5 php-5.4.19]# ./configure --prefix=/usr/local/php --enable-fpm --with-openssl --enable-mbstring \ --with-freetype-dir--with-jpeg-dir--with-png-dir--with-zlib --with-libxml-dir=/usr--enable-xml \ --enable-sockets --with-mcrypt --with-bz2 --with-config-file-path=/etc--with-config-file-scan-dir=/etc/php.d \ --with-mysql=mysqlnd --with-pdo-mysql=mysqlnd --with-mysqli=mysqlnd [root@jie5 php-5.4.19]# make && make install
2)、提供php的配置文件,php-fpm的System V腳本和php-fpm的配置文件,啓動php-fpm服務
[root@jie5 php-5.4.19]# cp php.ini-production /etc/php.ini [root@jie5 php-5.4.19]# cp sapi/fpm/init.d.php-fpm /etc/rc.d/init.d/php-fpm [root@jie5 php-5.4.19]# chmod +x /etc/rc.d/init.d/php-fpm [root@jie5 php-5.4.19]# chkconfig --add php-fpm [root@jie5 php-5.4.19]# chkconfig php-fpm on [root@jie5 php-5.4.19]# cd /usr/local/php/etc/ [root@jie5 etc]# cp php-fpm.conf.default php-fpm.conf [root@jie5 etc]# vim php-fpm.conf listen = 172.16.22.5:9000 #把監聽的127.0.0.1改爲本機網卡的IP [root@jie5 etc]# service php-fpm start
mysql服務器的配置:
1)、編譯安裝mysql的源碼包
[root@jie6 ~]# ifconfig | grep "inet addr" | grep -v "127.0.0.1" | awk -F: '{print $2}' | cut -d' ' -f1 查看ip地址 172.16.22.6 [root@jie6 ~]# tar xf mysql-5.5.33.tar.gz [root@jie6 ~]# yum -y groupinstall "Development tools" "Server Platform Development" [root@jie6 ~]# cd mysql-5.5.33 [root@jie6 mysql-5.5.33]# yum -y install cmake [root@jie6 mysql-5.5.33]# cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \ -DMYSQL_DATADIR=/mydata/data -DSYSCONFDIR=/etc \ -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_ARCHIVE_STORAGE_ENGINE=1 \ -DWITH_BLACKHOLE_STORAGE_ENGINE=1 -DWITH_READLINE=1 -DWITH_SSL=system \ -DWITH_ZLIB=system -DWITH_LIBWRAP=0 -DMYSQL_UNIX_ADDR=/tmp/mysql.sock \ -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci [root@jie6 mysql-5.5.33]# make && make install
2)、提供mysql的配置文件和system V腳本,初始化數據庫
[root@jie6 mysql-5.5.33]# cp /usr/local/mysql/support-files/my-large.cnf /etc/my.cnf [root@jie6 mysql-5.5.33]# cp /usr/local/mysql/support-files/mysql.server /etc/rc.d/init.d/mysqld [root@jie6 mysql-5.5.33]# cd /usr/local/mysql/ [root@jie6 mysql]# useradd -r mysql [root@jie6 mysql]# chown -R root:mysql ./* [root@jie6 mysql]# mkdir -pv /mydata/data 建立存放數據庫的路徑,企業通常放在作raid磁盤陣列的LVM上 mkdir: created directory `/mydata' mkdir: created directory `/mydata/data' [root@jie6 mysql]# chown -R mysql:mysql /mydata/data/ [root@jie6 mysql]# vim /etc/my.cnf vim /etc/my.cnf thread_concurrency = 4 datadir = /mydata/data 修改數據庫存放的路徑 [root@jie6 mysql]# /usr/local/mysql/scripts/mysql_install_db --user=mysql --datadir=/mydata/data/ --basedir=/usr/local/mysql 初始化數據庫,datadir是指定數據庫的存放路徑,basedir是指定數據庫安裝的路徑 [root@jie6 mysql]# service mysqld start Starting MySQL........ [ OK ]
3)、把源碼包安裝mysql的PATH變量、庫文件、頭文件,關聯到系統識別的路徑下
[root@jie6 mysql]#echo "PATH=/usr/local/mysql/bin:$PATH" >/etc/profile.d/mysqld.sh [root@jie6 mysql]#source /etc/profile.d/mysqld.sh [root@jie6 mysql]#echo "/usr/local/mysql/lib" >/etc/ld.so.conf.d/mysqld.conf [root@jie6 mysql]#ldconfig -v | grep mysql [root@jie6 mysql]#ln -sv /usr/local/mysql/include/ /usr/local/mysqld
自此全部服務器的軟件已經安裝完成,且能成功啓動
2、配置HA高可用集羣
heartbeat的配置文件必須存放在兩邊的節點上,且徹底保持一致
利用圖形化界面的crm配置heartbeat的資源
[root@jie1 resource.d]#hb_gui & 運行圖形化界面
自此heartbeat實現了nginx的高可用
3、配置LB負載均衡集羣
4、配置反向代理
5、配置動靜分離
因爲三四五都只須要在nginx的配置文件中實現,博主在此直接所有配置好
1)、讓nginx支持fastCGI,修改fastcgi_param文件爲如下內
[root@jie1 /]# cd /etc/nginx/ [root@jie1 nginx]# vim fastcgi_params fastcgi_param GATEWAY_INTERFACE CGI/1.1; fastcgi_param SERVER_SOFTWARE nginx; fastcgi_param QUERY_STRING $query_string; fastcgi_param REQUEST_METHOD $request_method; fastcgi_param CONTENT_TYPE $content_type; fastcgi_param CONTENT_LENGTH $content_length; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; fastcgi_param SCRIPT_NAME $fastcgi_script_name; fastcgi_param REQUEST_URI $request_uri; fastcgi_param DOCUMENT_URI $document_uri; fastcgi_param DOCUMENT_ROOT $document_root; fastcgi_param SERVER_PROTOCOL $server_protocol; fastcgi_param REMOTE_ADDR $remote_addr; fastcgi_param REMOTE_PORT $remote_port; fastcgi_param SERVER_ADDR $server_addr; fastcgi_param SERVER_PORT $server_port; fastcgi_param SERVER_NAME $server_name;
2)、修改nginx的配置文件
[root@jie1 ~]# cd /etc/nginx/ [root@jie1 nginx]# grep -v "#" nginx.conf| grep -v "^$" worker_processes 1; events { worker_connections 1024; } http { include mime.types; default_type application/octet-stream; sendfile on; keepalive_timeout 65; upstream webphpfpm { server 172.16.22.4:9000; server 172.16.22.5:9000; } #upstream模塊定義負載均衡,此定義php-fpm的負載均衡 server { listen 80; server_name localhost; location / { root /web; index index.php index.html index.htm; } error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } location ~ \.(html|htm|gif|jpg|jpeg|bmp|png|ico|txt|js|css)$ { proxy_pass http://172.16.22.3; } #proxy_pass定義靜態請求的反向代理 location ~ \.(php|css|jsp)$ { root /webphp; #此處定義後端php-fpm服務器的網頁存放路 徑,後端此服務器必須有此目錄 fastcgi_pass webphpfpm; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name; include fastcgi_params; } #動態請求提交給後端的php-fpm服務器,webphpfpm爲此前定義負載均衡的名稱 } }
3)、複製nginx主服務器的配置文件和支持fastcgi的文件到nginx備服務器上
[root@jie1 nginx]# scp nginx.conf 172.16.22.2:/etc/nginx/ [root@jie1 nginx]# scp fastcgi_params 172.16.22.2:/etc/nginx/
6、測試
測試文件的準備
Apache服務器上面創建網頁文件
[root@jie3 html]# pwd /var/www/html [root@jie3 html]# ls 1.jpeg index.html 在網頁根目錄下存放一個測試文件和一張圖片用於測試 [root@jie3 html]# cat index.html <h1>this is Apache server</h1> [root@jie3 html]#
全部的php-fpm服務器上面創建網頁文件,在生產環境中必須保持同樣
php-fpm1服務器的測試頁面
[root@jie4 webphp]# pwd /webphp #此文件夾是存放網頁文件的根目錄,是在nginx裏面指定的目錄 [root@jie4 webphp]# ls index.php testdb.php test.php [root@jie4 webphp]# cat index.php 測試頁面 <h1> this is php-fpm1 server </h1> [root@jie4 webphp]# cat test.php 測試phpinfo頁面 <h1>php-fpm1</h1> <?php phpinfo(); ?> [root@jie4 webphp]# cat testdb.php 測試鏈接數據庫的頁面 <h1>php-fpm1</h1> <?php $link=mysql_connect('172.16.22.6','root','mypass'); if ($link) echo "mysql test success!!"; else echo "mysql test failed!!!"; mysql_close(); ?> [root@jie4 webphp]#
php-fpm2服務器的測試頁面
[root@jie5 webphp]# pwd /webphp [root@jie5 webphp]# ls index.php testdb.php test.php [root@jie5 webphp]# cat index.php <h1> this is php-fpm2 server </h1> [root@jie5 webphp]# cat test.php <h1>php-fpm2</h1> <?php phpinfo(); ?> [root@jie5 webphp]# cat testdb.php <h1>php-fpm2</h1> <?php $link=mysql_connect('172.16.22.6','root','mypass'); if ($link) echo "mysql test success!!"; else echo "mysql test failed!!!"; mysql_close(); ?> [root@jie5 webphp]#
1)測試動靜分離
訪問的是vip的地址,靜態網頁文件和圖片都會被nginx代理到Apache服務器上,
測試動態的網頁文件,被nginx代理到php-fpm服務器上
2)測試負載均衡
測試phpinfo文件,多測試幾回看看是否是負載到不一樣的php-fpm服務器上
3)測試mysql
測試是否能夠鏈接mysql的測試文件
4)測試高可用
用heartbeat宕到nginx主服務器,看nginx備服務器是否繼續提供服務
如今看見資源都運行nginx主服務器上
停掉nginx主服務器的heartbeat,看資源是否在nginx備服務器上自動啓動
[root@jie1 nginx]# service heartbeat status heartbeat OK [pid 4294 et al] is running on jie1.com [jie1.com]... [root@jie1 nginx]# service heartbeat stop Stopping High-Availability services: Done. [root@jie1 nginx]#
能夠看見nginx主服務器jie1.com節點宕機以後nginx備服務器自行啓動並搶佔資源
自此heartbeat+nginx實現HA的高可用和LB負載均衡已經完成
此博客沒有對nginx的配置文件參數作詳細說明,也沒有設置nginx的優化參數,有關nginx的優化以及nginx配置文件詳解,以及nginx實現諸多功能的詳細配置會在nginx相關博客中寫出。請你們多多關注