详解在Python和IPython中使用Docker


Posted in Python onApril 28, 2015

现在Docker是地球上最炙手可热的项目之一,就意味着人民实际上不仅仅是因为这个才喜欢它。

话虽如此,我非常喜欢使用容器,服务发现以及所有被创造出的新趣的点子和领域来切换工作作为范例。

这个文章中我会简要介绍使用python中的docker-py模块来操作Docker 容器,这里会使用我喜爱的编程工具IPython。

安装docker-py

首先需要docker-py。注意这里的案例中我将会使用Ubuntu Trusty 14.04版本。

$ pip install docker-py

IPyhton

我真的很喜欢用IPython来探索Python。 它像是一共高级的python Shell,但是可以做的更多。

$ sudo apt-get install ipython

SNIP!

$ ipython

Python 2.7.6 (default, Mar 22 2014, 22:59:56)

Type "copyright", "credits" or "license" for more information.
IPython 1.2.1 -- An enhanced Interactive Python.

?         -> Introduction and overview of IPython's features.

%quickref -> Quick reference.

help      -> Python's own help system.

object?   -> Details about 'object', use 'object??' for extra details.
In [1]:

安装 docker

如果没有安装Docker,那首先安装docker

$ sudo apt-get install docker.io

然后把 docker.io 起个别名 docker
$ alias docker='docker.io'

$ docker version

Client version: 0.9.1

Go version (client): go1.2.1

Git commit (client): 3600720

Server version: 0.9.1

Git commit (server): 3600720

Go version (server): go1.2.1

Last stable version: 0.11.1, please update docker

Docker现在应该有个socket开启,我们可以用来连接。
$ ls /var/run/docker.sock

/var/run/docker.sock

Pull 镜像

让我们下载 busybox镜像

$ docker pull busybox

Pulling repository busybox

71e18d715071: Download complete

98b9fdab1cb6: Download complete

1277aa3f93b3: Download complete

6e0a2595b580: Download complete

511136ea3c5a: Download complete

b6c0d171b362: Download complete

8464f9ac64e8: Download complete

9798716626f6: Download complete

fc1343e2fca0: Download complete

f3c823ac7aa6: Download complete

现在我们准备使用 docker-py 了。

使用 docker-py

现在我们有了docker-py , IPython, Docker 和 busybox 镜像,我们就能建立一些容器。

