国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

docker下nginx反向代理和負(fù)載均衡配置

BetaRabbit / 1435人閱讀

摘要:命令可以刪除指定容器下面正式配置上面三個場景場景靜態(tài)資源代理在目錄下創(chuàng)建目錄并上傳靜態(tài)資源修改文件是不是。

鏡像安裝

可以通過以下命令拉取nginx和tomcat鏡像作為測試

[root@docker /]# docker pull nginx
[root@docker /]# docker pull tomcat
nginx

鏡像下載完后,執(zhí)行以下命令啟動nginx

[root@docker /]# docker run --name=my_nginx -p 8000:80 -d nginx

--name: 為nginx容器指定一個名稱方便管理
-p: 將nginx內(nèi)部80端口代理到宿主機(jī)8000端口,可以通過宿主機(jī):8000訪問nginx 80端口
-d: 后臺運行

可以通過docker ps 命令查看容器運行情況

[root@docker /]# docker ps
CONTAINER ID        IMAGE                 COMMAND                  CREATED             STATUS              PORTS                            NAMES
1833fcff605b        nginx                 "nginx -g "daemon off"   2 minutes ago       Up 2 minutes        0.0.0.0:8000->80/tcp             my_nginx

瀏覽器訪問http://192.168.43.32:8000/查看是否能夠訪問,或者使用curl命令(推薦)

[root@docker /]# curl http://192.168.43.32:8000



Welcome to nginx!
....
nginx配置文件

進(jìn)入nginx容器后臺

[root@docker /]# docker exec -it my_nginx bash
root@1833fcff605b:/# cd /etc/nginx/
root@1833fcff605b:/etc/nginx# ls -l
total 36
drwxr-xr-x. 2 root root   26 Dec 26 18:16 conf.d
-rw-r--r--. 1 root root 1007 Dec 26 11:11 fastcgi_params
-rw-r--r--. 1 root root 2837 Dec 26 11:11 koi-utf
-rw-r--r--. 1 root root 2223 Dec 26 11:11 koi-win
-rw-r--r--. 1 root root 5170 Dec 26 11:11 mime.types
lrwxrwxrwx. 1 root root   22 Dec 26 11:11 modules -> /usr/lib/nginx/modules
-rw-r--r--. 1 root root  643 Dec 26 11:11 nginx.conf
-rw-r--r--. 1 root root  636 Dec 26 11:11 scgi_params
-rw-r--r--. 1 root root  664 Dec 26 11:11 uwsgi_params
-rw-r--r--. 1 root root 3610 Dec 26 11:11 win-utf

nginx.conf是nginx主要配置文件,可以通過more命令查看nginx.conf(容器默認(rèn)不安裝vi工具)

root@1833fcff605b:/etc/nginx# more nginx.conf

user  nginx;
worker_processes  1;

