Uh oh!
There was an error while loading.Please reload this page.
- Notifications
You must be signed in to change notification settings - Fork326
stilliard/docker-pure-ftpd
Folders and files
| Name | Name | Last commit message | Last commit date | |
|---|---|---|---|---|
Repository files navigation
https://hub.docker.com/r/stilliard/pure-ftpd/
Check out ourbasic example workflow & ourslightly more advanced workflow with tls & an auto created user.
Pull down latest version with docker:
docker pull stilliard/pure-ftpd
Often needing to run assudo, e.g.sudo docker pull stilliard/pure-ftpd
If you want to make changes, my advice is to either change the run command when running it or extend this image to make any changes rather than forking the project.
This is because rebuilding the entire docker image via a fork can bevery slow as it rebuilds the entire pure-ftpd package from source.
To change the command run on start you could use thecommand: option if usingdocker-compose, or withdocker run directly you could use:
docker run --rm -d --name ftpd_server -p 21:21 -p 30000-30009:30000-30009 stilliard/pure-ftpd bash /run.sh -c 30 -C 10 -l puredb:/etc/pure-ftpd/pureftpd.pdb -E -j -R -P localhost -p 30000:30059To extend it you can create a new project with aDOCKERFILE like so:
FROM stilliard/pure-ftpd# e.g. you could change the defult command run:CMD /run.sh -c 30 -C 10 -l puredb:/etc/pure-ftpd/pureftpd.pdb -E -j -R -P $PUBLICHOST -p 30000:30059Then you can build your own image,docker build --rm -t my-pure-ftp ., where my-pure-ftp is the name you want to build as
docker run -d --name ftpd_server -p 21:21 -p 30000-30009:30000-30009 -e "PUBLICHOST=localhost" stilliard/pure-ftpd
Or for your own image, replace stilliard/pure-ftpd with the name you built it with, e.g. my-pure-ftp
You can also pass ADDED_FLAGS as an env variable to add additional options such as --tls to the pure-ftpd command.
e.g.-e "ADDED_FLAGS=--tls=2"
docker exec -it ftpd_server /bin/bash
To create a user on the ftp container, use the following environment variables:FTP_USER_NAME,FTP_USER_PASS andFTP_USER_HOME.
FTP_USER_HOME is the root directory of the new user.
Example usage:
docker run -e FTP_USER_NAME=bob -e FTP_USER_PASS=12345 -e FTP_USER_HOME=/home/bob stilliard/pure-ftpd
If you wish to set theUID &GID of the FTP user, use theFTP_USER_UID &FTP_USER_GID environment variables.
To use passive ports in a different range (eg:10000-10009), use the following setup:
docker run -e FTP_PASSIVE_PORTS=10000:10009 --expose=10000-10009 -p 21:21 -p 10000-10009:10000-10009
You may need the--expose= option, because default passive ports exposed are30000 to30009.
Create an ftp user:e.g. bob with chroot access only to /home/ftpusers/bob
pure-pw useradd bob -f /etc/pure-ftpd/passwd/pureftpd.passwd -m -u ftpuser -d /home/ftpusers/bob
No restart should be needed.
If you have any trouble with volume permissions due to theuid orgid of the created user you can change the-u flag for the uid you would like to use and/or specify-g with the group id as well. For more information see issue#35.
More info on usage here:https://download.pureftpd.org/pure-ftpd/doc/README.Virtual-Users
From the host machine:
ftp -p localhost 21
Docker compose can help you simplify the orchestration of your containers.
We have a simpleexample of the docker compose.
& here's amore detailed example using wordpress with ftp using this image.
By default we set 5 max clients at once, but you can increase this by using the following environment variableFTP_MAX_CLIENTS, e.g. toFTP_MAX_CLIENTS=50 and then also increasing the number of public ports opened fromFTP_PASSIVE_PORTS=30000:30009FTP_PASSIVE_PORTS=30000:30099. You'll also want to open those ports when running docker run.In addition you can specify the maximum connections per ip by setting the environment variableFTP_MAX_CONNECTIONS. By default the value is 5.
https://linux.die.net/man/8/pure-ftpd
To get verbose logs add the following to yourdocker run command:
-e "ADDED_FLAGS=-d -d"Then the logs will be redirected to the stdout of the container and captured by the docker log collector.You can watch them withdocker logs -f ftpd_server
Or, if you exec into the container you could watch over the log withtail -f /var/log/messages
Want a transfer log file? add the following to yourdocker run command:
-e"ADDED_FLAGS=-O w3c:/var/log/pure-ftpd/transfer.log"Latest versions
latest- latest working versionjessie-latest- latest but will always remain on debian jessiehardened- latest +added security defaults
Previous version before tags were introduced
wheezy-1.0.36- incase you want to roll back to before we started using debian jessie
Specific pure-ftpd versions
jessie-1.x.x- jessie + specific versions, e.g. jessie-1.0.36hardened-1.x.x- hardened + specific versions
Check the tags on github for available versions, feel free to submit issues and/or pull requests for newer versions
Usage of specific tags:sudo docker pull stilliard/pure-ftpd:hardened-1.0.36
An arm64 build is also available here:https://hub.docker.com/r/zhabba/pure-ftpd-arm64- Thanks @zhabba
/usr/sbin/pure-ftpd # path to pure-ftpd executable-c 5 # --maxclientsnumber (no more than 5 people at once)-C 5 # --maxclientsperip (no more than 5 requests from the same ip)-l puredb:/etc/pure-ftpd/pureftpd.pdb # --login (login file for virtual users)-E # --noanonymous (only real users)-j # --createhomedir (auto create home directory if it doesnt already exist)-R # --nochmod (prevent usage of the CHMOD command)-P $PUBLICHOST # IP/Host setting for PASV support, passed in your the PUBLICHOST env var-p 30000:30009 # PASV port range (10 ports for 5 max clients)-tls 1 # Enables optional TLS supportFor more information please seeman pure-ftpd, or visit:https://www.pureftpd.org/
This is for PASV support, please see:#5 PASV not fun :)
There are a few spots onto which you can mount a docker volume to configure theserver and persist uploaded data. It's recommended to use them in production.
/home/ftpusers/The ftp's data volume (by convention)./etc/pure-ftpd/passwdA directory containing the singlepureftpd.passwdfile which contains the user database (i.e., all virtual users, theirpasswords and their home directories). This is read on startup of thecontainer and updated by thepure-pw useradd -f /etc/pure- ftpd/passwd/pureftpd.passwd ...command./etc/ssl/private/A directory containing a singlepure-ftpd.pemfilewith the server's SSL certificates for TLS support. Optional TLS isautomatically enabled when the container finds this file on startup.
You may want to keep your user database through the successive image builds. It is possible with Docker volumes.
Create a named volume:
docker volume create --name my-db-volumeSpecify it when running the container:
docker run -d --name ftpd_server -p 21:21 -p 30000-30009:30000-30009 -e "PUBLICHOST=localhost" -v my-db-volume:/etc/pure-ftpd/passwd stilliard/pure-ftpdWhen an user is added, you need to use the password file which is in the volume:
pure-pw useradd bob -f /etc/pure-ftpd/passwd/pureftpd.passwd -m -u ftpuser -d /home/ftpusers/bob(Thanks to the -m option, you don't need to callpure-pw mkdb with this syntax).
e.g. to change the password for user "bob":
pure-pw passwd bob -f /etc/pure-ftpd/passwd/pureftpd.passwd -mDevelopment (via git clone)
# Clone the repogit clone https://github.com/stilliard/docker-pure-ftpd.gitcd docker-pure-ftpd# Build the imagemake build# Run container in background:make run# enter a bash shell inside the container:make enter# test that it's all working withmaketest
If you want to enable tls (for ftps connections), you need to have a validcertificate. You can get one from one of the certificate authorities that you'llfind when googling this topic. The certificate (containing private key andcertificate) needs to be at:
/etc/ssl/private/pure-ftpd.pemUse docker volumes to get the certificate there at runtime. The container willautomatically enable optional TLS when it detect the file at this location.
You can also self-sign a certificate, which is certainly the easiest way tostart out. Self signed certificates come with certain drawbacks, but it mightbe better to have a self signed one than none at all.
Here's how to create a self-signed certificate from within the container:
mkdir -p /etc/ssl/privateopenssl dhparam -out /etc/ssl/private/pure-ftpd-dhparams.pem 2048openssl req -x509 -nodes -newkey rsa:2048 -sha256 -keyout \ /etc/ssl/private/pure-ftpd.pem \ -out /etc/ssl/private/pure-ftpd.pemchmod 600 /etc/ssl/private/*.pemIfADDED_FLAGS contains--tls (e.g. --tls=1 or --tls=2) and file/etc/ssl/private/pure-ftpd.pem does not existsit is possible to generate self-signed certificate ifTLS_CN,TLS_ORG andTLS_C are set.
Keep in mind that if no volume is set for/etc/ssl/private/ directory generatedcertificates won't be persisted and new ones will be generated on each start.
You can also pass-e "TLS_USE_DSAPRAM=true" for faster generated certificatesthough this option is not recommended for production.
Please check out theTLS docs here.
Let's Encrypt provides two separate files for certificate and keyfile. ThePure-FTPd TLS encryption documentation suggests to simply concat them into one file.So you can simply provide the Let's Encrypt cert/etc/ssl/private/pure-ftpd-cert.pem and key/etc/ssl/private/pure-ftpd-key.pem via Docker Volumes and let them get auto-concatenated into/etc/ssl/private/pure-ftpd.pem.Or concat them manually with
cat /etc/letsencrypt/live/<your_server>/cert.pem /etc/letsencrypt/live/<your_server>/privkey.pem> pure-ftpd.pem
Thanks for the help on stackoverflow with this!https://stackoverflow.com/questions/23930167/installing-pure-ftpd-in-docker-debian-wheezy-error-421
Also thanks to all the awesome contributors that have made this project amazing!https://github.com/stilliard/docker-pure-ftpd/graphs/contributors
You can also help support the development of this project with coffee power:
About
Docker Pure-ftpd Server
Topics
Resources
License
Code of conduct
Contributing
Uh oh!
There was an error while loading.Please reload this page.
Stars
Watchers
Forks
Sponsor this project
Uh oh!
There was an error while loading.Please reload this page.
