Inspired by other similar plugins, I wanted a docker volume plugin that didn't require the secrets to be passed to the driver, but instead one that could read from keyring files instead.
Since this plugin reads from your keyring files, it requires the folder /etc/ceph
to
exist and be readable by the docker user. Keyring files should be stored in this folder
in order to be discoverable by the plugin.
Keyring files are expected to follow the naming pattern ceph.client.admin.keyring
by
default where ceph
is the name of the cluster and admin
is the name of the client.
To create a client on your ceph cluster, you can run a command similar to the following:
ceph auth get-or-create client.dockeruser mon 'allow r' osd 'allow rw' mds 'allow' \
> /etc/ceph/ceph.client.dockeruser.keyring
Then, copy over this keyring file to your docker hosts.
docker plugin install --alias cephfs brindster/docker-plugin-cephfs \
CLUSTER_NAME=ceph \
CLIENT_NAME=admin \
SERVERS=ceph1,ceph2,ceph3
There are three settings that can be modified on the plugin during installation. These settings act as default values, all of them are overridable when creating volumes.
Also, debug mode can be enabled on the plugin to output verbose logs during plugin operation.
Debug mode is enabled using the DEBUG_MODE=1
value.
Create a volume directly from the command line:
docker volume create --driver cephfs test
docker run -it --rm -v test:/data busybox sh
Alternatively, use from a docker-compose file:
version: '3'
services:
app:
image: nginx
volumes:
- test:/data
volumes:
test:
driver: cephfs
The following options are available:
version: '3'
services:
app:
image: nginx
volumes:
- test:/data
volumes:
test:
driver: cephfs
driver_opts:
client_name: dockeruser
keyring: /etc/ceph/dockeruser.keyring
mount_opts: mds_namespace=example
remote_path: /shared_data
servers: 192.168.1.10,ceph-mon.internal.example.com:16789