如果你不是很熟悉IPython,可以参照这个教程学习(http://ipython.org/ipython-doc/stable/interactive/tutorial.html),
IPython是十分强大的。

首先启动一个IPython ,导入docker模块。

$ ipython

Python 2.7.6 (default, Mar 22 2014, 22:59:56)

Type "copyright", "credits" or "license" for more information.
IPython 1.2.1 -- An enhanced Interactive Python.

?         -> Introduction and overview of IPython's features.

%quickref -> Quick reference.

help      -> Python's own help system.

object?   -> Details about 'object', use 'object??' for extra details.
In [1]: import docker

然后我们建立一个连接到Docker
In [2]: c = docker.Client(base_url='unix://var/run/docker.sock',

   ...:                   version='1.9',

   ...:                   timeout=10)

现在我们已经连接到Docker。

IPython使用tab键来补全的。 如果 输入 “c.” 然后按下tab键,IPython会显示Docker连接对象所有的方法和属性。

In [3]: c.

c.adapters                      c.headers                       c.pull

c.attach                        c.history                       c.push

c.attach_socket                 c.hooks                         c.put

c.auth                          c.images                        c.remove_container

c.base_url                      c.import_image                  c.remove_image

c.build                         c.info                          c.request

c.cert                          c.insert                        c.resolve_redirects

c.close                         c.inspect_container             c.restart

c.commit                        c.inspect_image                 c.search

c.containers                    c.kill                          c.send

c.cookies                       c.login                         c.start

c.copy                          c.logs                          c.stop

c.create_container              c.max_redirects                 c.stream

c.create_container_from_config  c.mount                         c.tag

c.delete                        c.options                       c.top

c.diff                          c.params                        c.trust_env

c.events                        c.patch                         c.verify

c.export                        c.port                          c.version

c.get                           c.post                          c.wait

c.get_adapter                   c.prepare_request

c.head                          c.proxies

让我们来看下c.images 我输入一个 “?”在c.之后,ipython 会提供这个对象的详细信息。
In [5]: c.images?

Type:       instancemethod

String Form:<bound method Client.images of <docker.client.Client object at 0x7f3acc731790>>

File:       /usr/local/lib/python2.7/dist-packages/docker/client.py

Definition: c.images(self, name=None, quiet=False, all=False, viz=False)

Docstring:  <no docstring>

获取busybox 镜像。
In [6]: c.images(name="busybox")

Out[6]:

[{u'Created': 1401402591,

  u'Id': u'71e18d715071d6ba89a041d1e696b3d201e82a7525fbd35e2763b8e066a3e4de',

  u'ParentId': u'8464f9ac64e87252a91be3fbb99cee20cda3188de5365bec7975881f389be343',

  u'RepoTags': [u'busybox:buildroot-2013.08.1'],

  u'Size': 0,

  u'VirtualSize': 2489301},

 {u'Created': 1401402590,

  u'Id': u'1277aa3f93b3da774690bc4f0d8bf257ff372e23310b4a5d3803c180c0d64cd5',

  u'ParentId': u'f3c823ac7aa6ef78d83f19167d5e2592d2c7f208058bc70bf5629d4bb4ab996c',

  u'RepoTags': [u'busybox:ubuntu-14.04'],

  u'Size': 0,

  u'VirtualSize': 5609404},

 {u'Created': 1401402589,

  u'Id': u'6e0a2595b5807b4f8c109f3c6c5c3d59c9873a5650b51a4480b61428427ab5d8',

  u'ParentId': u'fc1343e2fca04a455f803ba66d1865739e0243aca6c9d5fd55f4f73f1e28456e',

  u'RepoTags': [u'busybox:ubuntu-12.04'],

  u'Size': 0,

  u'VirtualSize': 5454693},

 {u'Created': 1401402587,

  u'Id': u'98b9fdab1cb6e25411eea5c44241561326c336d3e0efae86e0239a1fe56fbfd4',

  u'ParentId': u'9798716626f6ae4e6b7f28451c0a1a603dc534fe5d9dd3900150114f89386216',

  u'RepoTags': [u'busybox:buildroot-2014.02', u'busybox:latest'],

  u'Size': 0,

  u'VirtualSize': 2433303}]

建立一个容器。 注意我添加一个可以将要运行的命令,这里用的是”env”命令。
In [8]: c.create_container(image="busybox", command="env")

Out[8]:

{u'Id': u'584459a09e6d4180757cb5c10ac354ca46a32bf8e122fa3fb71566108f330c87',

 u'Warnings': None}

使用ID来启动这个容器
In [9]: c.start(container="584459a09e6d4180757cb5c10ac354ca46a32bf8e122fa3fb71566108f330c87")

我们可以检查日志,应该可以看到当容器创建的时候 ,我们配置的”env”命令的输出。
In [11]: c.logs(container="584459a09e6d4180757cb5c10ac354ca46a32bf8e122fa3fb71566108f330c87")

Out[11]: 'HOME=/\nPATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin\nHOSTNAME=584459a09e6d\n'

如果使用docker命令行,使用同样的命令行选项运行一个容器,应该可以看到类似的信息。
$ docker run busybox env

HOME=/

PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin

HOSTNAME=ce3ad38a52bf

据我所知,docker-py没有运行选项,我们只能创建一个容器然后启动它。

以下是一个案例:

In [17]: busybox = c.create_container(image="busybox", command="echo hi")
In [18]: busybox?

Type:       dict

String Form:{u'Id': u'34ede853ee0e95887ea333523d559efae7dcbe6ae7147aa971c544133a72e254', u'Warnings': None}

Length:     2

Docstring:

dict() -> new empty dictionary

dict(mapping) -> new dictionary initialized from a mapping object's

    (key, value) pairs

dict(iterable) -> new dictionary initialized as if via:

    d = {}

    for k, v in iterable:

        d[k] = v

dict(**kwargs) -> new dictionary initialized with the name=value pairs

    in the keyword argument list.  For example:  dict(one=1, two=2)
In [19]: c.start(busybox.get("Id"))
In [20]: c.logs(busybox.get("Id"))

Out[20]: 'hi\n'

如果你还没有使用过busybox镜像,我建议你使用下。我也建议debain下的jessie镜像,它只有120MB,比Ubuntu镜像要小。

总结

Docker是一个吸引人的新系统,可以用来建立有趣的新技术应用,特别是云服务相关的。使用IPython我们探索了怎么使用
docker-py模块来创建docker 容器。 现在使用python,我们可以结合docker和容易 创造出很多新的点子。

Python 相关文章推荐
Python的Asyncore异步Socket模块及实现端口转发的例子
Jun 14 Python
Python基于opencv的图像压缩算法实例分析
May 03 Python
详解django中使用定时任务的方法
Sep 27 Python
python list格式数据excel导出方法
Oct 31 Python
Python正则匹配判断手机号是否合法的方法
Dec 09 Python
python实现微信机器人: 登录微信、消息接收、自动回复功能
Apr 29 Python
分析运行中的 Python 进程详细解析
Jun 22 Python
详解利用OpenCV提取图像中的矩形区域(PPT屏幕等)
Jul 01 Python
python sqlite的Row对象操作示例
Sep 11 Python
Python线程指南分享
Nov 19 Python
使用Python构造hive insert语句说明
Jun 06 Python
python Matplotlib数据可视化(1):简单入门
Sep 30 Python
在Python程序中进行文件读取和写入操作的教程
Apr 28 #Python
介绍Python中的文档测试模块
Apr 28 #Python
Django中几种重定向方法
Apr 28 #Python
详解Python的单元测试
Apr 28 #Python
Python xlrd读取excel日期类型的2种方法
Apr 28 #Python
Python发送email的3种方法
Apr 28 #Python
Python中使用partial改变方法默认参数实例
Apr 28 #Python
You might like
在windows iis5下安装php4.0+mysql之我见
2006/10/09 PHP
Zend Framework实现留言本分页功能(附demo源码下载)
2016/03/22 PHP
PHP类的特性实例分析
2016/09/28 PHP
PHP实现的AES加密、解密封装类与用法示例
2018/08/02 PHP
JQuery autocomplete 使用手册
2010/04/01 Javascript
关于火狐(firefox)及ie下event获取的两种方法
2012/12/27 Javascript
JS:window.onload的使用介绍
2013/11/13 Javascript
javascript将相对路径转绝对路径示例
2014/03/14 Javascript
js网页右下角提示框实例
2014/10/14 Javascript
jQuery中bind()方法用法实例
2015/01/19 Javascript
jQuery插件formValidator实现表单验证
2016/05/23 Javascript
如何学JavaScript?前辈的经验之谈
2016/12/28 Javascript
JS判断一个数是否是水仙花数
2017/06/11 Javascript
vue组件传递对象中实现单向绑定的示例
2018/02/28 Javascript
浅析node.js的模块加载机制
2018/05/25 Javascript
vue生成token并保存到本地存储中
2018/07/17 Javascript
iView-admin 动态路由问题的解决方法
2018/10/03 Javascript
JavaScript代码调试方法实例小结
2019/01/05 Javascript
js中调用微信的扫描二维码功能的实现代码
2020/04/11 Javascript
javascript前端实现多视频上传
2020/12/13 Javascript
[04:48]DOTA2上海特锦赛小组赛第三日 TOP10精彩集锦
2016/02/28 DOTA
matplotlib简介,安装和简单实例代码
2017/12/26 Python
Python之ReportLab绘制条形码和二维码的实例
2018/01/15 Python
scrapy spider的几种爬取方式实例代码
2018/01/25 Python
Python cookbook(数据结构与算法)将序列分解为单独变量的方法
2018/02/13 Python
jupyter notebook引用from pyecharts.charts import Bar运行报错
2020/04/23 Python
基于numpy中数组元素的切片复制方法
2018/11/15 Python
Python绘图实现台风路径可视化代码实例
2020/10/23 Python
Aveda美国官网:天然护发产品、洗发水、护发素和沙龙
2016/12/09 全球购物
联想加拿大官方网站:Lenovo Canada
2018/04/05 全球购物
Wallis官网:英国女装零售商
2020/01/21 全球购物
车祸赔偿收入证明
2014/01/09 职场文书
九九重阳节标语
2014/10/07 职场文书
2014年纪检监察工作总结
2014/11/11 职场文书
2015年暑期社会实践总结
2015/07/13 职场文书
oracle数据库去除重复数据
2022/05/20 Oracle