Fork of otherguy/docker-dropbox
with minor changes.
Run Dropbox inside a Docker container. Supports local host folder mount or inter-container
linking via --volumes-from
.
For macOS users, mounting the Dropbox data folder is currently not possible!
See #6
for details
Back in 2018, Dropbox dropped support for several Linux filesystems and the Dropbox client refused to sync when an unsupported filesystem was encountered.
In July 2019, the decision was partially rolled back, allowing syncing from ZFS (on 64-bit systems only), eCryptFS, XFS (on 64-bit systems only), and BTRFS filesystems. Other filesystems dropped by the initial change are, however, still unsupported.
A dropbox-filesystem-fix
patch was developed by
@dark
and was previously used in this Docker image to make it work with
Docker volume mounts, especially on macOS where the mounted volume uses the FUSE
filesystem.
Unfortunately, as of January 2020
(Dropbox version 87.4.138
and later, currently up to 95.4.441
115.4.601
), this
fix is unable to get around the filesystem detection
in the newer Dropbox client versions. Using an older version of the Dropbox client is also not possible,
because the Dropbox API servers reject old client version and prevent them from connecting.
This breaks the possibility to mount a local folder via -v "/path/to/local/dropbox:/opt/dropbox/Dropbox"
on macOS systems.
This is the full command to start the Dropbox container. All volumes, environment variables and parameters are explained in the sections below.
$ docker run --detach -it --restart=always --name=dropbox \
--net="host" \
-e "TZ=$(readlink /etc/localtime | sed 's#^.*/zoneinfo/##')" \
-e "DROPBOX_UID=$(id -u)" \
-e "DROPBOX_GID=$(id -g)" \
-e "POLLING_INTERVAL=20" \
-v "/path/to/local/settings:/opt/dropbox" \
-v "/path/to/local/dropbox:/opt/dropbox/Dropbox" \
otherguy/dropbox:latest
Dropbox will return incorrect information (Dropbox daemon version: Not installed
) when you run dropbox version
in
the container. In case you ever need to know which version you have installed, instead run the following:
$ docker exec -it dropbox cat /opt/dropbox/bin/VERSION
When mounting the Dropbox data folder to your local filesystem, you need to set the DROPBOX_UID
and
DROPBOX_GID
environment variables to the user id and group id of whoever owns these files on the host
or in the other container. Failing to do so causes file permission errrors.
The example below uses id -u
and id -g
to retrieve the current user's user id and group id, respectively.
$ docker run --name=dropbox \
-e "DROPBOX_UID=$(id -u)" \
-e "DROPBOX_GID=$(id -g)" \
-v "/path/to/local/settings:/opt/dropbox/.dropbox" \
-v "/path/to/local/dropbox:/opt/dropbox/Dropbox" \
[...]
[image]
It is also highly recommended to pass your local timezone settings into the container. This fixes the problem
of the host being on local time zone and container defaulting to UTC
timezone. Dropbox is not checking time
zones when comparing file timestamps, leading to overwritten files and data loss.
You can pass your local timezone as an environment variable to the container: -e "TZ=Australia/Brisbane"
If you're on Linux 🐧, you can mount your /etc/timezone
and /etc/localtime
files into the container instead.
$ docker run --name=dropbox \
-v "/etc/timezone:/etc/timezone" \
-v "/etc/localtime:/etc/localtime" \
[...]
[image]
If you are on macOS or Linux, getting your current timezone and passing it into the container as an environment variable, is the simplest way.
$ docker run --name=dropbox \
-e "TZ=$(readlink /etc/localtime | sed 's#^.*/zoneinfo/##')" \
[...]
[image]
Using --net="host"
allows Dropbox to utilize local LAN sync.
$ docker run --name=dropbox \
--net="host" \
[...]
[image]
To link Dropbox to your account, check the logs of the Docker container to retrieve the Dropbox authentication URL:
$ docker logs --follow dropbox
Copy and paste the URL in a browser and login to your Dropbox account to associate the Docker container. You should see something like this:
This computer is now linked to Dropbox. Welcome [your name]"
To manage Dropbox exclusions or get a sharing link, you need to execute the dropbox
command inside the
Docker Dropbox container:
$ docker exec -it dropbox gosu dropbox dropbox [dropbox command]
For example, to get an overview of the commands possible, use help
:
$ docker exec -it dropbox gosu dropbox dropbox help
Or to see the current sync status use status
:
$ docker exec -it dropbox gosu dropbox dropbox status
-
DROPBOX_UID
If set, runs Dropbox with a custom user id. This must match the user id of the owner of the mounted files. Defaults to1000
. -
DROPBOX_GID
If set, runs Dropbox with a custom user id. This must match the group id of the owner of the mounted files. Defaults to1000
. -
DROPBOX_SKIP_UPDATE
If set totrue
, skips updating the Dropbox app on container startup. Note: This is not very reliable because the Dropbox daemon will still try to update itself even if this is set totrue
. -
POLLING_INTERVAL
Needs to be set to a positive integer value. The Dropbox daemon is polled for its status at regular intervals, which can be configured to reduce load on the system. This is the number in seconds to wait between polling the Dropbox daemon. Defaults to5
. -
SKIP_SET_PERMISSIONS
If this is set totrue
, the container skips setting the permissions on all files in the/opt/dropbox
folder in order to prevent long startup times. Note: please make sure to have correct permissions on all files before you do this! Implemented for #25. -
ENABLE_MONITORING
If this is set totrue
, an endpoint for Prometheus monitoring is enabled on port 8000. This provides the metricsdropbox_status
,dropbox_num_syncing
,dropbox_num_downloading
, anddropbox_num_uploading
, which may be useful for setting alerts to ensure that Dropbox is syncing properly and keeps itself up to date. Note this is still experimental and off by default.
-
/opt/dropbox
This represents the daemon user's home directory in the container. On the host, it will be populated with some binaries, some configuration, account settings, and other settings for Dropbox. If you don't mount this folder, your account needs to be linked every time you restart the container. -
/opt/dropbox/Dropbox
The actual Dropbox folder, containing all your synced files. Note that you may need to omit this on the first run so that Dropbox can have control to create it. Once it is created in the other volume, you can recreate the container with this volume as well.
Dropbox may fail with this error message present in logs (visible with docker logs
). If this happens, you'll need to run the container once without the /opt/dropbox/Dropbox
volume. See the notes on this above.
From Troubleshoot Dropbox syncing issues:
The Linux version of the Dropbox desktop app is limited from monitoring more than 10,000 folders by default. Anything more than that is not watched and, therefore, ignored when syncing. There's an easy fix for this. Open a terminal and enter the following:
echo fs.inotify.max_user_watches=100000 | sudo tee -a /etc/sysctl.conf; sudo sysctl -p
This command will tell your system to watch up to 100,000 folders. Once the command is entered and you enter your password, Dropbox will immediately resume syncing.
Bug reports and pull requests are welcome on GitHub at endotronic/docker-dropbox
or its close parent otherguy/docker-dropbox
.
- Alexander Graf for their work in
otherguy/docker-dropbox
- Jan Broer for the original repository
janeczku/dropbox
- Tony Pan for local timezone support (
#3
)