Go to file
2017-10-27 20:31:30 +08:00
assets Add support for service rollback 2017-10-26 16:16:51 +08:00
biz Refactor config and app entry 2017-10-27 20:31:30 +08:00
config Switch config to YAML format 2017-10-26 17:14:23 +08:00
controller Add support for service rollback 2017-10-26 16:16:51 +08:00
dao Refactor config and app entry 2017-10-27 20:31:30 +08:00
docs/images Add codes 2017-09-26 20:50:09 +08:00
misc Refactor config and app entry 2017-10-27 20:31:30 +08:00
model Add support for service rollback 2017-10-26 16:16:51 +08:00
views Add support for service rollback 2017-10-26 16:16:51 +08:00
.gitattributes Add codes 2017-09-26 20:50:09 +08:00
.gitignore Add codes 2017-09-26 20:50:09 +08:00
Dockerfile Add codes 2017-09-26 20:50:09 +08:00
Gopkg.toml Add codes 2017-09-26 20:50:09 +08:00
LICENSE Initial commit 2017-09-25 03:43:54 -05:00
main.go Refactor config and app entry 2017-10-27 20:31:30 +08:00
README.md Improve README 2017-10-24 18:04:28 +08:00

SWIRL

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
  • LDAP authentication support
  • Full permission control based on RBAC model
  • Scale out as you want
  • Multiple language support
  • And more...

Snapshots

Dashboard

Dashboard

Service list

Service list

Compose list

Compose list

Role editing

Role editing

Settings

Setting

Configuration

With config file

All options can be set with config/app.conf.

<config>
    <app>
        <add key="name" value="swirl"/>
    </app>
    <web>
        <add key="address" value=":8001"/>
        <!-- default authorize mode, valid options: *(everyone)/?(login user)/!(authorized explicitly) -->
        <add key="authorize_mode" value="?"/>
    </web>
    <swirl>
        <!-- optional -->
        <add key="docker_endpoint" value="tcp://docker-proxy:2375"/>
        <!-- optional, valid options: mongo -->
        <add key="db_type" value="mongo"/>
        <!-- required, database connection string, must match with db.type option -->
        <add key="db_address" value="localhost:27017/swirl"/>
    </swirl>
</config>

With environment variables

Only three main 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

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.

./swirl

Docker

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

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

Build

Swirl use dep as dependency management tool(coming soon).

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.