qt通过http调用创建docker容器

首先需要在 linux 服务器部署 docker 服务,此类文章网上很多,可以参考 如何在 Ubuntu 20.04 上安装和使用 Docker 或者 ubuntu安装docker,安装完成后如果还想通过 http 正常调用,还需在 docker.service 文件中配置 -H tcp://0.0.0.0:2375

bash 复制代码
root@ros:/lib/systemd/system# pwd
/lib/systemd/system
root@ros:/lib/systemd/system# cat docker.service | grep ExecStart
ExecStart=/usr/bin/dockerd -H fd:// -H tcp://0.0.0.0:2375 --containerd=/run/containerd/containerd.sock

再重启 docker 后,可通过 netstat命令查看服务是否正常开启。

bash 复制代码
root@ros:~# netstat -ntlp | grep docker
tcp6       0      0 :::2375          :::*             LISTEN      3283/dockerd

http 可调用的 api 可参考文档 Docker Engine API,本文主要实现 create container api 的调用。在调用之前,得确保服务器已经有载入镜像,可通过 docker images 指令查看:

bash 复制代码
root@ros:~# docker images 
REPOSITORY        TAG       IMAGE ID       CREATED      SIZE
test_image        tag1     20259e2caff6   2 days ago   5.17GB

这样就可以在参数中指定镜像创建容器:

cpp 复制代码
QJsonObject container_param;
container_param["Image"] = "test_image:tag1";

如果想设置容器的环境变量,可以给 env 传参:

cpp 复制代码
QJsonArray env;
QString env_id = QString("identifier=%1").arg(id);    // 设置业务上的唯一标识
QString env_zone = QString("TZ=Asia/Shanghai");    // 设置时区
env.append(env_id);
env.append(env_zone);
container_param["Env"] = env;

如果希望容器启动时执行特定脚本,可通过 cmd 参数:

cpp 复制代码
QJsonArray cmd;
cmd.append("/test.sh");
container_param["Cmd"] = cmd;

如果希望容器和宿主机做路径映射,可利用 hostconfig 下的 binds 参数:

cpp 复制代码
QJsonObject binds;
QJsonArray path;
QString task_path = QString("/usr/local/src:/home/lucas/src");
path.append(task_path);
QString log_path = QString("/opt/test/log:/home/lucas/log");
path.append(log_path);
binds["Binds"] = path;
container_param["HostConfig"] = binds;

这样,在容器内部的 /home/lucas/log 目录下的任何改动,宿主机的 /opt/test/log 目录也会同步更新。即使容器已销毁,日志仍然可在宿主机查看。

还有些标准输入输出、终端开启的相关参数可根据业务需要适当配置:

cpp 复制代码
container_param["AttachStdin"] = false;
container_param["AttachStdout"] = true;
container_param["AttachStderr"] = true;
container_param["Tty"] = true;
container_param["OpenStdin"] = true;

待需要参数都已赋值,最后可调用 create container api 开始创建容器:

cpp 复制代码
QJsonDocument doc(container_param);
QByteArray post_data = doc.toJson();

// url: http://127.0.0.1:2375/containers/create
QNetworkReply *reply = httpPost(url, post_data);

其中 httpPost() 方法可封装如下:

cpp 复制代码
QNetworkReply *HttpHelper::httpPost(const QString url, const QString post_data)
{
    QNetworkRequest request;
    request.setHeader(QNetworkRequest::ContentTypeHeader, QVariant("application/json"));
    request.setUrl(QUrl::fromUserInput(url));

    QNetworkReply *network_reply = m_networkMgr.post(request, post_data.toUtf8());
    QEventLoop event_loop;
    QObject::connect(network_reply, SIGNAL(finished()), &event_loop, SLOT(quit()));
    event_loop.exec();

    return network_reply;
}

如果正常,接口最终会返回一个 json 串,解析后可拿到 container id

bash 复制代码
{"Id":"0354238a43a38abfa2bf906a909ecedd411778c82fa017bf1b833b55ed2f3b50","Warnings":[]}

之后就可以调用 start container api 来启动容器:

bash 复制代码
http://127.0.0.1:2375/containers/0354238a43a3/start

这点也可通过在宿主机执行 docker ps 指令来进行验证。以上,欢迎交流~

相关推荐
IT策士10 分钟前
第 20 篇 搭建 Kubernetes 实验环境:Minikube 与 kubectl
云原生·容器·kubernetes
秋田君35 分钟前
Qt 5.12.8 下载与安装教程(附网盘资源)
开发语言·qt
ai产品老杨2 小时前
基于 Docker 容器化与异构计算的智能安防架构:解耦 GB28181/RTSP 协议与多芯片适配,源码交付如何助力集成商节省 95% 开发成本?
docker·容器·架构
Plastic garden2 小时前
Docker(2)网络模式
运维·docker·容器
郝学胜-神的一滴2 小时前
Qt 高级开发 019:从零定制登录窗口按钮、Logo 样式与交互悬浮效果
开发语言·c++·qt·程序人生·交互·用户界面
YY&DS3 小时前
Qt Designer 自定义控件已提升后,如何修改提升类
开发语言·qt
MR.欻3 小时前
ZLMediaKit 源码分析(七):HTTP-FLV 低延迟直播流分析
网络·网络协议·http
IT策士3 小时前
第 24 篇 k8s之健康检查:探针机制详解
云原生·容器·kubernetes
IT策士4 小时前
第 21 篇 k8s之Pod:最小调度单元与 YAML 详解
云原生·容器·kubernetes