1.部署tomcat镜像

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

docker-tomcat-nginx 反向代理和负载均衡的更多相关文章

  1. nginx和tomcat实现反向代理、负载均衡和session共享

    这类的文章很多,nginx和tomcat实现反向代理.负载均衡实现很容易,可以参照http://blog.csdn.net/liuzhigang1237/article/details/8880752 ...

  2. Nginx反向代理,负载均衡,redis session共享,keepalived高可用

    相关知识自行搜索,直接上干货... 使用的资源: nginx主服务器一台,nginx备服务器一台,使用keepalived进行宕机切换. tomcat服务器两台,由nginx进行反向代理和负载均衡,此 ...

  3. 使用nginx反向代理进行负载均衡

    在这里简单记录一下,我使用Nginx反向代理进行负载均衡,将请求发送到两台tomcat上. 首先解压两个tomcat,解压Nginx,一台tomcat配置可以不用动,但是我为了更方便只是将它的端口改为 ...

  4. 一篇文章搞定 Nginx 反向代理与负载均衡

    代理 要想弄明白反向代理,首先要知道啥是正向代理,要搞懂正向代理只需要知道啥是代理即可.代理其实就是一个中介,在不同事物或同一事物内部起到居间联系作用的环节.比如买票黄牛,房屋中介等等. 在互联网中代 ...

  5. nginx反向代理与负载均衡

    一:nginx反向代理与负载均衡配置思路与用法 1.nginx反向代理:就是你去相亲时,媒婆就是这里的代理,让媒婆带你去见姑娘 2.nginx负载均衡:就是有很多的媒婆经过商量给你选出最适合你的姑娘, ...

  6. 【转】Nginx反向代理和负载均衡

    原文链接:http://www.cnblogs.com/shuoer/p/7820899.html Nginx反向代理和负载均衡 环境说明 由于我使用的是windows系统,所以我用虚拟机虚拟出来了3 ...

  7. 谁说前端不需要懂-Nginx反向代理与负载均衡

    转:https://juejin.im/post/5b01336af265da0b8a67e5c9 学到老活到老 前端圈一直很新,一直要不停的学习,而且在进入大厂的路上,还要求熟悉一门后台语言等等.用 ...

  8. [转]Nginx反向代理和负载均衡部署指南

    Nginx反向代理和负载均衡部署指南   1.        安装 1)         从Nginx官网下载页面(http://nginx.org/en/download.html)下载Nginx最 ...

  9. 基于Nginx反向代理及负载均衡

    基于Nginx反向代理及负载均衡 参考:http://nginx.org/en/docs/http/ngx_http_proxy_module.html#proxy_pass 只要没有被启用,默认就是 ...

  10. (二)Nginx反向代理与负载均衡的实现

    引言:nginx正向代理与反向代理在上一篇文章中已经谈论过,这里狗尾草主要告诉大家Nginx对前端的小伙伴来说在工作中如何简单的使用. 1.0什么是反向代理 当我们有一个服务器集群,并且服务器集群中的 ...

随机推荐

  1. windows7使用Source insight上远程修改ubuntu共享内核源码

    由于本人阅读喜欢使用source insight.前段时间接触了linux核代码,而这份代码只能放在ubuntu服务器上编译,刚开始的时候是在windows上修改,完了之后再copy到服务器上去编译, ...

  2. c++中字符串处理函数

    c++11中提供了to_string函数,定义在string中, 重载了一大片, std::string to_string( int value ); () (since C++) std::str ...

  3. Tomcat的ServletAPI与Jetty的不能混用,否则会出现Serlvt类无法编译

  4. [JS]setInterval,setTimeout的使用以及伪随机数

  5. WLS_Oracle Weblogic安装和环境搭建(案例)

    2014-01-03 Created By BaoXinjian

  6. CF 161D Distance in Tree 树形DP

    一棵树,边长都是1,问这棵树有多少点对的距离刚好为k 令tree(i)表示以i为根的子树 dp[i][j][1]:在tree(i)中,经过节点i,长度为j,其中一个端点为i的路径的个数dp[i][j] ...

  7. CF 445A 简单DP

    今天早上找一道题的bug,还是找不出来,下午刷了几道水题,晚上准备回家的事, 然后本来想打CF的,一看,数学场,不打了. 这道题的题意: 给出一个序列,每次你可以从这个序列里面选择一个数ak,删除,然 ...

  8. POJ 3187 杨辉三角+枚举排列 好题

    如果给出一个由1~n组成的序列,我们可以每相邻2个数求和,得到一个新的序列,不断重复,最后得到一个数sum, 现在输入n,sum,要求输出一个这样的排列,如果有多种情况,输出字典序最小的那一个. 刚开 ...

  9. IP地址查询接口

    新浪的IP地址查询接口:http://int.dpool.sina.com.cn/iplookup/iplookup.php?format=js 新浪多地域测试方法:http://int.dpool. ...

  10. 帝国cms常用变量总结

    一.常用变量 当前栏目ID $GLOBALS['navclassid'] 当前父栏目ID $class_r[$cid]['bclassid'] 栏目路径 $class_r[栏目ID]['classpa ...