mirror of
https://github.com/cuigh/swirl
synced 2025-02-24 21:13:48 +00:00
145 lines
3.1 KiB
Markdown
145 lines
3.1 KiB
Markdown
# SWIRL
|
|
|
|
[data:image/s3,"s3://crabby-images/8f8c1/8f8c127f9fad7b08545cb4ad9b50ad7196821718" alt="Docker Pulls"](https://hub.docker.com/r/cuigh/swirl/)
|
|
[data:image/s3,"s3://crabby-images/12a3c/12a3c38ab71b627c5877c4ac1df3ab71c4b4c416" alt="Swirl"](https://goreportcard.com/report/cuigh/swirl)
|
|
|
|
**Swirl** is a web management tool for Docker, focused on swarm cluster.
|
|
|
|
## Features
|
|
|
|
* Swarm components management
|
|
* Image and container management
|
|
* Compose management with deployment support
|
|
* Service monitoring based on [Prometheus](https://hub.docker.com/r/cuigh/prometheus/)
|
|
* Service auto scaling
|
|
* LDAP authentication support
|
|
* Full permission control based on RBAC model
|
|
* Scale out as you want
|
|
* Multiple language support
|
|
* And more...
|
|
|
|
## Snapshots
|
|
|
|
### Home
|
|
|
|
data:image/s3,"s3://crabby-images/aa39e/aa39ed8b05a771050344382d0d2abb850f3a8e6a" alt="Home"
|
|
|
|
### Service list
|
|
|
|
data:image/s3,"s3://crabby-images/c151e/c151e8d4d8a557180e61d711b32494e96457cfbf" alt="Service list"
|
|
|
|
### Service stats
|
|
|
|
data:image/s3,"s3://crabby-images/bcc45/bcc4567ab2de01ad1f45c4110e6a8fdc769d892f" alt="Service stats"
|
|
|
|
### Stack list
|
|
|
|
data:image/s3,"s3://crabby-images/029aa/029aafef1a8c2d48ed1a19adb1b90e7b08d55f88" alt="Stack list"
|
|
|
|
### Settings
|
|
|
|
data:image/s3,"s3://crabby-images/6ba79/6ba7928fd63931c65ea1ed68c111e4efce3f6791" alt="Setting"
|
|
|
|
## Configuration
|
|
|
|
### With config file
|
|
|
|
All options can be set with `config/app.yml`.
|
|
|
|
```yaml
|
|
name: swirl
|
|
banner: false
|
|
|
|
web:
|
|
address: ':8001'
|
|
authorize: '?'
|
|
|
|
swirl:
|
|
db_type: mongo
|
|
db_address: localhost:27017/swirl
|
|
# docker_endpoint: tcp://docker-proxy:2375
|
|
|
|
log:
|
|
loggers:
|
|
- level: info
|
|
writers: console
|
|
writers:
|
|
- name: console
|
|
type: console
|
|
layout: '[{L}]{T}: {M}{N}'
|
|
```
|
|
|
|
### With environment variables
|
|
|
|
Only these options can be set by environment variables for now.
|
|
|
|
| Name | Value |
|
|
| --------------- | -----------------------------|
|
|
| DB_TYPE | mongo |
|
|
| DB_ADDRESS | localhost:27017/swirl |
|
|
| DOCKER_ENDPOINT | tcp://docker-proxy:2375 |
|
|
| AUTH_TIMEOUT | 4h |
|
|
|
|
### With swarm config
|
|
|
|
Docker support mounting configuration file through swarm from v17.06, so you can store your config in swarm and mount it to your program.
|
|
|
|
## Deployment
|
|
|
|
### Stand alone
|
|
|
|
Just copy the swirl binary and config/assets/views directories to the host, and run it.
|
|
|
|
```bash
|
|
./swirl
|
|
```
|
|
|
|
### Docker
|
|
|
|
```bash
|
|
docker run -d -p 8001:8001 \
|
|
--mount type=bind,src=/var/run/docker.sock,dst=/var/run/docker.sock \
|
|
-e DB_TYPE=mongo \
|
|
-e DB_ADDRESS=localhost:27017/swirl \
|
|
--name=swirl \
|
|
cuigh/swirl
|
|
```
|
|
|
|
### Docker swarm
|
|
|
|
```bash
|
|
docker service create \
|
|
--name=swirl \
|
|
--publish=8001:8001/tcp \
|
|
--env DB_ADDRESS=localhost:27017/swirl \
|
|
--constraint=node.role==manager \
|
|
--mount=type=bind,src=/var/run/docker.sock,dst=/var/run/docker.sock \
|
|
cuigh/swirl
|
|
```
|
|
|
|
### Docker compose
|
|
|
|
```bash
|
|
docker stack deploy -c compose.yml swirl
|
|
```
|
|
|
|
## Advanced features
|
|
|
|
**Swirl** use service labels to support some features, the labels in the table below are currently supported.
|
|
|
|
Name | Description | Examples
|
|
--- | --- | ---
|
|
swirl.scale | Service auto scaling | `swirl.scale=min=1,max=5,cpu=30:50`
|
|
|
|
## Build
|
|
|
|
**Swirl** use `dep` as dependency management tool. You can build **Swirl**
|
|
|
|
```sh
|
|
$ dep ensure
|
|
$ go build
|
|
```
|
|
|
|
## License
|
|
|
|
This product is licensed to you under the MIT License. You may not use this product except in compliance with the License. See LICENSE and NOTICE for more information. |