Docker SDK for Python

本文详细介绍Docker Python SDK的使用方法,包括容器的启动、停止、日志查看及镜像管理。并通过一个实战案例,展示如何自动化清理本地Docker镜像,保持环境整洁。

一、概述

Docker引擎API的Python库。它允许您执行docker命令所做的任何操作,但可以在Python应用程序中运行容器、管理容器、管理群集等。

官方文档:

https://docker-py.readthedocs.io/en/stable/

 

安装模块

pip3 install docker

 

二、语法介绍

运行一个容器

import docker
client = docker.from_env()
r = client.containers.run("alpine", ["echo", "hello", "world"])
print(str(r, encoding='utf-8'))

 

端口映射

r = client.containers.run('mysql/mysql-server:5.7',ports={'3306/tcp': 3300}, auto_remove=True, name='shark_mysql')

{'3306/tcp': 3300} 将容器的 TCP 3306 端口映射到宿主机的 3300 端口
name 指定了容器的名称

 

在后台运行容器

import docker
client = docker.from_env()
container = client.containers.run("busybox", detach=True)
print(container.id)

 

停止所有正在运行的容

import docker
client = docker.from_env()
for container in client.containers.list():
  container.stop()

 

打印特定容器的日志

您还可以对单个容器执行操作。此示例打印给定其ID的容器的日志。您需要在运行代码之前修改代码以更改容器的硬编码ID以打印日志。

import docker
client = docker.from_env()
container = client.containers.get('f1064a8a4c82')
print(container.logs())

 

列出所有镜像

import docker
client = docker.from_env()
for image in client.images.list():
  print(image.id)

 

拉取镜像

import docker
client = docker.from_env()
image = client.images.pull("alpine")
print(image.id)

 

提交容器

import docker
client = docker.from_env()
container = client.containers.run("alpine", ["touch", "/helloworld"], detach=True)
container.wait()
image = container.commit("helloworld")
print(image.id)

 

三、项目实战

需求说明

线上服务器的应用服务都是通过docker跑的。上线时,通过jenkins来发布的。版本号以BUILD_NUMBER为准!比如:

app_user:1
app_user:2
app_user:3
app_user:4
app_user:5
app_user:6
...

那么问题就来了,服务器本地镜像越来越多,会导致磁盘空间急剧上涨。但是我只需要最近3个版本即可,用了做回滚操作。

之前的镜像可以删除掉。

 

完整代码

start.py

#!/usr/bin/env python3
# coding: utf-8
# 删除本地镜像,保留最近3个版本

import time
import docker

# 项目列表
project_list = ['app_user']


def write_log(content, colour='white', skip=False):
    """
    写入日志文件
    :param content: 写入内容
    :param colour: 颜色
    :param skip: 是否跳过打印时间
    :return:
    """
    # 颜色代码
    colour_dict = {
        'red': 31,  # 红色
        'green': 32,  # 绿色
        'yellow': 33,  # 黄色
        'blue': 34,  # 蓝色
        'purple_red': 35,  # 紫红色
        'bluish_blue': 36,  # 浅蓝色
        'white': 37,  # 白色
    }
    choice = colour_dict.get(colour)  # 选择颜色

    path = "output.log"  # 日志文件
    with open(path, mode='a+', encoding='utf-8') as f:
        if skip is False:  # 不跳过打印时间时
            content = time.strftime('%Y-%m-%d %H:%M:%S') + ' ' + content

        info = "\033[1;{};1m{}\033[0m".format(choice, content)
        print(info)
        f.write(content + "\n")


client = docker.from_env()
# 镜像列表
images_obj = client.images.list()


# 项目字典
project_dict = {}
# project_dict ={
#     'app_user':['app_user:1', 'app_user:2'],
# }
for i in images_obj:
    # print(i,type(i),i.attrs.get('RepoTags'),type(i.attrs.get('RepoTags')))
    for project in project_list:
        # print("RepoTags",i.attrs.get('RepoTags'))
        if project not in project_dict:
            project_dict[project] = []
        for image in i.attrs.get('RepoTags'):
            if project in image:
                project_dict[project].append(image)

# print("project_dict",project_dict)

for i in project_dict:
    # print("i",len(project_dict[i]))
    # 判断镜像列表是否小于等于3
    if len(project_dict[i]) > 3:
        # print(project_dict[i])
        # 镜像列表排序,默认升序(从小到大)
        project_dict[i].sort()
        # print(project_dict[i])
        # 删除最后3个元素
        for n in range(3):
            project_dict[i].pop()
        # print(project_dict[i])

        # 将剩下的镜像删除
        for image in project_dict[i]:
            # print("删除",image)
            try:
                result = client.images.remove(image)
                write_log("删除镜像: %s 成功"%image, "green")
            except Exception as e:
                print(e)
                write_log("删除镜像: %s 失败"%image, "red")
View Code

注意:修改project_list变量即可。

 

执行代码

python3 start.py

 

 

本文参考链接:

https://www.jianshu.com/p/c1bfc14d5c02

 

### Docker SDK for Python 使用指南 Docker SDK for Python 提供了一种通过编程方式与 Docker 守护程序交互的方法。这使得自动化容器管理变得简单而高效[^1]。 #### 获取并安装 Docker SDK for Python 为了开始使用 Docker SDK for Python,首先需要确保环境中已正确安装了Python 和 pip 工具。接着可以通过pip来安装此库: ```bash pip install docker ``` 上述命令会自动下载最新版本的 Docker SDK 并完成环境配置。 #### 初始化客户端连接 建立与本地或远程 Docker 主机之间的通信链路是必要的操作之一。通常情况下,默认设置即可满足大多数需求;但对于特定场景,则可能需指定其他参数如 base_url 来改变默认行为: ```python import docker client = docker.from_env() ``` 这段代码创建了一个新的 `DockerClient` 实例,并尝试从环境变量读取配置信息以初始化连接。 #### 基本操作示例 下面是一些常见的 API 调用例子,用于展示如何利用 Docker SDK 执行基本的任务,比如拉取镜像、运行容器等: - **获取所有正在运行中的容器列表** ```python containers = client.containers.list() ``` - **基于给定名称启动新容器实例** ```python container = client.containers.run('ubuntu', 'echo hello world', detach=True, name='my_container') ``` 这些只是入门级别的介绍,在实际应用中还有许多高级特性和选项可供探索。 对于更深入的学习资源和完整的API参考手册,请参阅[Docker SDK for Python 的官方文档](https://docker-py.readthedocs.io/en/stable/)。这份文档不仅涵盖了所有的公共接口定义,还提供了丰富的案例研究帮助开发者更好地理解和运用这个强大的工具集。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值