将 Docker Compose 文件转换为 Kubernetes 资源
什么是 Kompose?它是一个用于将所有 Compose 相关内容(即 Docker Compose)转换为容器编排器(Kubernetes 或 OpenShift)的转换工具。
您可以在 Kompose 网站 https://kompose.kubernetes.ac.cn 上找到更多信息。
开始之前
您需要有一个 Kubernetes 集群,并且 kubectl 命令行工具必须配置为与您的集群通信。建议您在至少有两个节点的集群上运行本教程,这些节点不充当控制平面主机。如果您还没有集群,您可以使用 minikube 创建一个集群,或者您可以使用以下 Kubernetes 游乐场之一。
要检查版本,请输入kubectl version
。安装 Kompose
我们有多种方法可以安装 Kompose。我们首选的方法是从最新的 GitHub 版本下载二进制文件。
Kompose 每三周发布一次,您可以在 GitHub 发布页面 上查看所有当前版本。
# Linux
curl -L https://github.com/kubernetes/kompose/releases/download/v1.34.0/kompose-linux-amd64 -o kompose
# macOS
curl -L https://github.com/kubernetes/kompose/releases/download/v1.34.0/kompose-darwin-amd64 -o kompose
# Windows
curl -L https://github.com/kubernetes/kompose/releases/download/v1.34.0/kompose-windows-amd64.exe -o kompose.exe
chmod +x kompose
sudo mv ./kompose /usr/local/bin/kompose
或者,您可以下载 tarball。
使用 go get
安装会从具有最新开发更改的主分支拉取。
go get -u github.com/kubernetes/kompose
Kompose 位于 EPEL CentOS 存储库中。如果您还没有安装和启用 EPEL 存储库,您可以通过运行 sudo yum install epel-release
来完成。
如果您在系统中启用了 EPEL,您可以像安装任何其他软件包一样安装 Kompose。
sudo yum -y install kompose
Kompose 位于 Fedora 24、25 和 26 存储库中。您可以像安装任何其他软件包一样安装它。
sudo dnf -y install kompose
在 macOS 上,您可以通过 Homebrew 安装最新版本
brew install kompose
使用 Kompose
我们将带您从 Docker Compose 迁移到 Kubernetes。您只需要一个现有的 docker-compose.yml
文件。
转到包含
docker-compose.yml
文件的目录。如果您没有,请使用此文件进行测试。services: redis-leader: container_name: redis-leader image: redis ports: - "6379" redis-replica: container_name: redis-replica image: redis ports: - "6379" command: redis-server --replicaof redis-leader 6379 --dir /tmp web: container_name: web image: quay.io/kompose/web ports: - "8080:8080" environment: - GET_HOSTS_FROM=dns labels: kompose.service.type: LoadBalancer
要将
docker-compose.yml
文件转换为可以使用kubectl
的文件,请运行kompose convert
,然后运行kubectl apply -f <output file>
。kompose convert
输出类似于
INFO Kubernetes file "redis-leader-service.yaml" created INFO Kubernetes file "redis-replica-service.yaml" created INFO Kubernetes file "web-tcp-service.yaml" created INFO Kubernetes file "redis-leader-deployment.yaml" created INFO Kubernetes file "redis-replica-deployment.yaml" created INFO Kubernetes file "web-deployment.yaml" created
kubectl apply -f web-tcp-service.yaml,redis-leader-service.yaml,redis-replica-service.yaml,web-deployment.yaml,redis-leader-deployment.yaml,redis-replica-deployment.yaml
输出类似于
deployment.apps/redis-leader created deployment.apps/redis-replica created deployment.apps/web created service/redis-leader created service/redis-replica created service/web-tcp created
您的部署正在 Kubernetes 中运行。
访问您的应用程序。
如果您已经在开发过程中使用
minikube
minikube service web-tcp
否则,让我们查找您的服务正在使用哪个 IP!
kubectl describe svc web-tcp
Name: web-tcp Namespace: default Labels: io.kompose.service=web-tcp Annotations: kompose.cmd: kompose convert kompose.service.type: LoadBalancer kompose.version: 1.33.0 (3ce457399) Selector: io.kompose.service=web Type: LoadBalancer IP Family Policy: SingleStack IP Families: IPv4 IP: 10.102.30.3 IPs: 10.102.30.3 Port: 8080 8080/TCP TargetPort: 8080/TCP NodePort: 8080 31624/TCP Endpoints: 10.244.0.5:8080 Session Affinity: None External Traffic Policy: Cluster Events: <none>
如果您使用的是云提供商,您的 IP 将列在
LoadBalancer Ingress
旁边。curl http://192.0.2.89
清理。
完成对示例应用程序部署的测试后,只需在您的 shell 中运行以下命令以删除使用的资源。
kubectl delete -f web-tcp-service.yaml,redis-leader-service.yaml,redis-replica-service.yaml,web-deployment.yaml,redis-leader-deployment.yaml,redis-replica-deployment.yaml
用户指南
Kompose 支持两个提供商:OpenShift 和 Kubernetes。您可以使用全局选项 --provider
选择目标提供商。如果没有指定提供商,则默认情况下设置为 Kubernetes。
kompose convert
Kompose 支持将 V1、V2 和 V3 Docker Compose 文件转换为 Kubernetes 和 OpenShift 对象。
Kubernetes kompose convert
示例
kompose --file docker-voting.yml convert
WARN Unsupported key networks - ignoring
WARN Unsupported key build - ignoring
INFO Kubernetes file "worker-svc.yaml" created
INFO Kubernetes file "db-svc.yaml" created
INFO Kubernetes file "redis-svc.yaml" created
INFO Kubernetes file "result-svc.yaml" created
INFO Kubernetes file "vote-svc.yaml" created
INFO Kubernetes file "redis-deployment.yaml" created
INFO Kubernetes file "result-deployment.yaml" created
INFO Kubernetes file "vote-deployment.yaml" created
INFO Kubernetes file "worker-deployment.yaml" created
INFO Kubernetes file "db-deployment.yaml" created
ls
db-deployment.yaml docker-compose.yml docker-gitlab.yml redis-deployment.yaml result-deployment.yaml vote-deployment.yaml worker-deployment.yaml
db-svc.yaml docker-voting.yml redis-svc.yaml result-svc.yaml vote-svc.yaml worker-svc.yaml
您也可以同时提供多个 docker-compose 文件
kompose -f docker-compose.yml -f docker-guestbook.yml convert
INFO Kubernetes file "frontend-service.yaml" created
INFO Kubernetes file "mlbparks-service.yaml" created
INFO Kubernetes file "mongodb-service.yaml" created
INFO Kubernetes file "redis-master-service.yaml" created
INFO Kubernetes file "redis-slave-service.yaml" created
INFO Kubernetes file "frontend-deployment.yaml" created
INFO Kubernetes file "mlbparks-deployment.yaml" created
INFO Kubernetes file "mongodb-deployment.yaml" created
INFO Kubernetes file "mongodb-claim0-persistentvolumeclaim.yaml" created
INFO Kubernetes file "redis-master-deployment.yaml" created
INFO Kubernetes file "redis-slave-deployment.yaml" created
ls
mlbparks-deployment.yaml mongodb-service.yaml redis-slave-service.jsonmlbparks-service.yaml
frontend-deployment.yaml mongodb-claim0-persistentvolumeclaim.yaml redis-master-service.yaml
frontend-service.yaml mongodb-deployment.yaml redis-slave-deployment.yaml
redis-master-deployment.yaml
当提供多个 docker-compose 文件时,配置会合并。任何常见的配置都将被后续文件覆盖。
OpenShift kompose convert
示例
kompose --provider openshift --file docker-voting.yml convert
WARN [worker] Service cannot be created because of missing port.
INFO OpenShift file "vote-service.yaml" created
INFO OpenShift file "db-service.yaml" created
INFO OpenShift file "redis-service.yaml" created
INFO OpenShift file "result-service.yaml" created
INFO OpenShift file "vote-deploymentconfig.yaml" created
INFO OpenShift file "vote-imagestream.yaml" created
INFO OpenShift file "worker-deploymentconfig.yaml" created
INFO OpenShift file "worker-imagestream.yaml" created
INFO OpenShift file "db-deploymentconfig.yaml" created
INFO OpenShift file "db-imagestream.yaml" created
INFO OpenShift file "redis-deploymentconfig.yaml" created
INFO OpenShift file "redis-imagestream.yaml" created
INFO OpenShift file "result-deploymentconfig.yaml" created
INFO OpenShift file "result-imagestream.yaml" created
它还支持为服务中的构建指令创建 buildconfig。默认情况下,它使用当前 git 分支的远程存储库作为源存储库,并将当前分支用作构建的源分支。您可以使用 --build-repo
和 --build-branch
选项分别指定不同的源存储库和分支。
kompose --provider openshift --file buildconfig/docker-compose.yml convert
WARN [foo] Service cannot be created because of missing port.
INFO OpenShift Buildconfig using git@github.com:rtnpro/kompose.git::master as source.
INFO OpenShift file "foo-deploymentconfig.yaml" created
INFO OpenShift file "foo-imagestream.yaml" created
INFO OpenShift file "foo-buildconfig.yaml" created
注意
如果您正在使用oc create -f
手动推送 OpenShift 工件,则需要确保在推送 buildconfig 工件之前推送 imagestream 工件,以解决 OpenShift 问题:https://github.com/openshift/origin/issues/4518。备用转换
默认的 kompose
转换将以 yaml 格式生成 Kubernetes 部署 和 服务。您可以选择使用 -j
生成 json。此外,您还可以选择生成 副本控制器 对象、守护进程集 或 Helm 图表。
kompose convert -j
INFO Kubernetes file "redis-svc.json" created
INFO Kubernetes file "web-svc.json" created
INFO Kubernetes file "redis-deployment.json" created
INFO Kubernetes file "web-deployment.json" created
*-deployment.json
文件包含部署对象。
kompose convert --replication-controller
INFO Kubernetes file "redis-svc.yaml" created
INFO Kubernetes file "web-svc.yaml" created
INFO Kubernetes file "redis-replicationcontroller.yaml" created
INFO Kubernetes file "web-replicationcontroller.yaml" created
*-replicationcontroller.yaml
文件包含副本控制器对象。如果您想指定副本数量(默认值为 1),请使用 --replicas
标志:kompose convert --replication-controller --replicas 3
。
kompose convert --daemon-set
INFO Kubernetes file "redis-svc.yaml" created
INFO Kubernetes file "web-svc.yaml" created
INFO Kubernetes file "redis-daemonset.yaml" created
INFO Kubernetes file "web-daemonset.yaml" created
*-daemonset.yaml
文件包含守护进程集对象。
如果您想生成一个图表以与 Helm 一起使用,请运行
kompose convert -c
INFO Kubernetes file "web-svc.yaml" created
INFO Kubernetes file "redis-svc.yaml" created
INFO Kubernetes file "web-deployment.yaml" created
INFO Kubernetes file "redis-deployment.yaml" created
chart created in "./docker-compose/"
tree docker-compose/
docker-compose
├── Chart.yaml
├── README.md
└── templates
├── redis-deployment.yaml
├── redis-svc.yaml
├── web-deployment.yaml
└── web-svc.yaml
图表结构旨在为构建 Helm 图表提供一个骨架。
标签
kompose
支持 docker-compose.yml
文件中的 Kompose 特定标签,以便明确定义服务在转换时的行为。
kompose.service.type
定义要创建的服务类型。例如
version: "2" services: nginx: image: nginx dockerfile: foobar build: ./foobar cap_add: - ALL container_name: foobar labels: kompose.service.type: nodeport
kompose.service.expose
定义服务是否需要从集群外部访问。如果该值设置为 "true",则提供商会自动设置端点,对于任何其他值,该值将设置为主机名。如果在服务中定义了多个端口,则选择第一个端口作为暴露的端口。- 对于 Kubernetes 提供商,将创建 ingress 资源,并假定已经配置了 ingress 控制器。
- 对于 OpenShift 提供商,将创建路由。
例如
version: "2" services: web: image: tuna/docker-counter23 ports: - "5000:5000" links: - redis labels: kompose.service.expose: "counter.example.com" redis: image: redis:3.0 ports: - "6379"
当前支持的选项为
键 | 值 |
---|---|
kompose.service.type | nodeport / clusterip / loadbalancer |
kompose.service.expose | true / hostname |
注意
kompose.service.type
标签应与 ports
一起定义,否则 kompose
会失败。重启
如果您想创建没有控制器的普通 pod,您可以使用 docker-compose 的 restart
结构来定义。请查看下表以了解 restart
值的影响。
docker-compose restart | 创建的对象 | Pod restartPolicy |
---|---|---|
"" | 控制器对象 | Always |
always | 控制器对象 | Always |
on-failure | Pod | OnFailure |
no | Pod | Never |
注意
控制器对象可以是deployment
或 replicationcontroller
。例如,pival
服务将在此处变为 pod 下降。此容器计算了 pi
的值。
version: '2'
services:
pival:
image: perl
command: ["perl", "-Mbignum=bpi", "-wle", "print bpi(2000)"]
restart: "on-failure"
关于部署配置的警告
如果 Docker Compose 文件为服务指定了卷,则部署(Kubernetes)或 DeploymentConfig(OpenShift)策略将更改为 "Recreate",而不是 "RollingUpdate"(默认值)。这样做是为了避免多个服务实例同时访问卷。
如果 Docker Compose 文件中的服务名称包含 _
(例如,web_service
),则它将被替换为 -
,并且服务名称将相应地重命名(例如,web-service
)。Kompose 这样做是因为 "Kubernetes" 不允许在对象名称中使用 _
。
请注意,更改服务名称可能会破坏某些 docker-compose
文件。
Docker Compose 版本
Kompose 支持 Docker Compose 版本:1、2 和 3。由于其实验性质,我们在版本 2.1 和 3.2 上的支持有限。
我们 转换文档 中列出了所有三个版本之间兼容性的完整列表,包括所有不兼容的 Docker Compose 键的列表。