Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kubernetes/kompose
Convert Compose to Kubernetes
https://github.com/kubernetes/kompose
containers docker docker-compose go kubernetes
Last synced: 6 days ago
JSON representation
Convert Compose to Kubernetes
- Host: GitHub
- URL: https://github.com/kubernetes/kompose
- Owner: kubernetes
- License: apache-2.0
- Created: 2016-06-27T21:08:18.000Z (over 8 years ago)
- Default Branch: main
- Last Pushed: 2024-12-20T14:18:32.000Z (23 days ago)
- Last Synced: 2024-12-30T12:42:58.494Z (13 days ago)
- Topics: containers, docker, docker-compose, go, kubernetes
- Language: Go
- Homepage: http://kompose.io
- Size: 42.9 MB
- Stars: 9,705
- Watchers: 129
- Forks: 765
- Open Issues: 25
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: code-of-conduct.md
- Security: SECURITY.md
Awesome Lists containing this project
- stars - kubernetes/kompose
- awesome - kompose - Go from Docker Compose to Kubernetes (Go)
- awesome-ops - kubernetes/kompose - 2.0|9543|2016-06-27|2024-09-24 | 将 Docker Compose 转换为 Kubernetes | (K8S-Tools)
- awesome-repositories - kubernetes/kompose - Convert Compose to Kubernetes (Go)
- awesome-software-engineering - :scroll: \[eng\
- awesome-starred - kompose - Go from Docker Compose to Kubernetes (Go)
- awesome-list - kompose
- awesome-starred - kubernetes/kompose - Convert Compose to Kubernetes (go)
- awesome-docker - kompose - Go from Docker Compose to Kubernetes (Container Operations / Container Composition)
- awesome-golang-repositories - kompose
- awesome-cloud-native - kompose - Go from Docker Compose to Kubernetes. (Application Delivery)
- awesome-docker - kompose - Go from Docker Compose to Kubernetes (Container Operations / Container Composition)
- awesome-list-docker - kompose
README
# Kompose (Kubernetes + Compose)
[![Build Status Widget]][Build Status] [![Coverage Status Widget]][Coverage Status] [![GoDoc Widget]][GoDoc] [![GoReportCard Widget]][GoReportCardResult]
![logo](/docs/assets/images/logo.png)
`kompose` is a tool to help users who are familiar with `docker-compose` move to [Kubernetes](http://kubernetes.io). `kompose` takes a [Compose Specification](https://compose-spec.io/) file and translates it into Kubernetes resources.
`kompose` is a convenience tool to go from local Compose environment to managing your application with Kubernetes. Transformation of the [Compose Specification](https://compose-spec.io/) format to Kubernetes resources manifest may not be exact, but it helps tremendously when first deploying an application on Kubernetes.
## Use Case
Convert [`compose.yaml`](https://raw.githubusercontent.com/kubernetes/kompose/main/examples/compose.yaml) into Kubernetes deployments and services with one simple command:
```sh
$ kompose convert -f compose.yaml
INFO Kubernetes file "frontend-service.yaml" created
INFO Kubernetes file "redis-leader-service.yaml" created
INFO Kubernetes file "redis-replica-service.yaml" created
INFO Kubernetes file "frontend-deployment.yaml" created
INFO Kubernetes file "redis-leader-deployment.yaml" created
INFO Kubernetes file "redis-replica-deployment.yaml" created
```Other examples are provided in the _examples_ [directory](./examples).
## Installation
We have multiple ways to install Kompose. Our preferred method is downloading the binary from the latest GitHub release.
Our entire list of installation methods are located in our [installation.md](/docs/installation.md) document.
Installation methods:
- [Binary (Preferred method)](/docs/installation.md#github-release)
- [Go](/docs/installation.md#go)
- [CentOS](/docs/installation.md#centos)
- [openSUSE/SLE](/docs/installation.md#opensusesle)
- [NixOS](/docs/installation.md#nixos)
- [macOS (Homebrew and MacPorts)](/docs/installation.md#macos)
- [Windows](/docs/installation.md#windows)
- [Docker](/docs/installation.md#docker)#### Binary installation
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).
**Linux and macOS:**
```sh
# Linux
curl -L https://github.com/kubernetes/kompose/releases/download/v1.35.0/kompose-linux-amd64 -o kompose# macOS
curl -L https://github.com/kubernetes/kompose/releases/download/v1.35.0/kompose-darwin-amd64 -o komposechmod +x kompose
sudo mv ./kompose /usr/local/bin/kompose
```**Windows:**
Download from [GitHub](https://github.com/kubernetes/kompose/releases/download/v1.35.0/kompose-windows-amd64.exe) and add the binary to your PATH.
## Shell autocompletion
We support Bash, Zsh and Fish autocompletion.
```sh
# Bash (add to .bashrc for persistence)
source <(kompose completion bash)# Zsh (add to .zshrc for persistence)
source <(kompose completion zsh)# Fish autocompletion
kompose completion fish | source
```## Development and building of Kompose
### Building with `go`
**Requisites:**
1. [make](https://www.gnu.org/software/make/)
2. [Golang](https://golang.org/) v1.6 or later
3. Set `GOPATH` correctly or click [SettingGOPATH](https://github.com/golang/go/wiki/SettingGOPATH) for details**Steps:**
1. Clone repository
```console
$ git clone https://github.com/kubernetes/kompose.git $GOPATH/src/github.com/kubernetes/kompose
```2. Change directory to the cloned repo.
```console
cd $GOPATH/src/github.com/kubernetes/kompose
```3. Build with `make`
```console
$ make bin
```4. Or build with `go`
```console
$ go build -o kompose main.go
```5. Test your changes
```console
$ make test
```## Documentation
Documentation can be found at our [kompose.io](http://kompose.io) website or our [docs](https://github.com/kubernetes/kompose/tree/main/docs) folder.
Here is a list of all available docs:
- [Quick start](docs/getting-started.md)
- [Installation](docs/installation.md)
- [User guide](docs/user-guide.md)
- [Conversion](docs/conversion.md)
- [Architecture](docs/architecture.md)
- [Development](docs/development.md)## Community, Discussion, Contribution, and Support
**Issues:** If you find any issues, please [file it](https://github.com/kubernetes/kompose/issues).
**Kubernetes Community:** As part of the Kubernetes ecosystem, we follow the Kubernetes community principles. More information can be found on the [community page](http://kubernetes.io/community/).
**Chat (Slack):** We're fairly active on [Slack](http://slack.kubernetes.io#kompose) and you can find us in the #kompose channel.
### Code of Conduct
Participation in the Kubernetes community is governed by the [Kubernetes Code of Conduct](code-of-conduct.md).
[Build Status]: https://github.com/kubernetes/kompose/actions?query=workflow%3A%22Kompose+CI%22
[Build Status Widget]: https://github.com/kubernetes/kompose/workflows/Kompose%20CI/badge.svg
[GoDoc]: https://godoc.org/github.com/kubernetes/kompose
[GoDoc Widget]: https://godoc.org/github.com/kubernetes/kompose?status.svg
[Coverage Status Widget]: https://coveralls.io/repos/github/kubernetes/kompose/badge.svg?branch=main
[Coverage Status]: https://coveralls.io/github/kubernetes/kompose?branch=main
[GoReportCard Widget]: https://goreportcard.com/badge/github.com/kubernetes/kompose
[GoReportCardResult]: https://goreportcard.com/report/github.com/kubernetes/kompose