On this page
Plugin Config Version 1 of Plugin V2
This document outlines the format of the V0 plugin configuration. The plugin config described herein was introduced in the Docker daemon in the v1.12.0 release.
Plugin configs describe the various constituents of a docker plugin. Plugin configs can be serialized to JSON format with the following media types:
| Config Type | Media Type | 
|---|---|
| config | “application/vnd.docker.plugin.v1+json” | 
Config Field Descriptions
Config provides the base accessible fields for working with V0 plugin format in the registry.
- descriptionstring- description of the plugin 
- documentationstring- link to the documentation about the plugin
- interfacePluginInterface- interface implemented by the plugins, struct consisting of the following fields - typesstring array- types indicate what interface(s) the plugin currently implements. - currently supported: - docker.volumedriver/1.0 
- docker.networkdriver/1.0 
- docker.ipamdriver/1.0 
- docker.authz/1.0 
- docker.logdriver/1.0 
- docker.metricscollector/1.0 
 
- socketstring- socket is the name of the socket the engine should use to communicate with the plugins. the socket will be created in - /run/docker/plugins.
 
- entrypointstring array- entrypoint of the plugin, see - ENTRYPOINT
- workdirstring- workdir of the plugin, see - WORKDIR
- networkPluginNetwork- network of the plugin, struct consisting of the following fields - typestring- network type. - currently supported: - - **bridge** - **host** - **none**
 
- mountsPluginMount array- mount of the plugin, struct consisting of the following fields, see - MOUNTS- namestring- name of the mount. 
- descriptionstring- description of the mount. 
- sourcestring- source of the mount. 
- destinationstring- destination of the mount. 
- typestring- mount type. 
- optionsstring array- options of the mount. 
 
- ipchostboolean Access to host ipc namespace.
- pidhostboolean Access to host pid namespace.
- propagatedMountstring- path to be mounted as rshared, so that mounts under that path are visible to docker. This is useful for volume plugins. This path will be bind-mounted outside of the plugin rootfs so it’s contents are preserved on upgrade. 
- envPluginEnv array- env of the plugin, struct consisting of the following fields - namestring- name of the env. 
- descriptionstring- description of the env. 
- valuestring- value of the env. 
 
- argsPluginArgs- args of the plugin, struct consisting of the following fields - namestring- name of the args. 
- descriptionstring- description of the args. 
- valuestring array- values of the args. 
 
- linuxPluginLinux- capabilitiesstring array- capabilities of the plugin (Linux only), see list - here
- allowAllDevicesboolean- If - /devis bind mounted from the host, and allowAllDevices is set to true, the plugin will have- rwmaccess to all devices on the host.
- devicesPluginDevice array- device of the plugin, (Linux only), struct consisting of the following fields, see - DEVICES- namestring- name of the device. 
- descriptionstring- description of the device. 
- pathstring- path of the device. 
 
 
Example Config
Example showing the ‘tiborvass/sample-volume-plugin’ plugin config.
{
            "Args": {
                "Description": "",
                "Name": "",
                "Settable": null,
                "Value": null
            },
            "Description": "A sample volume plugin for Docker",
            "Documentation": "https://docs.docker.com/engine/extend/plugins/",
            "Entrypoint": [
                "/usr/bin/sample-volume-plugin",
                "/data"
            ],
            "Env": [
                {
                    "Description": "",
                    "Name": "DEBUG",
                    "Settable": [
                        "value"
                    ],
                    "Value": "0"
                }
            ],
            "Interface": {
                "Socket": "plugin.sock",
                "Types": [
                    "docker.volumedriver/1.0"
                ]
            },
            "Linux": {
                "Capabilities": null,
                "AllowAllDevices": false,
                "Devices": null
            },
            "Mounts": null,
            "Network": {
                "Type": ""
            },
            "PropagatedMount": "/data",
            "User": {},
            "Workdir": ""
}
API, Usage, plugins, documentation, developer
© 2019 Docker, Inc.
Licensed under the Apache License, Version 2.0.
Docker and the Docker logo are trademarks or registered trademarks of Docker, Inc. in the United States and/or other countries.
Docker, Inc. and other parties may also have trademark rights in other terms used herein.
 https://docs.docker.com/v18.09/engine/extend/config/