error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;

    log_format  main  "$remote_addr - $remote_user [$time_local] "$request" "
                      "$status $body_bytes_sent "$http_referer" "
                      ""$http_user_agent" "$http_x_forwarded_for"";

    access_log  /var/log/nginx/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    keepalive_timeout  65;

    #gzip  on;

    include /etc/nginx/conf.d/*.conf;
}

注意到最后一行配置
include /etc/nginx/conf.d/*.conf;
include可以將其他配置文件導(dǎo)入,進(jìn)入/etc/nginx/conf.d/目錄下查看

root@1833fcff605b:/etc/nginx# cd /etc/nginx/conf.d/
root@1833fcff605b:/etc/nginx/conf.d# ls
default.conf

default.conf

root@1833fcff605b:/etc/nginx/conf.d# more default.conf
server {
    listen       80;
    server_name  localhost;

    #charset koi8-r;
    #access_log  /var/log/nginx/host.access.log  main;

    location / {
        root   /usr/share/nginx/html;
        index  index.html index.htm;
    }

    #error_page  404              /404.html;

    # redirect server error pages to the static page /50x.html
    #
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   /usr/share/nginx/html;
    }

    # proxy the PHP scripts to Apache listening on 127.0.0.1:80
    #
    #location ~ .php$ {
    #    proxy_pass   http://127.0.0.1;
    #}

    # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
    #
    #location ~ .php$ {
    #    root           html;
    #    fastcgi_pass   127.0.0.1:9000;
    #    fastcgi_index  index.php;
    #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
    #    include        fastcgi_params;
    #}

    # deny access to .htaccess files, if Apache"s document root
    # concurs with nginx"s one
    #
    #location ~ /.ht {
    #    deny  all;
    #}
}

#表示注釋可以忽略
server:代表虛擬服務(wù)器,下面會解釋什么是虛擬服務(wù)器
server_name:服務(wù)器名稱
location:訪問路徑匹配規(guī)則,這也是nginx最靈活的地方,可以使用正則表達(dá)式
解釋下什么是虛擬服務(wù)器
如果給nginx服務(wù)器在dns上配置兩個域名
domain1.nginx.com
domain2.nginx.com
用戶訪問這兩個域名,你可能希望他們訪問同一個后臺服務(wù),也可能希望訪問不同的后臺服務(wù)
那么在nginx里就可以配置兩個虛擬服務(wù)器也就是兩個server節(jié)點

server {
    listen       80;
    server_name  domain1.nginx.com;
    ...
}
server {
    listen       80;
    server_name  domain2.nginx.com;
    ...
}

兩個虛擬服務(wù)器監(jiān)聽同一個端口80.nginx可以根據(jù)用戶訪問的host(http頭部host)字段代理到不同服務(wù)器上

location->root:靜態(tài)資源目錄,web靜態(tài)資源如圖片,js,html可通過該方式存放
location->index:如用戶未指定請求資源名稱,默認(rèn)訪問index指定的文件,如訪問http://host:port/html/則默認(rèn)訪問http://host:port/html/index.html

測試場景

我們假設(shè)有以下三個場景

場景1

宿主機(jī)有個目錄存儲靜態(tài)資源,需要通過nginx代理出去,用戶訪問http://host:port/resource/xxxx訪問

場景2

tomcat服務(wù)器(docker容器)上運行一個web程序,需要通過nginx代理出去,web程序context root為WebTestApp

場景3

該web程序運行在兩個tomcat容器中,需要通過nginx做負(fù)載均衡

nginx配置文件掛載

docker容器每次重啟都是一個新的環(huán)境,也就是說在docker容器內(nèi)做的任何修改都將被還原,但nginx的配置文件是在docker容器內(nèi),我們?nèi)绻苯舆M(jìn)行修改每次重啟后都會被還原,這并不是我們所希望的,所以首先需要將配置文件從docker容器中"搬到"宿主機(jī)上,這里會通過docker的卷(volume)實現(xiàn)。
volume可以將本地文件掛載到docker容器內(nèi),這樣容器重啟后信息不會丟失
對于nginx,可以將nginx.conf文件和conf.d目錄從容器內(nèi)部"搬"出來
在本地創(chuàng)建nginx.conf文件和conf.d目錄

[root@docker /]# mkdir -p /u01/nginx
[root@docker /]# mkdir -p /u01/nginx/conf.d
[root@docker /]# touch /u01/nginx/nginx.conf
[root@docker /]# touch /u01/nginx/conf.d/default.conf

nginx.conf文件和default.conf內(nèi)容可以直接從容器內(nèi)部復(fù)制

nginx.conf
user  nginx;
worker_processes  1;

error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;

    log_format  main  "$remote_addr - $remote_user [$time_local] "$request" "
                      "$status $body_bytes_sent "$http_referer" "
                      ""$http_user_agent" "$http_x_forwarded_for"";

    access_log  /var/log/nginx/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    keepalive_timeout  65;

    #gzip  on;

    include /etc/nginx/conf.d/*.conf;
}
default.conf
server {
    listen       80;
    server_name  localhost;

    #charset koi8-r;
    #access_log  /var/log/nginx/host.access.log  main;

    location / {
        root   /usr/share/nginx/html;
        index  index.html index.htm;
    }

    #error_page  404              /404.html;

    # redirect server error pages to the static page /50x.html
    #
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   /usr/share/nginx/html;
    }

    # proxy the PHP scripts to Apache listening on 127.0.0.1:80
    #
    #location ~ .php$ {
    #    proxy_pass   http://127.0.0.1;
    #}

    # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
    #
    #location ~ .php$ {
    #    root           html;
    #    fastcgi_pass   127.0.0.1:9000;
    #    fastcgi_index  index.php;
    #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
    #    include        fastcgi_params;
    #}

    # deny access to .htaccess files, if Apache"s document root
    # concurs with nginx"s one
    #
    #location ~ /.ht {
    #    deny  all;
    #}
}

重新啟動nginx

[root@docker /]# docker stop my_nginx
my_nginx
[root@docker /]# docker rm my_nginx
my_nginx
[root@docker nginx]# docker run --name=my_nginx -v /u01/nginx/nginx.conf:/etc/nginx/nginx.conf -v /u01/nginx/conf.d:/etc/nginx/conf.d -p 8000:80 -d nginx
6efe91858f071a50197da104cdccf8500234f1bf6d0f4f56d3dc5de02261272c
[root@docker /]# curl http://192.168.43.32:8000



Welcome to nginx!
....

注意到執(zhí)行了一個 docker rm my_nginx 命令,這是因為容器每次啟動需要指定不同的名字,一個名字不能使用多次,可以通過 docker ps -a查看所有容器,包括未運行的容器。rm命令可以刪除指定容器
下面正式配置上面三個場景

場景1-靜態(tài)資源代理

在u01目錄下創(chuàng)建目錄resource,并上傳靜態(tài)資源

[root@docker resource]# pwd
/u01/resource
[root@docker resource]# ll
total 164
-rw-r--r--. 1 root root 147291 Oct  8  2015 angular.min.js
-rw-r--r--. 1 root root  17189 Nov  3 10:32 docker.jpg
[root@docker resource]#

修改/u01/nginx/conf.d/default.conf文件

default.conf
server {
    listen       80;
    server_name localhost;
    location /resource {
        root   /u01;
        index  index.html index.htm;
    }
}

ps:root是/u01不是/u01/resource。如果root配置成/u01/resource/則nginx會去/u01/resource/resource目錄下尋找文件
重新啟動nginx容器,將resource目錄掛載到容器內(nèi)部

[root@docker u01]# docker stop my_nginx
my_nginx
[root@docker u01]# docker rm my_nginx
my_nginx
[root@docker u01]# docker run --name=my_nginx -v /u01/nginx/nginx.conf:/etc/nginx/nginx.conf -v /u01/nginx/conf.d:/etc/nginx/conf.d -v /u01/resource:/u01/resource -p 8000:80 -d nginx

訪問
http://192.168.43.32:8000/resource/docker.jpg
http://192.168.43.32:8000/resource/angular.min.js
測試配置是否成功(將上面ip替換成宿主機(jī)ip)

場景2-tomcat代理

準(zhǔn)備一個servet作為測試

package com.df.demo;

import java.io.IOException;
import java.io.PrintWriter;

import javax.servlet.*;
import javax.servlet.http.*;

public class WebTestService extends HttpServlet {
    private static final String CONTENT_TYPE = "text/html; charset=UTF-8";

    public void init(ServletConfig config) throws ServletException {
        super.init(config);
    }

    public void doGet(HttpServletRequest request,
                      HttpServletResponse response) throws ServletException,
                                                           IOException {
        response.setContentType(CONTENT_TYPE);
        PrintWriter out = response.getWriter();
        out.print("hello docker tomcat");
        out.close();
    }
}

打成war包,包名為WebTestApp.war,在u01上創(chuàng)建webapps目錄并上傳war包

[root@docker webapps]# pwd
/u01/webapps
[root@docker webapps]# ls
WebTestApp.war

啟動tomcat容器,并將/u01/webapps目錄掛載到tomcat的/usr/local/tomcat/webapps目錄下

[root@docker ~]# docker run --name=my_tomcat1 -v /u01/webapps:/usr/local/tomcat/webapps -p 8001:8080 -d tomcat
[root@docker ~]# curl http://localhost:8001/WebTestApp
hello docker tomcat

程序已經(jīng)成功部署到tomcat上
修改/u01/nginx/conf.d/default.conf文件

default.conf
server {
    listen       80;
    server_name localhost;
    location / {
        proxy_pass   http://tomcat_server;
    }
}

修改/u01/nginx/nginx.conf在http配置節(jié)點中增加以下配置

upstream tomcat_server {
      server t1:8080;
    }

upstream 可以定義一組服務(wù)器
proxy_pass 設(shè)置代理的服務(wù)器,格式為http://upstream_name

重啟nginx容器,這里我們需要使用一個新的docker參數(shù)--link

[root@docker u01]# docker run --name=my_nginx1 --link=my_tomcat1:t1 -v /u01/nginx/nginx.conf:/etc/nginx/nginx.conf -v /u01/nginx/conf.d:/etc/nginx/conf.d -p 8000:80 -d nginx
[root@docker ~]# curl http://192.168.43.32:8000/WebTestApp
hello docker tomcat

ps:這里換了一個名字my_nginx1,用原來的名字my_nginx無法啟動容器,會報以下錯誤

2018/01/27 08:40:44 [emerg] 1#1: host not found in upstream "t1:8080" in /etc/nginx/nginx.conf:30
nginx: [emerg] host not found in upstream "t1:8080" in /etc/nginx/nginx.conf:30

t1無法找到,但如果不使用--name指定名稱可正常啟動,原因未知。
link參數(shù)可以在兩個容器之間建立網(wǎng)絡(luò)連接,格式為--link=my_tomcat1:t1 my_tomcat1為容器名稱,t1為取的別名
可登錄nginx容器查看/etc/hosts文件,docker會將t1加入到hosts文件中

[root@docker ~]# docker exec -it my_nginx1 bash
root@fa5f782b9448:/# more /etc/hosts
127.0.0.1    localhost
::1    localhost ip6-localhost ip6-loopback
fe00::0    ip6-localnet
ff00::0    ip6-mcastprefix
ff02::1    ip6-allnodes
ff02::2    ip6-allrouters
172.17.0.5    t1 1f9b1d432ab0 my_tomcat1
172.17.0.6    fa5f782b9448
場景3-tomcat負(fù)載均衡

修改/u01/nginx/nginx.conf在場景2的基礎(chǔ)上增加新的服務(wù)器

upstream tomcat_server {
      server t1:8080;
      server t2:8080;
    }

在啟動一個tomcat容器my_tomcat2

[root@docker ~]# docker run --name=my_tomcat2 -v /u01/webapps:/usr/local/tomcat/webapps -d tomcat

重啟nginx

[root@docker /]# docker stop my_nginx1
[root@docker /]# dcoker rm my_nginx1
[root@docker /]# docker run --name=my_nginx1 --link=my_tomcat1:t1 --link=my_tomcat2:t2 -v /u01/nginx/nginx.conf:/etc/nginx/nginx.conf -v /u01/nginx/conf.d:/etc/nginx/conf.d -p 8000:80 -d nginx
[root@docker ~]# curl http://192.168.43.32:8000/WebTestApp
hello docker tomcat

可以分別登錄兩個tomcat容器查看access.log可以查看結(jié)果,nginx在兩臺服務(wù)器之間做輪詢.輪詢是nginx默認(rèn)的負(fù)載均衡方式。

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://specialneedsforspecialkids.com/yun/27318.html

相關(guān)文章

  • 使用Docker+Nginx模擬負(fù)載均衡

    摘要:以及自動剔除因故障負(fù)載均衡列表中宕機(jī)的服務(wù)器。這兩天折騰了一下的安裝配置,并通過模擬出在多服務(wù)器提供服務(wù)的狀態(tài)下的負(fù)載均衡。修改好配置文件后,使用重新載入配置。 原文發(fā)表于我的博客,轉(zhuǎn)載請注明出處 一直聽說Nginx的強大,它不僅可以作為Web服務(wù)器,按照調(diào)度規(guī)則實現(xiàn)動態(tài)、靜態(tài)頁面的分離;還可以作為反向代理服務(wù)器,構(gòu)建服務(wù)集群,按輪詢、權(quán)重等多種方式對后端服務(wù)器做負(fù)載均衡。以及自動剔...

    davidac 評論0 收藏0
  • 使用Docker+Nginx模擬負(fù)載均衡

    摘要:以及自動剔除因故障負(fù)載均衡列表中宕機(jī)的服務(wù)器。這兩天折騰了一下的安裝配置,并通過模擬出在多服務(wù)器提供服務(wù)的狀態(tài)下的負(fù)載均衡。修改好配置文件后,使用重新載入配置。 原文發(fā)表于我的博客,轉(zhuǎn)載請注明出處 一直聽說Nginx的強大,它不僅可以作為Web服務(wù)器,按照調(diào)度規(guī)則實現(xiàn)動態(tài)、靜態(tài)頁面的分離;還可以作為反向代理服務(wù)器,構(gòu)建服務(wù)集群,按輪詢、權(quán)重等多種方式對后端服務(wù)器做負(fù)載均衡。以及自動剔...

    import. 評論0 收藏0
  • dockernginx反向代理負(fù)載均衡配置

    摘要:命令可以刪除指定容器下面正式配置上面三個場景場景靜態(tài)資源代理在目錄下創(chuàng)建目錄并上傳靜態(tài)資源修改文件是不是。 鏡像安裝 可以通過以下命令拉取nginx和tomcat鏡像作為測試 [root@docker /]# docker pull nginx [root@docker /]# docker pull tomcat nginx 鏡像下載完后,執(zhí)行以下命令啟動nginx [root@do...

    _DangJin 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<