专栏首页刘天斯的专栏Docker 远程 python API 操作容器一例
原创

Docker 远程 python API 操作容器一例

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环境部署

安装EPEL镜像源

yum install http://ftp.riken.jp/Linux/fedora/epel/6/x86_64/epel-release-6-8.noarch.rpm

2.1.关闭selnux

修改配置文件: /etc/selinux/config

2.2.安全起见,先升级系统至最新版本;

需要Cent6或更高的版本,RHEL的内核版本是 2.6.32-431或者更高,为了让docker工作需要特定的内核补丁。yum update -y

重启系统:init 6

2.3.安装、启动服务

注意:如果安装了(不相关)的docker包,它将与docker-io冲突。在安装docker-io之前,请先卸载docker

2.4.安装

yum -y install docker-io

2.5.启动服务

service docker start

如果我们需要开机自启动,如下:

2.6.添加随机启动

chkconfig docker on

2.7.查看服务运行状态

service docker status

docker (pid 1398) is running...

2.8. 要获取最新的centos镜像

docker pull centos:latest

2.9.命令行查看镜像:

docker images centos

REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE

centos latest b157b77b1a65 2 weeks ago 243.7 MB

通过以上步骤安装部署,测试,一个docker基础环境已经运行起来了。

3、修改自启动服务文件,支持远程TCP接口与本地SOCK连接;

# vi /etc/init.d/docker

view plainprint?
$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

view plainprint?
# 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

view plainprint?
[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查看,见下图:

三、编写操作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

view plainprint?
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

view plainprint?
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主机观察结果,见下图:

四、校验服务

1、校验SSH服务

2、校验WEB服务

3、检查数据卷

原创声明,本文系作者授权云+社区发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 构建一个高可用及自动发现的 Docker 基础架构

    Docker的发展前景一片大好。但在企业当中,如何选择适合自己的Docker构建方案?下面详细介绍如何使用 Haproxy + etcd + confd 构建一...

    刘天斯
  • 基于 kubernetes 构建 Docker 集群管理详解

    Kubernetes 是Google开源的容器集群管理系统,基于Docker构建一个容器的调度服务,提供资源调度、均衡容灾、服务注册、动态扩缩容等功能套件,目前...

    刘天斯
  • Docker Remote API简单使用 原

    默认情况下,Docker daemon监听unix://var/run/docker.sock,并且客户端必须有root权限用来与daemon交互。

    donghui
  • Devops step by step

    接着上次分享的devops历程[Followme Devops实践之路], 大家希望能够出一个step by step手册, 那今天我就来和手把手来一起搭建这么...

    张善友
  • 安装docker后修改docker文件目录

    docker会下载容器,运行会挂载磁盘,所以我们需要把docker装在大容量的分区。

    Ryan-Miao
  • docker运行容器远程挂载卷

    用户1418372
  • 项目部署(二)

    What would life be if we had no courage to attempt anything?

    小闫同学啊
  • Linux Ceonto7安装Docker-CE并使用

    较旧的 Docker 版本称为 docker 或 docker-engine 。如果已安装这些程序,请卸载它们以及相关的依赖项。

    夹胡碰
  • 6.Docker使用辅助工具汇总

    more information: https://docs.docker.com/engine/security/security/#docker-daemo...

    WeiyiGeek
  • n1.Docker安装运行所遇异常解决

    描述:默认情况下Docker的存放位置为 /var/lib/docker , 具体的位置可以通过sudo docker info | grep "Docker ...

    WeiyiGeek

扫码关注云+社区

领取腾讯云代金券