欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

用nginX+keepalived實(shí)現(xiàn)高可用的負(fù)載均衡

系統(tǒng) 1670 0

摘要:
實(shí)施nginx和keepalived的規(guī)劃、安裝、配置等步驟


前面的 《統(tǒng)一web訪問(wèn)層方案》 中就目的、目標(biāo)和整體方案進(jìn)行了討論,本文討論具體的實(shí)施。簡(jiǎn)單來(lái)說(shuō)就是在兩臺(tái)服務(wù)器上分別部署NginX,并通過(guò)keepalived實(shí)現(xiàn)高可用。

1 規(guī)劃和準(zhǔn)備


需要統(tǒng)一訪問(wèn)的應(yīng)用系統(tǒng):

應(yīng)用系統(tǒng) 域名/虛擬目錄 應(yīng)用服務(wù)器及URL
svn dev.mycompany.com/svn http://50.1.1.21/svn
svn web管理 dev.mycompany.com/submin http://50.1.1.21/submin
網(wǎng)站 www.mycompany.com http://50.1.1.10; http://50.1.1.11; http://50.1.1.12
OA oa.mycompany.com http://50.1.1.13:8080; http://50.1.1.14:8080

web訪問(wèn)服務(wù)器

用兩臺(tái)接入服務(wù)器50.1.1.3/4分別作為主、備(MASTER、BACKUP)服務(wù)器,使用RHEL5.6x64,配置了yum 私服。

兩臺(tái)接入服務(wù)器公用一個(gè)虛擬IP(VIP):50.1.1.2

2 安裝


兩臺(tái)接入服務(wù)器分別安裝NginX和keepalived:

      
        
          #準(zhǔn)備依賴包:
        
        

    yum -y install gcc pcre-devel zlib-devel openssl-devel

    

    
        
          #下載
        
        

    wget http://nginx.org/download/nginx-1.2.4.tar.gz 

    wget http://www.keepalived.org/software/keepalived-1.2.7.tar.gz

    

    
        
          #安裝NginX
        
        

    tar zxvf nginx-1.2.4.tar.gz

    
        
          cd 
        
        nginx-1.2.4

    ./configure

    make 
        
          &&
        
         make install



    
        
          #安裝keepalived
        
        

    tar zxvf keepalived-1.2.7.tar.gz

    
        
          cd 
        
        keepalived-1.2.7

    ./configure

    make 

    make install



    cp /usr/local/etc/rc.d/init.d/keepalived /etc/rc.d/init.d/

    cp /usr/local/etc/sysconfig/keepalived /etc/sysconfig/

    mkdir /etc/keepalived

    cp /usr/local/etc/keepalived/keepalived.conf /etc/keepalived/

    cp /usr/local/sbin/keepalived /usr/sbin/



    
        
          #加入啟動(dòng)
        
        
          echo
        
        
          "/usr/local/nginx/sbin/nginx"
        
         >> /etc/rc.local

    
        
          echo
        
        
          "/etc/init.d/keepalived start"
        
         >> /etc/rc.local

 


      
    

3 配置

