1. 程式人生 > >keepalived安裝實現nginx主備高可用

keepalived安裝實現nginx主備高可用

ssl協議 regular open fig 打開 日誌文件 解析 nginx pid

1.    keepalived安裝環境 
su - root
yum -y install kernel-devel*
yum -y install openssl-*
yum -y install popt-devel
yum -y install lrzsz
yum -y install openssh-clients
yum -y install libnl libnl-devel popt
2.    安裝keepalived
2.1.    安裝keepalived
將keepalived-1.2.15.tar.gz上傳到服務器/usr/local/下。

cd 
/usr/local tar -zxvf keepalived-1.2.15.tar.gz cd keepalived-1.2.15 執行配置命令 ./configure --prefix=/usr/local/keepalived 3、編譯 make 4、安裝 make install 至此安裝成功 5、拷貝執行文件 cp /usr/local/keepalived/sbin/keepalived /usr/sbin/ 6、將init.d文件拷貝到etc下,加入開機啟動項 cp /usr/local/keepalived/etc/rc.d/init.d/keepalived /etc/init.d/keepalived
7、將keepalived文件拷貝到etc下,加入網卡配置 cp /usr/local/keepalived/etc/sysconfig/keepalived /etc/sysconfig/ 8、創建keepalived文件夾 mkdir -p /etc/keepalived 9、將keepalived配置文件拷貝到etc下 cp /usr/local/keepalived/etc/keepalived/keepalived.conf /etc/keepalived/keepalived.conf 10、添加可執行權限 chmod +x /etc/init.d/keepalived 2.2. 加入開機啟動: chkconfig
--add keepalived #添加時必須保證/etc/init.d/keepalived存在 chkconfig keepalived on 添加完可查詢系統服務是否存在:chkconfig --list 2.3. 啟動keepalived 啟動:service keepalived start 停止:service keepalived stop 重啟:service keepalived restart 3. 配置日誌文件 1.將keepalived日誌輸出到local0: vi /etc/sysconfig/keepalived KEEPALIVED_OPTIONS="-D -d -S 0" 2.在/etc/rsyslog.conf裏添加: local0.* /var/log/keepalived.log 3.重新啟動keepalived和rsyslog服務: service rsyslog restart service keepalived restart 4. 打開防火墻的通訊地址 iptables -A INPUT -d 224.0.0.18 -j ACCEPT /etc/rc.d/init.d/iptables save

1 nginx安裝環境
    nginx是C語言開發,建議在linux上運行,本教程使用Centos6.5作為安裝環境。
?    gcc
    安裝nginx需要先將官網下載的源碼進行編譯,編譯依賴gcc環境,如果沒有gcc環境,需要安裝gcc:yum install gcc-c++ 
?    PCRE
    PCRE(Perl Compatible Regular Expressions)是一個Perl庫,包括 perl 兼容的正則表達式庫。nginx的http模塊使用pcre來解析正則表達式,所以需要在linux上安裝pcre庫。
yum install -y pcre pcre-devel
註:pcre-devel是使用pcre開發的一個二次開發庫。nginx也需要此庫。
?    zlib
    zlib庫提供了很多種壓縮和解壓縮的方式,nginx使用zlib對http包的內容進行gzip,所以需要在linux上安裝zlib庫。
yum install -y zlib zlib-devel

?    openssl
    OpenSSL 是一個強大的安全套接字層密碼庫,囊括主要的密碼算法、常用的密鑰和證書封裝管理功能及SSL協議,並提供豐富的應用程序供測試或其它目的使用。
    nginx不僅支持http協議,還支持https(即在ssl協議上傳輸http),所以需要在linux安裝openssl庫。
yum install -y openssl openssl-devel

2 編譯安裝
將nginx-1.8.0.tar.gz拷貝至linux服務器。

解壓:
tar -zxvf nginx-1.8.0.tar.gz
cd nginx-1.8.0

1、    configure
./configure --help查詢詳細參數(參考本教程附錄部分:nginx編譯參數)

參數設置如下:
./configure --prefix=/usr/local/nginx --pid-path=/var/run/nginx/nginx.pid --lock-path=/var/lock/nginx.lock --error-log-path=/var/log/nginx/error.log --http-log-path=/var/log/nginx/access.log --with-http_gzip_static_module --http-client-body-temp-path=/var/temp/nginx/client --http-proxy-temp-path=/var/temp/nginx/proxy --http-fastcgi-temp-path=/var/temp/nginx/fastcgi --http-uwsgi-temp-path=/var/temp/nginx/uwsgi --http-scgi-temp-path=/var/temp/nginx/scgi

註意:上邊將臨時文件目錄指定為/var/temp/nginx,需要在/var下創建temp及nginx目錄


2、    編譯安裝
make
make  install

安裝成功查看安裝目錄 :
 


3 啟動nginx
cd /usr/local/nginx/sbin/
./nginx 

查詢nginx進程:
 

15098是nginx主進程的進程id,15099是nginx工作進程的進程id

註意:執行./nginx啟動nginx,這裏可以-c指定加載的nginx配置文件,如下:
./nginx -c /usr/local/nginx/conf/nginx.conf
如果不指定-c,nginx在啟動時默認加載conf/nginx.conf文件,此文件的地址也可以在編譯安裝nginx時指定./configure的參數(--conf-path= 指向配置文件(nginx.conf))

4 停止nginx
方式1,快速停止:
cd /usr/local/nginx/sbin
./nginx -s stop
此方式相當於先查出nginx進程id再使用kill命令強制殺掉進程。

方式2,完整停止(建議使用):
cd /usr/local/nginx/sbin
./nginx -s quit
此方式停止步驟是待nginx進程處理任務完畢進行停止。


5 重啟nginx
方式1,先停止再啟動(建議使用):
對nginx進行重啟相當於先停止nginx再啟動nginx,即先執行停止命令再執行啟動命令。
如下:
./nginx -s quit
./nginx

方式2,重新加載配置文件:
當nginx的配置文件nginx.conf修改後,要想讓配置生效需要重啟nginx,使用-s reload不用先停止nginx再啟動nginx即可將配置信息在nginx中生效,如下:
./nginx -s reload

keepalived安裝實現nginx主備高可用