Centos7編譯安裝nginx-1.10.3配置域名轉發負載均衡

架構圖參考如下:


Paste_Image.png

1.下載nginx


Paste_Image.png

2.解壓nginx壓縮包.tar.gz


Paste_Image.png

解壓后得到文件夾


Paste_Image.png

進入解壓目錄查看
Paste_Image.png

3.安裝gcc
[root@localhost nginx-1.10.3]# yum -y install gcc-c++
安裝最基礎的模塊
[root@localhost nginx-1.10.3]# yum -y install pcre-devel
安裝gzip
[root@localhost nginx-1.10.3]# yum -y install zlib-devel
以上都是在編譯安裝nginx時需要的一些環境

4.編輯nginx
[root@localhost nginx-1.10.3]# ./configure --prefix=/usr/local/nginx
--------{{備注:可選
yum -y install openssl openssl-devel
--prefix=/usr/local/nginx --conf-path=/usr/local/nginx/nginx.conf --http-client-body-temp-path=/var/cache/nginx/client_temp --http-proxy-temp-path=/var/cache/nginx/proxy_temp --http-fastcgi-temp-path=/var/cache/nginx/fastcgi_temp --http-uwsgi-temp-path=/var/cache/nginx/uwsgi_temp --http-scgi-temp-path=/var/cache/nginx/scgi_temp --with-http_ssl_module --with-http_realip_module --with-http_addition_module --with-http_sub_module --with-http_dav_module --with-http_flv_module --with-http_mp4_module --with-http_gunzip_module --with-http_gzip_static_module --with-http_random_index_module --with-http_secure_link_module --with-http_stub_status_module --with-http_auth_request_module --with-threads --with-stream --with-stream_ssl_module --with-http_slice_module --with-mail --with-mail_ssl_module --with-file-aio --with-http_v2_module
--------}}
[root@localhost nginx-1.10.3]# make
[root@localhost nginx-1.10.3]# make install

5.啟動nginx


Paste_Image.png

查看nginx是否啟動


Paste_Image.png

root用戶進程號1303的才是,nobody的可以刪除

6.重啟nginx


Paste_Image.png

7.防火墻問題
Centos7默認使用的firewall作為防火墻
[root@localhost ~]# firewall-cmd --state 查看防火墻運行狀態
running
[root@localhost ~]# systemctl start firewalld.service 開啟防火墻
[root@localhost ~]# systemctl stop firewalld.service 關閉防火墻
[root@localhost ~]# systemctl disable firewalld.service 徹底關閉防火墻,開機不啟動
[root@localhost ~]# systemctl enable firewalld.service 開啟防火墻,開機啟動

啟動防火墻后增加80端口
[root@localhost ~]# firewall-cmd --add-port=80/tcp
success

局域網訪問http://192.168.210.100


Paste_Image.png

8.配置nginx,根據不同的域名轉發到不同的主機,直接編輯nginx.conf


Paste_Image.png

路由器配置虛擬機服務器,將80端口指向nginx,也就是192.168.210.100這臺主機,可將配置文件自帶的server注釋掉,然后添加如下內容,這樣在訪問www.a.com這個域名時便可轉向到192.168.210.230這臺主機,在訪問www.b.com這個域名時轉向到192.168.210.231這臺主機

 upstream a-server{
        ip_hash;
        server 192.168.210.230;
        }
  server {
        listen       80;
         server_name  www.a.com;
        location / {
            proxy_pass http://a-server;
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            root   html;
            index  index.html index.htm;
        }
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
    }
 upstream b-server{
        ip_hash;
        server 192.168.210.231;
        }
  server {
        listen       80;
         server_name  www.b.com;
        location / {
            proxy_pass http://b-server;
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            root   html;
            index  index.html index.htm;
        }
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
    }

修改完配置文件后記得重啟nginx.
重啟1:
進入nginx目錄
[root@localhost ~]# cd /usr/local/nginx/sbin/
[root@localhost sbin]# ls
nginx
[root@localhost sbin]# ./nginx -s reload

重啟2:
當nginx已經在運行時,則需要平滑重啟,步驟如下:
先查看nginx master的pid: ps aux|grep nginx|grep master
[root@localhost ~]# ps aux|grep nginx|grep master
root 1303 0.0 0.0 21932 1868 ? Ss 3月08 0:00 nginx: master process /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf
nginx的pid為1303,如下平滑重啟命令,完成重啟
[root@localhost ~]# kill -HUP 1303

開放80端口:
sudo firewall-cmd --permanent --zone=public --add-port=80/tcp
sudo firewall-cmd --permanent --zone=public --add-port=80/udp
讓firewall-cmd重新加載配置:
sudo firewall-cmd --reload
再次列一下當前防火墻配置看是否開放成功:
firewall-cmd --list-all

遇到的錯誤及解決辦法
1.nginx/logs/nginx.pid" failed (2: No such file or directory)
解決方法:
重新編譯(make,make install),安裝就好.

2.[emerg]mkdir()"/var/temp/nginx/client" failed(2:No such file or directory)
解決方法:
查看了一下是由于沒有Nginx/client的目錄.缺少對應的文件,建立相應的文件就好.

參考1:https://www.cnblogs.com/ghjbk/p/6744131.html
參考2:http://blog.csdn.net/agangdi/article/details/41087921
參考3:負載均衡

upstream myserver{
               #        ip_hash;
                server 192.168.200.21;
                server 192.168.200.22;
                server 192.168.200.23;
    }

    server {
        listen       80;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;
 location ~ .*\.(gif|jpg|png|htm|html|css|js|flv|ico|swf|eot|woff2|ttf|svg)(.*) {
             proxy_pass http://myserver ;
             proxy_redirect off;
             proxy_set_header Host $host;
             proxy_cache_valid 200 302 1h;
             proxy_cache_valid 301 1d;
             proxy_cache_valid any 1m;
             expires 30d;
       }

        location / {
                proxy_pass http://myserverbcs;
                proxy_set_header Host $http_host;
                proxy_set_header X-Real-IP $remote_addr;
                proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        }

Nginx的負載分發策略
Nginx 的 upstream目前支持的分配算法:
1.輪詢 ——1:1 輪流處理請求(默認)
每個請求按時間順序逐一分配到不同的應用服務器,如果應用服務器down掉,自動剔除,剩下的繼續輪詢。
2.權重 ——you can you up
通過配置權重,指定輪詢幾率,權重和訪問比率成正比,用于應用服務器性能不均的情況。
3.ip_哈希算法
每個請求按訪問ip的hash結果分配,這樣每個訪客固定訪問一個應用服務器,可以解決session共享的問題。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,001評論 6 537
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,786評論 3 423
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,986評論 0 381
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,204評論 1 315
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,964評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,354評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,410評論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,554評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,106評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,918評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,093評論 1 371
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,648評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,342評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,755評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,009評論 1 289
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,839評論 3 395
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,107評論 2 375

推薦閱讀更多精彩內容