2017-01-05 13:57:27 +00:00
---
2018-05-21 15:55:51 +00:00
reviewers:
2017-01-05 13:57:27 +00:00
- cdrage
2017-06-08 18:48:28 +00:00
title: Translate a Docker Compose File to Kubernetes Resources
2018-05-20 04:43:52 +00:00
weight: 170
2017-01-05 13:57:27 +00:00
---
2018-05-05 16:00:51 +00:00
{{< toc > }}
2017-01-05 13:57:27 +00:00
2017-09-15 00:14:28 +00:00
# Kubernetes + Compose = Kompose
2017-03-29 02:49:43 +00:00
2017-09-15 00:14:28 +00:00
What's Kompose? It's a conversion tool for all things compose (namely Docker Compose) to container orchestrators (Kubernetes or OpenShift).
2017-04-20 17:45:00 +00:00
2018-03-20 21:40:01 +00:00
More information can be found on the Kompose website at [http://kompose.io ](http://kompose.io ).
2017-03-29 02:49:43 +00:00
2017-09-15 00:14:28 +00:00
In three simple steps, we'll take you from Docker Compose to Kubernetes.
2017-03-29 02:49:43 +00:00
2017-09-15 00:14:28 +00:00
__1. Take a sample docker-compose.yaml file__
2017-03-29 02:49:43 +00:00
2017-09-15 00:14:28 +00:00
```yaml
version: "2"
services:
redis-master:
2017-12-22 17:55:16 +00:00
image: k8s.gcr.io/redis:e2e
2017-09-15 00:14:28 +00:00
ports:
- "6379"
redis-slave:
image: gcr.io/google_samples/gb-redisslave:v1
ports:
- "6379"
environment:
- GET_HOSTS_FROM=dns
frontend:
image: gcr.io/google-samples/gb-frontend:v4
ports:
- "80:80"
environment:
- GET_HOSTS_FROM=dns
labels:
kompose.service.type: LoadBalancer
2017-03-29 02:49:43 +00:00
```
2017-09-15 00:14:28 +00:00
__2. Run `kompose up` in the same directory__
2017-03-29 02:49:43 +00:00
2017-09-15 00:14:28 +00:00
```bash
$ kompose up
We are going to create Kubernetes Deployments, Services and PersistentVolumeClaims for your Dockerized application.
If you need different kind of resources, use the 'kompose convert' and 'kubectl create -f' commands instead.
2017-03-29 02:49:43 +00:00
2017-09-15 00:14:28 +00:00
INFO Successfully created Service: redis
INFO Successfully created Service: web
INFO Successfully created Deployment: redis
INFO Successfully created Deployment: web
2017-04-20 17:45:00 +00:00
2017-09-15 00:14:28 +00:00
Your application has been deployed to Kubernetes. You can run 'kubectl get deployment,svc,pods,pvc' for details.
```
__Alternatively, you can run `kompose convert` and deploy with `kubectl` __
2017-04-20 17:45:00 +00:00
2017-09-15 00:14:28 +00:00
__2.1. Run `kompose convert` in the same directory__
```bash
$ kompose convert
INFO Kubernetes file "frontend-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 "redis-master-deployment.yaml" created
INFO Kubernetes file "redis-slave-deployment.yaml" created
```
__2.2. And start it on Kubernetes!__
```bash
$ kubectl create -f frontend-service.yaml,redis-master-service.yaml,redis-slave-service.yaml,frontend-deployment.yaml,redis-master-deployment.yaml,redis-slave-deployment.yaml
service "frontend" created
service "redis-master" created
service "redis-slave" created
deployment "frontend" created
deployment "redis-master" created
deployment "redis-slave" created
```
__3. View the newly deployed service__
Now that your service has been deployed, let's access it.
If you're already using `minikube` for your development process:
```bash
$ minikube service frontend
```
Otherwise, let's look up what IP your service is using!
2017-03-29 02:49:43 +00:00
```sh
2017-09-15 00:14:28 +00:00
$ kubectl describe svc frontend
Name: frontend
Namespace: default
Labels: service=frontend
Selector: service=frontend
Type: LoadBalancer
IP: 10.0.0.183
LoadBalancer Ingress: 123.45.67.89
Port: 80 80/TCP
NodePort: 80 31144/TCP
Endpoints: 172.17.0.4:80
Session Affinity: None
No events.
2017-04-20 17:45:00 +00:00
2017-09-15 00:14:28 +00:00
```
2017-04-20 17:45:00 +00:00
2017-09-15 00:14:28 +00:00
If you're using a cloud provider, your IP will be listed next to `LoadBalancer Ingress` .
```sh
$ curl http://123.45.67.89
2017-03-29 02:49:43 +00:00
```
2017-09-15 00:14:28 +00:00
# Installation
2017-12-26 09:40:05 +00:00
We have multiple ways to install Kompose. Our preferred method is downloading the binary from the latest GitHub release.
2017-09-15 00:14:28 +00:00
#### GitHub release
Kompose is released via GitHub on a three-week cycle, you can see all current releases on the [GitHub release page ](https://github.com/kubernetes/kompose/releases ).
2017-01-05 13:57:27 +00:00
2017-04-20 17:45:00 +00:00
```sh
2017-09-15 00:14:28 +00:00
# Linux
curl -L https://github.com/kubernetes/kompose/releases/download/v1.1.0/kompose-linux-amd64 -o kompose
# macOS
curl -L https://github.com/kubernetes/kompose/releases/download/v1.1.0/kompose-darwin-amd64 -o kompose
# Windows
curl -L https://github.com/kubernetes/kompose/releases/download/v1.1.0/kompose-windows-amd64.exe -o kompose.exe
2017-04-20 17:45:00 +00:00
chmod +x kompose
sudo mv ./kompose /usr/local/bin/kompose
```
2017-01-05 13:57:27 +00:00
2017-09-15 00:14:28 +00:00
Alternatively, you can download the [tarball ](https://github.com/kubernetes/kompose/releases ).
2017-01-05 13:57:27 +00:00
2017-09-15 00:14:28 +00:00
#### Go
2017-01-05 13:57:27 +00:00
2017-09-15 00:14:28 +00:00
Installing using `go get` pulls from the master branch with the latest development changes.
2017-01-05 13:57:27 +00:00
2017-09-15 00:14:28 +00:00
```sh
go get -u github.com/kubernetes/kompose
```
#### CentOS
Kompose is in [EPEL ](https://fedoraproject.org/wiki/EPEL ) CentOS repository.
If you don't have [EPEL ](https://fedoraproject.org/wiki/EPEL ) repository already installed and enabled you can do it by running `sudo yum install epel-release`
If you have [EPEL ](https://fedoraproject.org/wiki/EPEL ) enabled in your system, you can install Kompose like any other package.
```bash
sudo yum -y install kompose
```
#### Fedora
Kompose is in Fedora 24, 25 and 26 repositories. You can install it just like any other package.
```bash
sudo dnf -y install kompose
2017-01-05 13:57:27 +00:00
```
2017-09-15 00:14:28 +00:00
#### macOS
On macOS you can install latest release via [Homebrew ](https://brew.sh ):
```bash
brew install kompose
```
# User Guide
- CLI
- [`kompose convert` ](#kompose-convert )
- [`kompose up` ](#kompose-up )
- [`kompose down` ](#kompose-down )
- Documentation
- [Build and Push Docker Images ](#build-and-push-docker-images )
- [Alternative Conversions ](#alternative-conversions )
- [Labels ](#labels )
- [Restart ](#restart )
- [Docker Compose Versions ](#docker-compose-versions )
Kompose has support for two providers: OpenShift and Kubernetes.
You can choose a targeted provider using global option `--provider` . If no provider is specified, Kubernetes is set by default.
2017-01-05 13:57:27 +00:00
2017-09-15 00:14:28 +00:00
## `kompose convert`
Kompose supports conversion of V1, V2, and V3 Docker Compose files into Kubernetes and OpenShift objects.
### Kubernetes
```sh
2017-01-05 13:57:27 +00:00
$ kompose --file docker-voting.yml convert
2017-04-20 17:45:00 +00:00
WARN Unsupported key networks - ignoring
WARN Unsupported key build - ignoring
2017-09-15 00:14:28 +00:00
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
2017-01-05 13:57:27 +00:00
$ ls
2017-01-09 15:29:15 +00:00
db-deployment.yaml docker-compose.yml docker-gitlab.yml redis-deployment.yaml result-deployment.yaml vote-deployment.yaml worker-deployment.yaml
2017-09-15 00:14:28 +00:00
db-svc.yaml docker-voting.yml redis-svc.yaml result-svc.yaml vote-svc.yaml worker-svc.yaml
2017-01-05 13:57:27 +00:00
```
2017-01-09 15:29:15 +00:00
You can also provide multiple docker-compose files at the same time:
2017-09-15 00:14:28 +00:00
```sh
2017-01-09 15:29:15 +00:00
$ kompose -f docker-compose.yml -f docker-guestbook.yml convert
2017-09-15 00:14:28 +00:00
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
2017-01-09 15:29:15 +00:00
$ ls
2017-09-15 00:14:28 +00:00
mlbparks-deployment.yaml mongodb-service.yaml redis-slave-service.jsonmlbparks-service.yaml
2017-01-09 15:29:15 +00:00
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
2017-09-15 00:14:28 +00:00
```
2017-01-05 13:57:27 +00:00
2017-09-15 00:14:28 +00:00
When multiple docker-compose files are provided the configuration is merged. Any configuration that is common will be over ridden by subsequent file.
2017-01-05 13:57:27 +00:00
### OpenShift
2017-09-15 00:14:28 +00:00
```sh
2017-01-05 13:57:27 +00:00
$ kompose --provider openshift --file docker-voting.yml convert
2017-04-20 17:45:00 +00:00
WARN [worker] Service cannot be created because of missing port.
2017-09-15 00:14:28 +00:00
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
2017-01-05 13:57:27 +00:00
```
2017-01-09 15:29:15 +00:00
It also supports creating buildconfig for build directive in a service. By default, it uses the remote repo for the current git branch as the source repo, and the current branch as the source branch for the build. You can specify a different source repo and branch using ``--build-repo`` and ``--build-branch`` options respectively.
2017-09-15 00:14:28 +00:00
```sh
2017-04-20 17:45:00 +00:00
$ kompose --provider openshift --file buildconfig/docker-compose.yml convert
2017-09-15 00:14:28 +00:00
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
2017-01-09 15:29:15 +00:00
```
**Note**: If you are manually pushing the Openshift artifacts using ``oc create -f``, you need to ensure that you push the imagestream artifact before the buildconfig artifact, to workaround this Openshift issue: https://github.com/openshift/origin/issues/4518 .
2017-09-15 00:14:28 +00:00
## `kompose up`
2017-01-05 13:57:27 +00:00
Kompose supports a straightforward way to deploy your "composed" application to Kubernetes or OpenShift via `kompose up` .
### Kubernetes
2017-09-15 00:14:28 +00:00
```sh
2017-01-05 13:57:27 +00:00
$ kompose --file ./examples/docker-guestbook.yml up
We are going to create Kubernetes deployments and services for your Dockerized application.
If you need different kind of resources, use the 'kompose convert' and 'kubectl create -f' commands instead.
2017-09-15 00:14:28 +00:00
INFO Successfully created service: redis-master
INFO Successfully created service: redis-slave
INFO Successfully created service: frontend
2017-04-20 17:45:00 +00:00
INFO Successfully created deployment: redis-master
INFO Successfully created deployment: redis-slave
2017-09-15 00:14:28 +00:00
INFO Successfully created deployment: frontend
2017-01-05 13:57:27 +00:00
Your application has been deployed to Kubernetes. You can run 'kubectl get deployment,svc,pods' for details.
$ kubectl get deployment,svc,pods
2017-03-30 11:33:34 +00:00
NAME DESIRED CURRENT UP-TO-DATE AVAILABLE AGE
deploy/frontend 1 1 1 1 4m
deploy/redis-master 1 1 1 1 4m
deploy/redis-slave 1 1 1 1 4m
NAME CLUSTER-IP EXTERNAL-IP PORT(S) AGE
svc/frontend 10.0.174.12 < none > 80/TCP 4m
svc/kubernetes 10.0.0.1 < none > 443/TCP 13d
svc/redis-master 10.0.202.43 < none > 6379/TCP 4m
svc/redis-slave 10.0.1.85 < none > 6379/TCP 4m
NAME READY STATUS RESTARTS AGE
po/frontend-2768218532-cs5t5 1/1 Running 0 4m
po/redis-master-1432129712-63jn8 1/1 Running 0 4m
po/redis-slave-2504961300-nve7b 1/1 Running 0 4m
2017-01-05 13:57:27 +00:00
```
Note:
- You must have a running Kubernetes cluster with a pre-configured kubectl context.
- Only deployments and services are generated and deployed to Kubernetes. If you need different kind of resources, use the 'kompose convert' and 'kubectl create -f' commands instead.
### OpenShift
2017-09-15 00:14:28 +00:00
```sh
$ kompose --file ./examples/docker-guestbook.yml --provider openshift up
2017-01-05 13:57:27 +00:00
We are going to create OpenShift DeploymentConfigs and Services for your Dockerized application.
If you need different kind of resources, use the 'kompose convert' and 'oc create -f' commands instead.
2017-09-15 00:14:28 +00:00
INFO Successfully created service: redis-slave
INFO Successfully created service: frontend
INFO Successfully created service: redis-master
2017-04-20 17:45:00 +00:00
INFO Successfully created deployment: redis-slave
INFO Successfully created ImageStream: redis-slave
2017-09-15 00:14:28 +00:00
INFO Successfully created deployment: frontend
INFO Successfully created ImageStream: frontend
2017-04-20 17:45:00 +00:00
INFO Successfully created deployment: redis-master
INFO Successfully created ImageStream: redis-master
2017-01-05 13:57:27 +00:00
Your application has been deployed to OpenShift. You can run 'oc get dc,svc,is' for details.
$ oc get dc,svc,is
NAME REVISION DESIRED CURRENT TRIGGERED BY
dc/frontend 0 1 0 config,image(frontend:v4)
dc/redis-master 0 1 0 config,image(redis-master:e2e)
dc/redis-slave 0 1 0 config,image(redis-slave:v1)
NAME CLUSTER-IP EXTERNAL-IP PORT(S) AGE
svc/frontend 172.30.46.64 < none > 80/TCP 8s
svc/redis-master 172.30.144.56 < none > 6379/TCP 8s
svc/redis-slave 172.30.75.245 < none > 6379/TCP 8s
NAME DOCKER REPO TAGS UPDATED
2017-09-15 00:14:28 +00:00
is/frontend 172.30.12.200:5000/fff/frontend
is/redis-master 172.30.12.200:5000/fff/redis-master
is/redis-slave 172.30.12.200:5000/fff/redis-slave v1
2017-01-05 13:57:27 +00:00
```
Note:
- You must have a running OpenShift cluster with a pre-configured `oc` context (`oc login`)
2017-09-15 00:14:28 +00:00
## `kompose down`
2017-01-05 13:57:27 +00:00
2017-09-15 00:14:28 +00:00
Once you have deployed "composed" application to Kubernetes, `$ kompose down` will help you to take the application out by deleting its deployments and services. If you need to remove other resources, use the 'kubectl' command.
2017-01-05 13:57:27 +00:00
2017-09-15 00:14:28 +00:00
```sh
2017-01-05 13:57:27 +00:00
$ kompose --file docker-guestbook.yml down
2017-09-15 00:14:28 +00:00
INFO Successfully deleted service: redis-master
2017-04-20 17:45:00 +00:00
INFO Successfully deleted deployment: redis-master
2017-09-15 00:14:28 +00:00
INFO Successfully deleted service: redis-slave
2017-04-20 17:45:00 +00:00
INFO Successfully deleted deployment: redis-slave
2017-09-15 00:14:28 +00:00
INFO Successfully deleted service: frontend
2017-04-20 17:45:00 +00:00
INFO Successfully deleted deployment: frontend
2017-01-05 13:57:27 +00:00
```
Note:
- You must have a running Kubernetes cluster with a pre-configured kubectl context.
2017-09-15 00:14:28 +00:00
## Build and Push Docker Images
Kompose supports both building and pushing Docker images. When using the `build` key within your Docker Compose file, your image will:
- Automatically be built with Docker using the `image` key specified within your file
- Be pushed to the correct Docker repository using local credentials (located at `.docker/config` )
Using an [example Docker Compose file ](https://raw.githubusercontent.com/kubernetes/kompose/master/examples/buildconfig/docker-compose.yml ):
```yaml
version: "2"
2017-01-05 13:57:27 +00:00
2017-09-15 00:14:28 +00:00
services:
foo:
build: "./build"
image: docker.io/foo/bar
```
2017-01-05 13:57:27 +00:00
2017-09-15 00:14:28 +00:00
Using `kompose up` with a `build` key:
```sh
$ kompose up
INFO Build key detected. Attempting to build and push image 'docker.io/foo/bar'
INFO Building image 'docker.io/foo/bar' from directory 'build'
INFO Image 'docker.io/foo/bar' from directory 'build' built successfully
INFO Pushing image 'foo/bar:latest' to registry 'docker.io'
INFO Attempting authentication credentials 'https://index.docker.io/v1/
INFO Successfully pushed image 'foo/bar:latest' to registry 'docker.io'
INFO We are going to create Kubernetes Deployments, Services and PersistentVolumeClaims for your Dockerized application. If you need different kind of resources, use the 'kompose convert' and 'kubectl create -f' commands instead.
INFO Deploying application in "default" namespace
INFO Successfully created Service: foo
INFO Successfully created Deployment: foo
Your application has been deployed to Kubernetes. You can run 'kubectl get deployment,svc,pods,pvc' for details.
```
In order to disable the functionality, or choose to use BuildConfig generation (with OpenShift) `--build (local|build-config|none)` can be passed.
```sh
# Disable building/pushing Docker images
$ kompose up --build none
# Generate Build Config artifacts for OpenShift
$ kompose up --provider openshift --build build-config
```
## Alternative Conversions
2018-02-14 05:30:50 +00:00
The default `kompose` transformation will generate Kubernetes [Deployments ](http://kubernetes.io/docs/user-guide/deployments/ ) and [Services ](http://kubernetes.io/docs/concepts/services-networking/service/ ), in yaml format. You have alternative option to generate json with `-j` . Also, you can alternatively generate [Replication Controllers ](http://kubernetes.io/docs/user-guide/replication-controller/ ) objects, [Daemon Sets ](http://kubernetes.io/docs/admin/daemons/ ), or [Helm ](https://github.com/helm/helm ) charts.
2017-09-15 00:14:28 +00:00
```sh
2017-04-20 17:45:00 +00:00
$ kompose convert -j
2017-09-15 00:14:28 +00:00
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
2017-01-05 13:57:27 +00:00
```
The `*-deployment.json` files contain the Deployment objects.
2017-09-15 00:14:28 +00:00
```sh
$ 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
2017-01-05 13:57:27 +00:00
```
2017-09-15 00:14:28 +00:00
The `*-replicationcontroller.yaml` files contain the Replication Controller objects. If you want to specify replicas (default is 1), use `--replicas` flag: `$ kompose convert --replication-controller --replicas 3`
2017-01-05 13:57:27 +00:00
2017-09-15 00:14:28 +00:00
```sh
$ 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
2017-01-05 13:57:27 +00:00
```
2017-09-15 00:14:28 +00:00
The `*-daemonset.yaml` files contain the Daemon Set objects
2017-01-05 13:57:27 +00:00
If you want to generate a Chart to be used with [Helm ](https://github.com/kubernetes/helm ) simply do:
2017-09-15 00:14:28 +00:00
```sh
$ 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
2017-01-05 13:57:27 +00:00
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
```
The chart structure is aimed at providing a skeleton for building your Helm charts.
## Labels
2017-01-09 15:29:15 +00:00
`kompose` supports Kompose-specific labels within the `docker-compose.yml` file in order to explicitly define a service's behavior upon conversion.
2017-01-05 13:57:27 +00:00
2017-01-09 15:29:15 +00:00
- kompose.service.type defines the type of service to be created.
2017-01-05 13:57:27 +00:00
2017-01-09 15:29:15 +00:00
For example:
2017-01-05 13:57:27 +00:00
```yaml
version: "2"
2017-09-15 00:14:28 +00:00
services:
2017-01-05 13:57:27 +00:00
nginx:
image: nginx
dockerfile: foobar
build: ./foobar
cap_add:
- ALL
container_name: foobar
2017-09-15 00:14:28 +00:00
labels:
2017-01-05 13:57:27 +00:00
kompose.service.type: nodeport
```
2017-01-09 15:29:15 +00:00
- kompose.service.expose defines if the service needs to be made accessible from outside the cluster or not. If the value is set to "true", the provider sets the endpoint automatically, and for any other value, the value is set as the hostname. If multiple ports are defined in a service, the first one is chosen to be the exposed.
- For the Kubernetes provider, an ingress resource is created and it is assumed that an ingress controller has already been configured.
- For the OpenShift provider, a route is created.
For example:
```yaml
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"
```
The currently supported options are:
| Key | Value |
|----------------------|-------------------------------------|
| kompose.service.type | nodeport / clusterip / loadbalancer |
| kompose.service.expose| true / hostname |
2017-09-15 00:14:28 +00:00
**Note**: `kompose.service.type` label should be defined with `ports` only, otherwise `kompose` will fail.
2017-01-09 15:29:15 +00:00
## Restart
2017-12-26 09:40:05 +00:00
If you want to create normal pods without controllers you can use `restart` construct of docker-compose to define that. Follow table below to see what happens on the `restart` value.
2017-01-09 15:29:15 +00:00
| `docker-compose` `restart` | object created | Pod `restartPolicy` |
|----------------------------|-------------------|---------------------|
| `""` | controller object | `Always` |
| `always` | controller object | `Always` |
| `on-failure` | Pod | `OnFailure` |
| `no` | Pod | `Never` |
**Note**: controller object could be `deployment` or `replicationcontroller` , etc.
2017-09-15 00:14:28 +00:00
For e.g. `pival` service will become pod down here. This container calculated value of `pi` .
2017-01-09 15:29:15 +00:00
```yaml
2017-04-20 17:45:00 +00:00
version: '2'
2017-01-09 15:29:15 +00:00
services:
2017-04-20 17:45:00 +00:00
pival:
image: perl
command: ["perl", "-Mbignum=bpi", "-wle", "print bpi(2000)"]
restart: "on-failure"
2017-01-09 15:29:15 +00:00
```
2017-04-20 17:45:00 +00:00
2017-09-15 00:14:28 +00:00
#### Warning about Deployment Config's
2017-04-20 17:45:00 +00:00
If the Docker Compose file has a volume specified for a service, the Deployment (Kubernetes) or DeploymentConfig (OpenShift) strategy is changed to "Recreate" instead of "RollingUpdate" (default). This is done to avoid multiple instances of a service from accessing a volume at the same time.
2017-09-15 00:14:28 +00:00
If the Docker Compose file has service name with `_` in it (eg.`web_service`), then it will be replaced by `-` and the service name will be renamed accordingly (eg.`web-service`). Kompose does this because "Kubernetes" doesn't allow `_` in object name.
Please note that changing service name might break some `docker-compose` files.
## Docker Compose Versions
Kompose supports Docker Compose versions: 1, 2 and 3. We have limited support on versions 2.1 and 3.2 due to their experimental nature.
2017-09-25 23:43:35 +00:00
A full list on compatibility between all three versions is listed in our [conversion document ](https://github.com/kubernetes/kompose/blob/master/docs/conversion.md ) including a list of all incompatible Docker Compose keys.