码迷,mamicode.com
首页 > 其他好文 > 详细

docker-7 docker在阿里云的使用

时间:2016-11-16 02:57:16      阅读:276      评论:0      收藏:0      [点我收藏+]

标签:targe   centos6   SHA256   推送   ssl   ted   命令   内网   理论   

在传统模式中,开发团队在开发环境中完成软件开发,自己做了一遍单元测试, 测试通过,?交到代码版本管理库。运维把应用部署到测 试环境, QA 进行测试,没问题后通知部署人员发布到生产环境。 在上述过程中涉及到至少三个环境:开发、测试和生产。现实情况是,开发自测 没问题,但到了测试或者生产环境程序无法运行,让开发团队排查,经过长时间 排查最后发现是测试环境的一个第三方库过时了。这样的现象在软件开发中很普 遍,已经不适用如今的快速开发和部署。docker可以满足你的需求。

阿里云容器hub开发者平台,可以去这里下载需要的镜像

https://dev.aliyun.com/search.html?spm=5176.1972343.0.1.MSG1P3

首先先查看内核版本,这一步很重要

# 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.conf

default=0    把default=1 改为default = 0

最后重启服务器

开始安装docker

# curl -sSL https://get.docker.com/ | sh  

# docker --version
Docker 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 centos
latest: Pulling from centos
3690474eb5b4: Already exists 
af0819ed1fac: Already exists 
05fe84bf6d3f: Already exists 
97cad5e16cb6: Already exists 
Digest: sha256:934ff980b04db1b7484595bac0c8e6f838e1917ad3a38f904ece64f70bbca040
Status: Image is up to date for centos:latest

从阿里云私有镜像仓库拉取centos镜像到本地,因为配置了阿里云镜像加速,所以下载非常快,30秒钟搞定。

# docker images

REPOSITORY                             TAG                 IMAGE ID            CREATED             VIRTUAL SIZE centos 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 #ADD ADD jdk1.7.0_72.gz /usr/local/ ADD biz-tomcat.tar.gz /usr/local/ #RUN RUN yum -y install wget gcc gcc-c++ make openssl openssl-devel net-tools vim RUN mkdir /docker/myapp/ROOT -p #ENV ENV JAVA_HOME /usr/local/jdk1.7.0_72 ENV JRE_HOME $JAVA_HOME/jre ENV CLASSPATH .:$JAVA_HOME/lib:$JRE_HOME/lib ENV PATH $PATH:$JAVA_HOME/bin ENV CATALINA_HOME /usr/local/biz-tomcat EXPOSE 8080 CMD ["/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 NAMES
969ad48e4085 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

 

 

 

 

 

docker-7 docker在阿里云的使用

标签:targe   centos6   SHA256   推送   ssl   ted   命令   内网   理论   

原文地址:http://www.cnblogs.com/kafeikele/p/6067958.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!