在传统模式中,开发团队在开发环境中完成软件开发,自己做了一遍单元测试, 测试通过,ᨀ交到代码版本管理库。运维把应用部署到测 试环境, QA 进行测试,没问题后通知部署人员发布到生产环境。 在上述过程中涉及到至少三个环境:开发、测试和生产。现实情况是,开发自测 没问题,但到了测试或者生产环境程序无法运行,让开发团队排查,经过长时间 排查最后发现是测试环境的一个第三方库过时了。这样的现象在软件开发中很普 遍,已经不适用如今的快速开发和部署。docker可以满足你的需求。
阿里云容器hub开发者平台,可以去这里下载需要的镜像
首先先查看内核版本,这一步很重要
# uname -a
查看系统内核版本,docker要求内核版本为3.10以上,建议(不要在centos6.6上面安装使用docker,有很多坑,我就是一个个踩过来的)
我使用的是阿里云的ECS centos 6.6 64位的,所以需要升级内很,内核版本升级的方法:
# rpm --import https://www.elrepo.org/RPM-GPG-KEY-elrepo.org# rpm -Uvh http://www.elrepo.org/elrepo-release-6-6.el6.elrepo.noarch.rpm# yum --enablerepo=elrepo-kernel install kernel-lt -y# vim /etc/grub.confdefault=0 把default=1 改为default = 0最后重启服务器
开始安装docker
# curl -sSL https://get.docker.com/ | sh # docker --versionDocker version 1.7.1, build 786b29d# vim /etc/sysconfig/docker other_args="--registry-mirror=https://rr8hxwoy.mirror.aliyuncs.com -H tcp://0.0.0.0:235 -H unix:///var/run/docker.sock" 配置阿里云加速 docker pull会很快
启动docker
# /etc/init.d/docker start # chkconfig docker on
运行docker容器
# docker pull centoslatest: Pulling from centos3690474eb5b4: Already exists af0819ed1fac: Already exists 05fe84bf6d3f: Already exists 97cad5e16cb6: Already exists Digest: sha256:934ff980b04db1b7484595bac0c8e6f838e1917ad3a38f904ece64f70bbca040Status: Image is up to date for centos:latest
从阿里云私有镜像仓库拉取centos镜像到本地,因为配置了阿里云镜像加速,所以下载非常快,30秒钟搞定。
# docker images REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZEcentos latest 97cad5e16cb6 12 days ago 196.5 MB # docker run -d -it centos /bin/bash 运行centos容器 # docker ps -a CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 969ad48e4085 centos "/bin/bash" 5 seconds ago Up 4 seconds jovial_torvalds # docker exec -it 969a /bin/bash 进入容器 969a是容器的ID
Docker启动容器命令在前面已经详细的讲过,不会的童鞋可以到我之前的博客看看
重点来了
java+tomcat在容器中应用
测试环境服务器配置 centos 6.6 64位,4核处理器,8G内存
理论上可以跑16个java容器,因为每个容器消耗内存为500M左右,我在上面跑了8个java容器,另外跑了一个nginx做反向代理和一个redis,nginx 和redis都没有使用docker
需要前提下载好jdk1.7.0.72和 tomcat ,并把他们放在和Dockerfile同一级目录 vim Dockerfile #This is My first Dockerfile#version 1.0#Base image FROM centos:latest#MAINTAINER hh Wang#ADDADD jdk1.7.0_72.gz /usr/local/ADD biz-tomcat.tar.gz /usr/local/#RUNRUN yum -y install wget gcc gcc-c++ make openssl openssl-devel net-tools vimRUN mkdir /docker/myapp/ROOT -p#ENVENV JAVA_HOME /usr/local/jdk1.7.0_72ENV JRE_HOME $JAVA_HOME/jreENV CLASSPATH .:$JAVA_HOME/lib:$JRE_HOME/libENV PATH $PATH:$JAVA_HOME/binENV CATALINA_HOME /usr/local/biz-tomcatEXPOSE 8080CMD ["/usr/local/biz-tomcat/bin/catalina.sh","run"]
# docker build -t whh/biz_tomcat:v1 . 后面有一个点,一定要记住
# docker run -it -d -v /mnt/docker/myapp/ROOT/biz:/docker/myapp/ROOT -v /var/log/biz-tomcat/logs:/usr/local/biz-tomcat/logs -p 9080:8080 --name biz whh/biz_tomcat:v1
tomcat的根目录要事先修改为自己需要的路径,我这里为docker/myapp/ROOT,把根目录挂在在宿主机的/mnt/docker/myapp/ROOT/biz目录下面,当更新代码的时候,直接把代码传到这个目录,然后重启一下容器就可以了,不需要把代码上传到容器里面,那样很麻烦。
[root@VM_159_91_centos biz]# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES969ad48e4085 centos "/bin/bash" 21 minutes ago Up 21 minutes jovial_torvalds f67257661e70 registry "/entrypoint.sh /etc 7 hours ago Up 7 hours 0.0.0.0:5000->5000/tcp high_darwin 4bcc381f5b9f whh/biz_tomcat:v1 "/usr/local/biz-tomc 9 hours ago Up 7 hours 0.0.0.0:9080->8080/tcp biz# docker tag whh/biz_tomcat:v1 IP:5000/whh/biz_tomcat:v1 IP写自己本机内网的IP或者公网IP都可以
# docker push IP:5000/whh/biz_tomcat:v1 推送到自己私有的仓库,从其他的服务器就可以直接pull下来使用
00:19:15 2016-11-16