Docker compose discussion #451
Labels
Discussion
Open to discussion from different team members
research
Issues that can't be developed immediately and require research
The
docker-compose
volumes, networks and service keys/volumes/networks are critical in dappnode since all dappnode packages are distributed throughdocker-compose.yml
files.service keys
The compose keys may be critical and allow a container to gain privileges on the host and perform almost any type of attack.
In dappnode there is a compose keys "whitelist" to restrict the use of these keys. However this list has been growing due to necessities and it must be reviewed in deep.
To discuss:
cap_add
: used by Mysterium. tropicar could you find another approach to not use that capability? if not, could you explain why capabilityNET_ADMIN
is necessary?devices
seems to be used nowhere. Should it be removed?extra_hosts
seems to be used nowhere. Should it be removed?logging
this value is overwritten during installation time at https://github.com/dappnode/DNP_DAPPMANAGER/blob/947f9196efbb596f4d94ea9d647dd54ed1b295c4/packages/dappmanager/src/modules/compose/unsafeCompose.ts#L99 . Should it be removed ?network_host
seems to be used nowhere. Should it be removed?pid
restricted toservice:*
.privileged
currently used by dappmanager wifi and vpn. It should be restricted to this small whiltelistrestart
this value is been overwritten during installation time at https://github.com/dappnode/DNP_DAPPMANAGER/blob/947f9196efbb596f4d94ea9d647dd54ed1b295c4/packages/dappmanager/src/modules/compose/unsafeCompose.ts#L98 . . Should it be removed ?security_opt
used by lighthouse and web3signer. This is necessary due to using newer docker images with old docker engine versions. Docker engine version should be updated on dappnode hosts. See Consider switching docker installation and update method from package to repository #392networks
There are currently two docker networks for simplicity in dappnode:
dncore_network
(for all containers) anddnpublic_network
(for HTTPS portal mappings). The current setup is that no one owns any docker network, both of them are declared as external. Thedncore_network
is created on dappnode installation withdocker network create
. Thednpublic_network
is created by the dappmanager when installing the HTTPS package.To discuss:
dnpublic_network
be owned by the HTTPS package? see reasoning Definednpublic_network
in thedocker-compose.yml
DNP_HTTPS#66volumes
There are two types of docker volumes used in dappnode: named and bind-mounted volumes. Bind mounted volumes are dangerous and should be only used in a reasoned case of necessity (especially the docker socket volume)
To discuss:
/run/dbus/system_bus_socket
used by avahi and upnp/usr/src/dappnode/DNCORE/
used to have on host the core compose files, and hostScripts/var/run/docker.sock
to allow dappmanager to perform docker actions/etc/hostname
to render the hostname in the UI. Would be a better solution to run a script to get the hostname on startup instead of bind-mounting the volume? tropicar/var/run/docker.sock
used to execute container with host network privileges/var/run/docker.sock
?/etc/hostname
?/usr/src/dappnode/config
?/lib/modules
?/lib/modules
? 3alpha/etc/
to get access to/etc/os-release
and/etc/motd
files from host. Consider only mounting those files instead of the entire/etc
folder/usr/src/dappnode/
to modify scripts and profile/var/run/docker.sock
to startup dappmanager container┆Issue is synchronized with this Basecamp todo by Unito
The text was updated successfully, but these errors were encountered: