Nginx安裝配置

所用安裝包也可以從此處下載


  1. 下載nginx
    官網:https://nginx.org/(我的是1.8.1)

  2. 上傳並解壓nginx
    tar -zxvf nginx-1.8.1.tar.gz -C /usr/local/src

  3. 編譯nginx
    #進入到nginx源碼目錄
    cd /usr/local/src/nginx-1.8.1
    #檢查安裝環境,並指定將來要安裝的路徑
    ./configure --prefix=/usr/local/nginx
    #缺包報錯 ./configure: error: C compiler cc is not found
    #使用YUM安裝缺少的包
    yum -y install gcc pcre-devel openssl openssl-devel(centos命令,如果是其他系統請自行更改

  4. #編譯安裝
    make && make install

  5. 安裝完後測試是否正常:
    /usr/loca/nginx/sbin/nginx
    查看端口是否有ngnix進程監聽
    netstat -ntlp | grep 80
    如果啓動nginx報錯:
    nginx: [emerg] open() “/etc/nginx.conf” failed (2: no such file or directory)

    1. find / -name nginx.conf
    2. cp 查找到的nginx.conf位置 啓動缺少nginx.conf位置
  6. 配置nginx
    打開nginx.conf

    1. 修改nginx配置文件
      server {
      listen 80;
      server_name xxx.com; #nginx所在服務器的主機名
      #反向代理的配置
      location / { #攔截所有請求
      root html;
      proxy_pass http://192.168.0.21:8080; #這裏是代理走向的目標服務器:tomcat
      }
      }
#重啓nginx
kill -HUP `cat /usr/local/nginx/logs/nginx.pid `
  1. 動靜分離

    1. 刪除上面的server配置

    2. 按照上面的方法配置一下內容
      #動態資源 index.jsp
      location ~ .*.(jsp|do|action)$ {
      proxy_pass http://192.168.0.2:8080;
      }

      #靜態資源
      location ~ .*.(html|js|css|gif|jpg|jpeg|png)$ {
      expires 3d;
      }

  2. 負載均衡
    在http這個節下面配置一個叫upstream的,後面的名字可以隨意取,但是要和location下的proxy_pass http://後的保持一致

http {
    是在http裏面的, 已有http, 不是在server裏,在server外面
    upstream tomcats { 
        server shizhan02:8080 weight=1;#weight表示多少個
        server shizhan03:8080 weight=1;
        server shizhan04:8080 weight=1;
	}
#卸載server裏
location ~ .*\.(jsp|do|action) {
    proxy_pass http://tomcats;        #tomcats是後面的tomcat服務器組的邏輯組號
	}
}

利用keepalived實現高可靠(HA)

HA(High Available), 高可用性集羣,是保證業務連續性的有效解決方案,一般有兩個或兩個以上的節點,且分爲活動節點及備用節點。
在這裏插入圖片描述

keepalive是一款可以實現高可靠的軟件,通常部署在2臺服務器上,分爲一主一備。Keepalived可以對本機上的進程進行檢測,一旦Master檢測出某個進程出現問題,將自己切換成Backup狀態,然後通知另外一個節點切換成Master狀態。

  1. 與上面安裝過程一樣
下載keepalived官網:https://keepalived.org

將keepalived解壓到/usr/local/src目錄下
tar -zxvf  keepalived-1.2.19.tar.gz -C /usr/local/src

進入到/usr/local/src/keepalived-1.2.19目錄
cd /usr/local/src/keepalived-1.2.19

開始configure
./configure --prefix=/usr/local/keepalived

#編譯並安裝
make && make install
  1. 修改/etc/keepalived/keepalived.conf 配置虛擬ip 兩個節點必須是在同一內網
    #MASTER節點

    global_defs {
    }
    vrrp_instance VI_1 {
        state MASTER   #指定A節點爲主節點 備用節點上設置爲BACKUP即可
        interface eth0    #綁定虛擬IP的網絡接口
        virtual_router_id 51   #VRRP組名,兩個節點的設置必須一樣,以指明各個節點屬於同一VRRP組
        priority 100   #主節點的優先級(1-254之間),備用節點必須比主節點優先級低
        advert_int 1  #組播信息發送間隔,兩個節點設置必須一樣
        authentication {    #設置驗證信息,兩個節點必須一致
            auth_type PASS
            auth_pass 1111
        }
        virtual_ipaddress {    #指定虛擬IP, 兩個節點設置必須一樣
            192.168.33.60/24    #如果兩個nginx的ip分別是192.168.33.61,,...62,則此處的虛擬ip跟它倆同一個網段即可
        }
    }
    

    #BACKUP節點

     global_defs {
     }
     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 {
             192.168.33.60/24
         }
     }
    
  2. #分別啓動兩臺機器上的keepalived
    service keepalived start
    測試:
    殺掉master上的keepalived進程,你會發現,在slave機器上的eth0網卡多了一個ip地址
    查看ip地址的命令: ip addr

  3. 配置心跳檢測
    原理:
    Keepalived並不跟nginx耦合,它倆完全不是一家人
    但是keepalived提供一個機制:讓用戶自定義一個shell腳本去檢測用戶自己的程序,返回狀態給keepalived就可以了
    #MASTER節點

    global_defs {
    }

     vrrp_script chk_health {
     #腳本內容,條件選擇 grep出nginx線程,排除grep這條,其他的就是純淨的線程內容,如果是兩條就返回0,錯誤就返回1,如果返回異常就要將nginx提起來,使用後面的函數腳本
         script "[[ `ps -ef | grep nginx | grep -v grep | wc -l` -ge 2 ]] && exit 0 || exit 1"
         interval 1    #每隔1秒執行上述的腳本,去檢查用戶的程序ngnix
         #錯誤的話就降低權重
         weight -2
     }
     
     vrrp_instance VI_1 {
         state MASTER
         interface eth0
         virtual_router_id 1
         priority 100
         advert_int 2
         authentication {
             auth_type PASS
             auth_pass 1111
         }
     
         track_script {#修改的地飯,配置的腳本
             chk_health
         }
     
         virtual_ipaddress {
             10.0.0.10/24
         }
     	
     	#腳本
         notify_master "/usr/local/keepalived/sbin/notify.sh master"
         notify_backup "/usr/local/keepalived/sbin/notify.sh backup"
         notify_fault "/usr/local/keepalived/sbin/notify.sh fault"
     }
    

    #添加切換通知腳本
    vi /usr/local/keepalived/sbin/notify.sh

    #!/bin/bash
    case "$1" in
    #如果輸入進來的參數是master就執行這個命令
    master)
        /usr/local/nginx/sbin/nginx
        exit 0
    ;;
    #同上
    backup)
            /usr/local/nginx/sbin/nginx -s stop
            /usr/local/nginx/sbin/nginx
            exit 0
        ;;
        #同上
        fault)
            /usr/local/nginx/sbin/nginx -s stop
            exit 0
        ;;
        *)
            echo 'Usage: notify.sh {master|backup|fault}'
            exit 1
        ;;
    esac
    
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章