docker容器間通訊的一種方法

轉載請註明出處,原文連接http://tailnode.tk/2017/01/do...node

以個人ghost博客爲例進行說明,我在VPS上用docker啓動了兩個ghost博客,還有一個Nginx作反向代理,將兩個域名分別指向兩個博客。nginx

docker啓動命令

ghost:docker

docker run -e NODE_ENV=production --name ghost1 -v /path/to/data/ghost/ghost1/:/var/lib/ghost -d ghost
docker run -e NODE_ENV=production --name ghost2 -v /path/to/data/ghost/ghost2/:/var/lib/ghost -d ghost

nginx:dom

docker run -p 80:80 --name nginx --link ghost1 --link ghost2 -v /path/to/data/nginx/nginx.conf:/etc/nginx/nginx.conf -d nginx

先啓動兩個ghost,而後啓動nginx。使用--link參數將容器「連接」到一塊兒,此參數會在容器中加入環境變量並在/etc/hosts中插入一條容器名與IP的映射代理

root@fabfd4bacfda:/# cat /etc/hosts
172.17.0.3      ghost1 d19c0134011a
172.17.0.5      ghost2 0e2e66ba70e0
172.17.0.4      fabfd4bacfda

設置nginx反向代理

修改nginx.conf,在http段內添加以下內容code

http {
    server {
        listen 80;
        server_name www.domain1.tk domain1.tk;

        location / {
            proxy_pass http://ghost1:2368;
            proxy_redirect     off;
            proxy_set_header   Host             $host;
            proxy_set_header   X-Real-IP        $remote_addr;
            proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for;
        }
    }
    server {
        listen 80;
        server_name www.domain2.tk domain2.tk;

        location / {
            proxy_pass http://ghost2:2368;
            proxy_redirect     off;
            proxy_set_header   Host             $host;
            proxy_set_header   X-Real-IP        $remote_addr;
            proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for;
        }
    }

}

注意proxy_pass的值proxy_pass http://ghost2:2368;。 ghost2是nginx容器/etc/hosts中的一條,是由--link參數添加進來的。server

設置完這些後,nginx就會將兩個域名的請求分別代理到兩個博客中。rem

補充

容器重啓後IP可能變化,因此直接在nginx.conf中指定IP並非一個好方法。使用--link時hosts文件會隨着容器IP的變化更新,因此使用域名纔是更容易維護的方法。get

相關文章
相關標籤/搜索