兩臺(tái)接入服務(wù)器的NginX的配置完全一樣,主要是配置/usr/local/nginx/conf/nginx.conf的http。其中多域名 指向是通過(guò)虛擬主機(jī)(配置http下面的server)實(shí)現(xiàn);同一域名的不同虛擬目錄通過(guò)每個(gè)server下面的不同location實(shí)現(xiàn);到后端的服務(wù) 器在http下面配置upstream,然后在server或location中通過(guò)proxypass引用。要實(shí)現(xiàn)前面規(guī)劃的接入方式,http的配置 如下:

      
        
          http
        
        
          {
        
        
          include
        
        
          mime
        
        
          .
        
        
          types
        
        
          ;
        
        
          default_type
        
        
          application
        
        
          /
        
        
          octet
        
        
          -
        
        
          stream
        
        
          ;
        
        
          sendfile
        
        
          on
        
        
          ;
        
        
          upstream
        
        
          dev
        
        
          .
        
        
          hysec
        
        
          .
        
        
          com
        
        
          {
        
        
          server
        
        
          50.1.1.21
        
        
          :
        
        
          80
        
        
          ;
        
        
          }
        
        
          upstream
        
        
          www
        
        
          .
        
        
          hysec
        
        
          .
        
        
          com
        
        
          {
        
        
          ip_hash
        
        
          ;
        
        
          server
        
        
          50.1.1.10
        
        
          :
        
        
          80
        
        
          ;
        
        
          server
        
        
          50.1.1.11
        
        
          :
        
        
          80
        
        
          ;
        
        
          server
        
        
          50.1.1.12
        
        
          :
        
        
          80
        
        
          ;
        
        
          }
        
        
          upstream
        
        
          oa
        
        
          .
        
        
          hysec
        
        
          .
        
        
          com
        
        
          {
        
        
          ip_hash
        
        
          ;
        
        
          server
        
        
          50.1.1.13
        
        
          :
        
        
          8080
        
        
          ;
        
        
          server
        
        
          50.1.1.14
        
        
          :
        
        
          8080
        
        
          ;
        
        
          server
        
        
          {
        
        
          listen
        
        
          80
        
        
          ;
        
        
          server_name
        
        
          dev
        
        
          .
        
        
          hysec
        
        
          .
        
        
          com
        
        
          ;
        
        
          location
        
        
          /
        
        
          svn
        
        
          {
        
        
          proxy_pass
        
        
          http
        
        
          :
        
        
          //dev.hysec.com;
        
        
          }
        
        
          location
        
        
          /
        
        
          submin
        
        
          {
        
        
          proxy_pass
        
        
          http
        
        
          :
        
        
          //dev.hysec.com;
        
        
          }
        
        
          }
        
        
          server
        
        
          {
        
        
          listen
        
        
          80
        
        
          ;
        
        
          server_name
        
        
          www
        
        
          .
        
        
          hysec
        
        
          .
        
        
          com
        
        
          ;
        
        
          location
        
        
          /
        
        
          {
        
        
          proxy_pass
        
        
          http
        
        
          :
        
        
          //www.hysec.com;
        
        
          }
        
        
          server
        
        
          {
        
        
          listen
        
        
          80
        
        
          ;
        
        
          server_name
        
        
          oa
        
        
          .
        
        
          hysec
        
        
          .
        
        
          com
        
        
          ;
        
        
          location
        
        
          /
        
        
          {
        
        
          proxy_pass
        
        
          http
        
        
          :
        
        
          //oa.hysec.com;
        
        
          }
        
        
          }
        
      
    

驗(yàn)證方法:

首先用IP訪問(wèn)前表中各個(gè)應(yīng)用服務(wù)器的url,再用域名和路徑訪問(wèn)前表中各個(gè)應(yīng)用系統(tǒng)的域名/虛擬路徑

按照上面的安裝方法,keepalived的配置文件在/etc/keepalived/keepalived.conf。主、從服務(wù)器的配置相關(guān)聯(lián)但有所不同。如下:

  • Master配置
      
        
          !
        
        
          Configuration
        
        
          File
        
        
          for
        
        
          keepalived
        
        
          global_defs
        
        
          {
        
        
          notification_email
        
        
          {
        
        
          wanghaikuo
        
        
          @
        
        
          hysec
        
        
          .
        
        
          com
        
        
          wanghaikuo
        
        
          @
        
        
          gmail
        
        
          .
        
        
          com
        
        
          }
        
        
          notification_email_from
        
        
          wanghaikuo
        
        
          @
        
        
          hysec
        
        
          .
        
        
          com
        
        
          smtp_server
        
        
          smtp
        
        
          .
        
        
          hysec
        
        
          .
        
        
          com
        
        
          smtp_connect_timeout
        
        
          30
        
        
          router_id
        
        
          nginx_master
        
        
          }
        
        
          vrrp_instance
        
        
          VI_1
        
        
          {
        
        
          state
        
        
          MASTER
        
        
          interface
        
        
          eth0
        
        
          virtual_router_id
        
        
          51
        
        
          priority
        
        
          101
        
        
          advert_int
        
        
          1
        
        
          authentication
        
        
          {
        
        
          auth_type
        
        
          PASS
        
        
          auth_pass
        
        
          1111
        
        
          }
        
        
          virtual_ipaddress
        
        
          {
        
        
          50.1.1.2
        
        
          }
        
        
          }
        
      
    
  • Backup配置
      
        
          !
        
        
          Configuration
        
        
          File
        
        
          for
        
        
          keepalived
        
        
          global_defs
        
        
          {
        
        
          notification_email
        
        
          {
        
        
          wanghaikuo
        
        
          @
        
        
          hysec
        
        
          .
        
        
          com
        
        
          wanghaikuo
        
        
          @
        
        
          gmail
        
        
          .
        
        
          com
        
        
          }
        
        
          notification_email_from
        
        
          wanghaikuo
        
        
          @
        
        
          hysec
        
        
          .
        
        
          com
        
        
          smtp_server
        
        
          smtp
        
        
          .
        
        
          hysec
        
        
          .
        
        
          com
        
        
          smtp_connect_timeout
        
        
          30
        
        
          router_id
        
        
          nginx_backup
        
        
          }
        
        
          vrrp_instance
        
        
          VI_1
        
        
          {
        
        
          state
        
        
          BACKUP
        
        
          interface
        
        
          eth0
        
        
          virtual_router_id
        
        
          51
        
        
          priority
        
        
          99
        
        
          advert_int
        
        
          1
        
        
          authentication
        
        
          {
        
        
          auth_type
        
        
          PASS
        
        
          auth_pass
        
        
          1111
        
        
          }
        
        
          virtual_ipaddress
        
        
          {
        
        
          50.1.1.2
        
        
          }
        
        
          }
        
      
    

驗(yàn)證:

  1. 先后在主、從服務(wù)器上啟動(dòng)keepalived:

    /etc/init.d/keepalived start

  2. 在主服務(wù)器上查看是否已經(jīng)綁定了虛擬IP:

    ip addr

  3. 停止主服務(wù)器上的keepalived:

    /etc/init.d/keepalived stop

  4. 然后在從服務(wù)器上查看是否已經(jīng)綁定了虛擬IP

  5. 啟動(dòng)主服務(wù)器上的keepalived,看看主服務(wù)器能否重新接管虛擬IP

經(jīng)過(guò)前面的配置,如果主服務(wù)器的keepalived停止服務(wù),從服務(wù)器會(huì)自動(dòng)接管VIP對(duì)外服務(wù);一旦主服務(wù)器的keepalived恢復(fù),會(huì)重新接管VIP。 但這并不是我們需要的,我們需要的是當(dāng)NginX停止服務(wù)的時(shí)候能夠自動(dòng)切換。

keepalived支持配置監(jiān)控腳本,我們可以通過(guò)腳本監(jiān)控NginX的狀態(tài),如果狀態(tài)不正常則進(jìn)行一系列的操作,最終仍不能恢復(fù)NginX則殺掉keepalived,使得從服務(wù)器能夠接管服務(wù)。

如何監(jiān)控NginX的狀態(tài) 最簡(jiǎn)單的做法是監(jiān)控NginX進(jìn)程,更靠譜的做法是檢查NginX端口,最靠譜的做法是檢查多個(gè)url能否獲取到頁(yè)面。

如何嘗試恢復(fù)服務(wù) 如果發(fā)現(xiàn)NginX不正常,重啟之。等待3秒再次校驗(yàn),仍然失敗則不再嘗試。

根據(jù)上述策略很容易寫出監(jiān)控腳本。這里使用nmap檢查nginx端口來(lái)判斷nginx的狀態(tài),記得要首先安裝nmap。監(jiān)控腳本如下:

      
        
          #!/bin/sh
        
        
          # check nginx server status
        
        
          NGINX
        
        
          =
        
        /usr/local/nginx/sbin/nginx

    
        
          PORT
        
        
          =
        
        80



    nmap localhost -p 
        
          $PORT
        
        
          |
        
         grep 
        
          "$PORT/tcp open"
        
        
          #echo $?
        
        
          if
        
        
          [
        
        
          $?
        
         -ne 0 
        
          ]
        
        
          ;
        
        
          then
        
        
          $NGINX
        
         -s stop

        
        
          $NGINX
        
        

        sleep 3

        nmap localhost -p 
        
          $PORT
        
        
          |
        
         grep 
        
          "$PORT/tcp open"
        
        
          [
        
        
          $?
        
         -ne 0 
        
          ]
        
        
          &&
        
         /etc/init.d/keepalived stop

    
        
          fi
        
      
    

不要忘了設(shè)置腳本的執(zhí)行權(quán)限,否則不起作用。

假設(shè)上述腳本放在/opt/chk_nginx.sh,則keepalived.conf中增加如下配置:

      
        
          vrrp_script
        
        
          chk_http_port
        
        
          {
        
        
          script
        
        
          "/opt/chk_nginx.sh"
        
        
          interval
        
        
          2
        
        
          weight
        
        
          2
        
        
          }
        
        
          track_script
        
        
          {
        
        
          chk_http_port
        
        
          }
        
      
    

更進(jìn)一步,為了避免啟動(dòng)keepalived之前沒(méi)有啟動(dòng)nginx , 可以在/etc/init.d/keepalived的start中首先啟動(dòng)nginx:

      
        
          start
        
        
          ()
        
        
          {
        
        
          /
        
        
          usr
        
        
          /
        
        
          local
        
        
          /
        
        
          nginx
        
        
          /
        
        
          sbin
        
        
          /
        
        
          nginx
        
        
          sleep
        
        
          3
        
        
          echo
        
        
          -
        
        
          n
        
        
          $
        
        
          "Starting $prog: "
        
        
          daemon
        
        
          keepalived
        
        
          $
        
        
          {
        
        
          KEEPALIVED_OPTIONS
        
        
          }
        
        
          RETVAL
        
        
          =
        
        
          $
        
        
          ?
        
        
          echo
        
        
          [
        
        
          $
        
        
          RETVAL
        
        
          -
        
        
          eq
        
        
          0
        
        
          ]
        
        
          &&
        
        
          touch
        
        
          /
        
        
          var
        
        
          /
        
        
          lock
        
        
          /
        
        
          subsys
        
        
          /
        
        
          $
        
        
          prog
        
        
          }
        
      
    

4 還可以做什么

對(duì)于簡(jiǎn)單重復(fù)性勞動(dòng),人總是容易犯錯(cuò),這種事情最好交給機(jī)器去做。 比如,在這個(gè)案例中,作為統(tǒng)一接入服務(wù)器,可能經(jīng)常要修改nginx的配置、nginx下面的html文件等。而且,一定要保證集群中的每臺(tái)服務(wù)器的配置 相同。 最好的做法是由配置管理服務(wù)器來(lái)管理,如果沒(méi)有,也可以使用簡(jiǎn)單的linux文件同步來(lái)解決。

5 支持https

需要安裝openSSL:

    
      yum install openssl-devel


    
  

在nginx/conf下生成秘鑰:

      
        
          #生成RSA密鑰
        
        

    openssl dsaparam -rand -genkey -out myRSA.key 1024



    
        
          #生成CA密鑰:(要輸入一個(gè)自己記得的密碼)
        
        

    openssl gendsa -des3 -out cert.key myRSA.key



    
        
          #用這個(gè)CA密鑰來(lái)創(chuàng)建證書,需要上一步創(chuàng)建的密碼
        
        

    openssl req -new -x509 -days 365 -key cert.key -out cert.pem



    
        
          #把證書設(shè)置為root專用
        
        

    chmod 700 cert.*



    
        
          #生成免密碼文件
        
        

    openssl rsa -in cert.key -out cert.key.unsecure


      
    

如果要啟用SSL,首先在安裝nginx是要增加配置參數(shù):--with-http_ssl_module , 然后在nginx中進(jìn)行如下配置:

      
        
          #
        
        
          這里是
        
        
          SSL
        
        
          的相關(guān)配置
        
        
          server
        
        
          {
        
        
          listen
        
        
          443
        
        
          ;
        
        
          server_name
        
        
          www
        
        
          .
        
        
          example
        
        
          .
        
        
          com
        
        
          ;
        
        
          #
        
        
          你自己的域名
        
        
          root
        
        
          /
        
        
          home
        
        
          /
        
        
          www
        
        
          ;
        
        
          ssl
        
        
          on
        
        
          ;
        
        
          ssl_certificate
        
        
          cert
        
        
          .
        
        
          perm
        
        
          ;
        
        
          #使用
        
        
          .
        
        
          unsecure
        
        
          文件可以在
        
        
          nginx
        
        
          啟動(dòng)時(shí)不輸入密碼
        
        
          ssl_certificate_key
        
        
          cert
        
        
          .
        
        
          key
        
        
          .
        
        
          unsecure
        
        
          ;
        
        
          location
        
        
          /
        
        
          {
        
        
          #
        
        
          ...
        
        
          }
        
        
          }
        
      
    

公共證書的申請(qǐng)過(guò)程:

  1. 生成RSA(私鑰)文件:

    openssl genrsa -des3 -out myRSA.key 2048

  2. 生成csr文件:

    openssl req -new -key myRSA.key -out my.csr

  3. 將csr提交給證書機(jī)構(gòu),比如GlobalSign。

  4. 證書機(jī)構(gòu)會(huì)返回私有證書(crt)和中級(jí)證書(crt)

  5. 到機(jī)構(gòu)網(wǎng)站下載根證書(root_CA.cer), 將根證書拼接到私有證書之后

  6. 在nginx中配置證書:

      
        
          ssl_certificate
        
        
          /
        
        
          etc
        
        
          /
        
        
          ssl
        
        
          /
        
        
          my
        
        
          .
        
        
          crt
        
        
          ;
        
        
          ssl_certificate_key
        
        
          /
        
        
          etc
        
        
          /
        
        
          ssl
        
        
          /
        
        
          myRSA
        
        
          .
        
        
          key
        
        
          ;
        
        
          ssl_client_certificate
        
        
          /
        
        
          etc
        
        
          /
        
        
          ssl
        
        
          /
        
        
          root_CA
        
        
          .
        
        
          cer
        
        
          ;
        
      
    

6 支持webservice

通過(guò)chunkin-nginx-module模塊支持webservice。

否則會(huì)報(bào)錯(cuò):411:http 頭中缺少 Conten-Length 參數(shù)

步驟:

      
            git clone https://github.com/agentzh/chunkin-nginx-module.git



    
        
          #重新編譯nginx
        
        
          cd 
        
        PATH/TO/NGINX/SOURCE

    ./configure xxx --add-module
        
          =
        
        /PATH/TO/chunkin-nginx-module

    make 
        
          &&
        
         make install


      
    

在nginx的server{}節(jié)點(diǎn)中增加配置:

      
        
          chunkin
        
        
          on
        
        
          ;
        
        
          error_page
        
        
          411
        
        
          =
        
        
          @
        
        
          my_411_error
        
        
          ;
        
        
          location
        
        
          @
        
        
          my_411_error
        
        
          {
        
        
          chunkin_resume
        
        
          ;
        
        
          }
        
      
    

7 狀態(tài)監(jiān)控

編譯時(shí)需要增加 --with-http_stub_status_module 參數(shù)。

查看編譯參數(shù):使用命令 /usr/local/nginx/sbin/nginx -V

安裝好之后增加配置:

      
        
          location
        
        
          /nginx_status
        
        
          {
        
        
          stub_status
        
        
          on
        
        
          ;
        
        
          access_log
        
        
          off
        
        
          ;
        
        
          # deny all;
        
        
          allow
        
        
          all
        
        
          ;
        
        
          }
        
      
    

重新加載配置后,會(huì)看到一些文本:

Active connections: 1 (對(duì)后端發(fā)起的活動(dòng)連接數(shù))

server accepts handled requests

5 5 5 (處理連接個(gè)數(shù),成功握手次數(shù),處理請(qǐng)求數(shù))

用nginX+keepalived實(shí)現(xiàn)高可用的負(fù)載均衡


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: av在线成人| 亚洲欧美日韩精品中文乱码 | 成人一区二区三区四区 | 91精品国产亚洲爽啪在线观看 | 天天躁日日躁狠狠躁av麻豆 | 色综合99 | 国产综合视频在线观看 | 婷婷精品 | 春宵福利网站在线观看 | 久久噜噜噜精品国产亚洲综合 | 成人av一区 | cheaperapp.work直接访问 | 国产一码二码免费观看 | 日本黄色大片免费看 | 这里只有精品在线视频观看 | 九九这里只有精品视频 | 中文字幕精品一区二区三区精品 | 福利网址| 久久综合狠狠综合久久 | 日韩一区二区在线观看视频 | 成人伊人| 国产一区二区三区久久久久久久久 | 国产免费叼嘿在线观看 | 日本黄页免费大片在线观看 | gogo全球大胆高清人露出91 | 国产啪| 欧美日韩精 | 蜜臀AV性色A片在线观看 | 欧美一区二区三区免费观看视频 | 色吊丝国产 | 天天摸日日碰天天看免费 | 欧美一区二区三区免费视频 | 日韩做A爰片久久毛片A片 | 18pao成人国产永久视频 | 国产精品思瑞在线观看 | 国产精品人妻无码久久久郑州 | 亚洲天堂一区二区三区 | 超碰在线影院 | 日本高清www午色夜黄 | free国产hd老熟bbw | 久久免费精品视频 |