设为首页 收藏本站
查看: 1018|回复: 0

[经验分享] 利用Ansible部署运行Apache(http)的Docker容器

[复制链接]

尚未签到

发表于 2018-7-29 09:04:04 | 显示全部楼层 |阅读模式
  在自动化运维领域,除了saltstack,还有ansible这个批量安装部署工具,在写具体内容先,先谈谈我用过两个工具后的感想。
  saltstack是C/S框架,要在客户端装软件,并且启动服务才能进行管理,ansible是通过ssh连接到客户端的,也就是说必须把密钥传给客户端才能进行管理,虽然可以关闭这个验证方式,但是生产环境中肯定是不能关闭的,从这一点看,还是ansible更容易配置,完全可以用脚本循环遍历所有主机来添加密钥。
  使用方面,命令复杂程度相似,理解起来更容易的应该是saltstack,命令基本都是英语的组合,ansible则是依靠各种模式,参数来执行管理。
  脚本编程方面,编程复杂度方面不尽相同,ansible提供群组的方式来对多主机提供管理,在推送操作到客户端时需给出明确的执行文件(yml),对于文件的存放位置没有明确的规定,saltstack需要在命令行提供主机信息,在推送时执行的是配置文件中提供的目录中的文件(sls),推送的文件也必须在这个目录中。
  以上是我个人的一些见解,下面开始实战操作
  环境介绍:
  Centos 6.5
  Ansible 2.3.0
  Docker 1.7.1
  Http 2.4.6-67
  一.Docker操作
  1.docker安装
  这部分略过,如果你对docker安装和一些常用命令不了解,请参考《Docker常用命令和操作》
  2.拉取ansible镜像
  docker pull ansible/centos7-ansible    #推荐使用这个镜像
  拉取成功后可以在images里查看到这个镜像
DSC0000.png

  3.运行镜像,打开一个容器
  docker run -it --name ansible 6883
  4.修改配置文件
  vi /etc/ansible/hosts
  [local]\nlocalhost\n  >>>>>
  [local]
  localhost
  这两个回车符在运行时是不能转义的,会报错
  5.提交修改后的容器
  docker commit 1277 ansiblev2
  6.编写镜像构建方法
  vim Dockerfile
FROM ansiblev2  
MAINTAINER bin bin@123.com
  

  

  
WORKDIR /opt/ansible    #定义工作区
  
RUN mkdir /opt/ansible/files    #创建必须目录
  
RUN mkdir /opt/ansible/template
  

  
ADD httpd.conf /opt/ansible/files    #把需要的文件复制到指定位置
  
ADD index.html.j2 /opt/ansible/template
  
ADD web.yml /opt/ansible/
  

  
RUN ansible-playbook /opt/ansible/web.yml -c local  #运行ansible进行自动部署
  

  
VOLUME /var/www/html    #定义数据卷
  

  
CMD ["/usr/sbin/httpd","-X"]    #让httpd服务在前台运行
  
EXPOSE 80        #开放80端口,httpd.conf配置文件中必须也是80端口
  二.Ansible操作
  1.编写服务部署方法
  vim web.yml  #ansible和saltstack在文字格式方面要求同样严格,如果报错,请查看格式是否正确!
- name: Configure webserver with http        #在运行时的提示信息  
  hosts: local        #对本地主机组进行操作
  
  sudo: True        #运行时切换用户
  
  tasks:            #建立任务
  
    - name: install http
  
      yum: name=httpd update_cache=yes    #安装httpd,更新缓存
  
    - name: copy http config file
  
      copy: src=files/httpd.conf dest=/etc/httpd/conf    #文件复制
  

  
    - name: enable configuration
  
      file: >        #竖版写法,建立软连接
  
         dest=/etc/httpd/configure
  
         src=/etc/httpd/conf/
  
         state=link
  

  
    - name: copy index.html    #拷贝主页文件
  
      template: src=template/index.html.j2 dest=/var/www/html/index.html mode=0644
  2.index.html.j2的内容
<html>  
  <head>
  
    <title>Welcome to ansible!</title>
  
  </head>
  
  <body>
  
  <h1>http,configured by Ansible</h1>
  
  <p>If you can see this,Ansible successfully installed http.</p>
  
  <p>{{ ansible_env }}</p>    #会显示容器的环境变量
  
  #要想显示更多信息,可以通过ansible hostname -m setup来查看可以引用的变量
  
  <p>{{ ansible_env.PATH }}</p>    #显示环境变量中的PATH的值
  
  </body>
  
</html>
  三.构建镜像,启动容器
  1.构建镜像
  当前目录结构
DSC0001.png

  docker build -t ansible/httpd .
  2.启动容器
  docker run -d -p 8000:80 --name httpd ansible/httpd  #把容器的80端口映射到本地的8000端口
  3.查看容器运行情况
  docker ps -a
DSC0002.png

  4.因为在构建镜像的时候指定了数据卷,可以在启动容器的时候挂载数据卷,方便代码修改
  docker run -d -p 8001:80 -v /var/www/html:/var/www/html --name http2 ansible/httpd
  四.测试主页
  http://192.168.6.10:8000
DSC0003.png

  出现如上显示为部署正常

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-542826-1-1.html 上篇帖子: 基于ansible自动化定义zabbix-keys 下篇帖子: 用Ansible配置思科网络设备
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表