设为首页 收藏本站
云服务器等爆品抢先购,低至4.2元/月
查看: 2309|回复: 0

[经验分享] Docker远程python API操作容器一例

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2014-11-14 10:38:29 | 显示全部楼层 |阅读模式
      Docker-py作为官方推出的客户端API,功能可以满足我们大部分操作需求,API涉及镜像(images)及容器(CONTAINER)的功能操作,利用docker-py可以轻松开发出Docker的管理平台,以便维护大规模的Docker集群,本文介绍如何通过DockerFile创建一个WEB服务的镜像,再通过远程API对容器进行管理。

一、环境准备
1、环境说明
192.168.1.20 #Docker python API主机
192.168.1.22 #Docker服务主机
2、Docker环境部署(略)
3、修改自启动服务文件,支持远程TCP接口与本地SOCK连接;
# vi /etc/init.d/docker

    $exec -H tcp://0.0.0.0:2375 -H unix:///var/run/docker.sock -d &>> $logfile &  

#service docker restart

二、创建镜像
1、获取最新的centos镜像
# docker pull centos:latest
2、编写Dockerfile(支持apache+ssh服务)
# mkdir /home/Dockerfile/webserver
# cd /home/Dockerfile/webserver
# vi Dockerfile

    # This is a base comment  
    FROM centos:latest  
    MAINTAINER yorko Liu <liutiansi@gmail.com>  
      
    #yum install Package  
    RUN yum -y install net-tools  
    RUN yum -y install iputils  iproute  man  vim-minimal  openssh-server  openssh-clients  
    RUN yum -y install httpd  
    RUN yum -y install python-setuptools  
    RUN easy_install supervisor  
      
    #set sshd  
    RUN ssh-keygen -q -N "" -t dsa -f /etc/ssh/ssh_host_dsa_key  
    RUN ssh-keygen -q -N "" -t rsa -f /etc/ssh/ssh_host_rsa_key  
    RUN ssh-keygen -t ecdsa -f /etc/ssh/ssh_host_ecdsa_key -N ""  
    RUN sed -ri 's/session    required     pam_loginuid.so/#session    required     pam_loginuid.so/g' /etc/pam.d/sshd  
    RUN mkdir -p /root/.ssh && chown root.root /root && chmod 700 /root/.ssh  
    RUN echo 'root:Ksjhg34TDju' | chpasswd  
      
    #set supervisor  
    RUN mkdir -p /var/log/supervisor  
    ADD supervisord.conf /etc/supervisord.conf  
      
    #set port  
    EXPOSE 22  
    EXPOSE 80  
      
    #set ENV  
    ENV LANG en_US.UTF-8  
    ENV LC_ALL en_US.UTF-8  
      
    #run supervisor  
    CMD ["/usr/bin/supervisord -c /etc/supervisord.conf"]  


通过supervisord来维护Docker容器中服务进程,编写supervisord.conf
# vi supervisord.conf

    [supervisord]  
    nodaemon=true  
      
    [program:sshd]  
    command=/usr/sbin/sshd -D  
      
    [program:httpd]  
    command=/usr/sbin/httpd -DFOREGROUND  


创建镜像,运行:
# docker build -t yorko/webserver:v1 .
注:最后有一个“.”,别遗漏。
镜像生成完毕后运行docker images查看,见下图:
attachment.jpg

三、编写操作API
登录192.168.1.20服务器
# mkdir /home/test/docker-py
# cd /home/test/docker-py
1、安装docker-py
# wget https://github.com/docker/docker-py/archive/master.zip
# unzip master
# cd docker-py-master/
# python setup.py install
如正常导入模块(import docker)说明安装成功。
2、创建容器docker_create.py


    import docker  
      
    c = docker.Client(base_url='tcp://192.168.1.22:2375',version='1.14',timeout=10)  
    c.create_container(image="yorko/webserver:v1",stdin_open=True,tty=True,command="/usr/bin/supervisord -c /etc/supervisord.conf",volumes=['/data'],ports=[80,22],name="webserver11")  
    #通过create_container方法创建容器,指定"yorko/webserver:v1"镜像名称,使用supervisord接管进程服务,挂载主宿机/data作为数据卷,容器监听80与22端口,容器的名称为webserver11  
    print str(r)  


3、运行容器docker_start.py


    import docker  
      
    c = docker.Client(base_url='tcp://192.168.1.22:2375',version='1.14',timeout=10)  
    r=c.start(container='webserver11', binds={'/data':{'bind': '/data','ro': False}}, port_bindings={80:80,22:2022}, lxc_conf=None,  
            publish_all_ports=True, links=None, privileged=False,  
            dns=None, dns_search=None, volumes_from=None, network_mode=None,  
            restart_policy=None, cap_add=None, cap_drop=None)  
    #通过start方法启动容器,指定数据卷的挂载关系及权限,以及端口与主宿机的映射关系等  
    print str(r)  


4、运行
# python docker_create.py
# python docker_start.py
更多API参考https://github.com/docker/docker-py
5、在Docker主机观察结果,见下图:
attachment.jpg

三、校验服务
1、校验SSH服务
attachment.jpg

2、校验WEB服务
attachment.jpg

3、检查数据卷
attachment.jpg                
         


运维网声明 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-29347-1-1.html 上篇帖子: 构建一个高可用及自动发现的Docker基础架构 下篇帖子: docker容器端口IP规划及端口动态扩容 python
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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