Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/composerize/composerize
🏃→🎼 docker run asdlksjfksdf > docker-composerize up
https://github.com/composerize/composerize
docker docker-compose dockerfile
Last synced: 4 days ago
JSON representation
🏃→🎼 docker run asdlksjfksdf > docker-composerize up
- Host: GitHub
- URL: https://github.com/composerize/composerize
- Owner: composerize
- License: mit
- Created: 2016-08-26T02:20:37.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2024-09-27T10:39:35.000Z (4 months ago)
- Last Synced: 2025-01-01T22:04:41.125Z (11 days ago)
- Topics: docker, docker-compose, dockerfile
- Language: JavaScript
- Homepage: http://composerize.com
- Size: 3.07 MB
- Stars: 3,259
- Watchers: 22
- Forks: 225
- Open Issues: 14
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome - composerize/composerize - 🏃→🎼 docker run asdlksjfksdf > docker-composerize up (docker)
- jimsghstars - composerize/composerize - 🏃→🎼 docker run asdlksjfksdf > docker-composerize up (JavaScript)
README
# composerize
[![Build Status](https://travis-ci.org/magicmark/composerize.svg?branch=master)](https://travis-ci.com/github/magicmark/composerize)
[![npm](https://img.shields.io/npm/v/composerize.svg)](https://www.npmjs.com/package/composerize)
[![Follow @mark_larah](https://img.shields.io/twitter/follow/mark_larah)](https://twitter.com/mark_larah?ref_src=github_composerize)
[![ShareVB on GitHub](https://img.shields.io/badge/ShareVB-100000?logo=github&logoColor=white)](https://github.com/sharevb)
http://composerize.com - Turns `docker run` commands into `docker-compose.yml` files and even merge with existing `docker-compose.yml`!Looking for the reverse : http://decomposerize.com / [Decomposerize](https://github.com/outilslibre/decomposerize)
Want to convert from Docker compose file formats : http://composeverter.com / [Composeverter](https://github.com/outilslibre/composeverter)
![Demo](https://i.imgur.com/GayZj2G.png)
## CLI
composerize can be run in the cli.
`npm install composerize -g` to install, and run as such:
```bash
$ composerize docker run -p 80:80 -v /var/run/docker.sock:/tmp/docker.sock:ro --restart always --log-opt max-size=1g nginx
```See `composerize --help` for more options.
## Docker image
A dockker image of composerize, decomposerize and composeverter websites is available here: https://github.com/Oaklight/composerize-minimal/blob/master/README_en.md (thanks to @Oaklight)
## How to use with node.js
Make sure to install the `composerize` package in your project by running:
```bash
npm install composerize
```With the following code, you can easily integrate **Composerize** into your Node.js project and generate Docker Compose configurations from Docker run commands.
```javascript
const composerize = require('composerize');const dockerRunCommand = 'docker run -d -p 8080:80 --name my-web-app nginx:latest';
// Convert the Docker run command to a Docker Compose configuration
const composeConfig = composerize(dockerRunCommand);console.log(composeConfig);
```You can also merge docker run command(s) with an existing Docker Compose file content :
```javascript
const composerize = require('composerize');const dockerRunCommand = 'docker run -d -p 8080:80 --name my-web-app nginx:latest';
// An existing Docker Compose configuration as a string
const existingComposeConfig = `
version: '3'
services:
existing-service:
image: my-existing-image:latest
ports:
- '8000:80'
`;// Convert the Docker run command to a Docker Compose configuration and merge with provided docker compose
const composeConfig = composerize(dockerRunCommand, existingComposeConfig);console.log(composeConfig);
```You can also choose which version of Docker compose V2, you target : 2.x, 3.x or Common Specification by specifying a third parameter `composeVersion` on `convertDockerRunToCompose` :
- 'v2x'
- 'v3x'
- 'latest'```javascript
const composerize = require('composerize');const dockerRunCommand = 'docker run -d -p 8080:80 --name my-web-app nginx:latest';
// Convert the Docker run command to a Docker Compose configuration for 2.x
const composeConfig = composerize(dockerRunCommand, null, 'v2x');console.log(composeConfig);
```You can also choose indentation level by specifying a fourth parameter `indent` on `convertDockerRunToCompose` :
- 'v2x'
- 'v3x'
- 'latest'```javascript
const composerize = require('composerize');const dockerRunCommand = 'docker run -d -p 8080:80 --name my-web-app nginx:latest';
// Convert the Docker run command to a Docker Compose configuration for 2.x
const composeConfig = composerize(dockerRunCommand, null, 'latest', 2);console.log(composeConfig);
```## Contributing
- [Clone a fork of the repo](https://guides.github.com/activities/forking/) and install the project dependencies by running `yarn`
- Make your changes, and build the project by running `make build`
- Test your changes with `make test`## Maintainers
- Mark Larah (Twitter: [@mark_larah](https://twitter.com/mark_larah))
- ShareVB [GitHub](https://github.com/sharevb)