docker-tomcat-nginx 反向代理和负载均衡

1.部署tomcat镜像

下载官方的tomcat镜像。
sudo docker pull tomcat:7-jre7

 

启动docker容器,2个实例,分别映射不同的端口号,
~/work/sample-webapps/[v1.0|v2.0]/下面存放JavaWeb.war包,通过volume方式映射到docker镜像中
docker run -it --rm -p 8080:8080 -v ~/work/sample-webapps/v1.0:/usr/local/tomcat/webapps/ tomcat:7-jre7
docker run -it --rm -p 8081:8080 -v ~/work/sample-webapps/v2.0:/usr/local/tomcat/webapps/ tomcat:7-jre7

启动完成之后,就可以访问到两个tomcat服务了。192.168.5.109是docker宿主机的ip。

在8080和8081两个端口启动两个容器,分别对应不同的版本号,方便识别。
通过端口映射访问到JavaWeb应用,用浏览器测试即可。
 

1.1 如何进入docker容器内部?

#查看当前docker容器,使用4位id可以进入docker容器内部
docker ps  # 找到对应的容器id
docker exec -t -i yourContainerName /bin/bash #通过shell进入docker容器内部

 

 

2.配置nginx反向代理和负载均衡

通过nginx反向代理之后,请求动态数据/JavaWeb的数据,都转发到tomcat中处理,
多个tomcat组成集群,负载均衡就可以实现,V1.0 和V2.0 都可能显示
组成tomcat集群的upstream更详细配置,可以参考官方文档,nginx默认以轮询方式转发请求给tomcat集群中的服务器,还有ip_hash等其他方式。
反向代理之后效果如下:
 
 
ubuntu14.04 上面sudo apt-get install 安装的 nginx版本是1.6 稳定版 
启动方式 sudo /etc/init.d/nginx start 如果端口占用,说明安装之后已经默认启动完成了。
nginx重新加载配置文件,不需要重启nginx sudo /etc/init.d/nginx reload
/etc/nginx/nginx.conf 文件内容如下:
user www-data;
worker_processes 4;
pid /run/nginx.pid;
 
events {
    worker_connections 768;
    # multi_accept on;
}
 
http {
 
    ##
    # Basic Settings
    ##
 
    sendfile on;
    tcp_nopush on;
    tcp_nodelay on;
    keepalive_timeout 65;
    types_hash_max_size 2048;
    # server_tokens off;
 
    # server_names_hash_bucket_size 64;
    # server_name_in_redirect off;
 
    include /etc/nginx/mime.types;
    default_type application/octet-stream;
 
    ##
    # Logging Settings
    ##
 
    access_log /var/log/nginx/access.log;
    error_log /var/log/nginx/error.log;
 
    ##
    # Gzip Settings
    ##
 
    gzip on;
    gzip_disable "msie6";
 
    # gzip_vary on;
    # gzip_proxied any;
    # gzip_comp_level 6;
    # gzip_buffers 16 8k;
    # gzip_http_version 1.1;
    # gzip_types text/plain text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript;
 
    ##
    # nginx-naxsi config
    ##
    # Uncomment it if you installed nginx-naxsi
    ##
 
    #include /etc/nginx/naxsi_core.rules;
 
    ##
    # nginx-passenger config
    ##
    # Uncomment it if you installed nginx-passenger
    ##
 
    #passenger_root /usr;
    #passenger_ruby /usr/bin/ruby;
 
    ##
    # Virtual Host Configs
    ##
 
    include /etc/nginx/conf.d/*.conf;
    include /etc/nginx/sites-enabled/*;
 
    upstream docker-tomcat-cluster {
      server 127.0.0.1:8080;    
      server 127.0.0.1:8081;
    }
    server { 
        listen 80;
        server_name 192.168.5.109; #must give the domain to match
        location /JavaWeb { 
          proxy_pass http://docker-tomcat-cluster ;
          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; 
        } 
    }
}

 

3.docker镜像迁移和批量部署

sudo docker images
sudo docker save -o ./tomcat7-jre7.tar ccc8

 

将tar文件,copy到另一台主机
docker load -i /opt/soft_bak/tomcat7-jre7.tar

 

导入后未命名,通过tag命令打上标记。
docker images #找到镜像
docker tag 3e7767ddd728 geektown/tomcat7-jre7
docker images #查看tag之后的镜像

 

 
posted @ 2015-11-28 21:19  极客堂  阅读(4000)  评论(0编辑  收藏  举报