Small and flexible docker image with vsftpd server with tls
I think upstream has made it more complicated than it needs to be since this commit and I'm not merging its commits anymore, although I cherry-pick some of them when I see fit.
https://github.com/delfer/docker-alpine-ftp-server/commit/fbf9afd9368d63a225e093bae227fa878de46b2c
Also for future reference this is the PR of this commit: delfer#36
FOr further discussion about this you can use this issue.
docker run -d \
-p 21:21 \
-p 21000-21010:21000-21010 \
-e USERS="one|1234" \
-e ADDRESS=ftp.site.domain \
quay.io/aminvakil/alpine-ftp-server-tls
Environment variables:
USERS
- space and|
separated list (optional, default:alpineftp|alpineftp
)- format
name1|password1|[folder1][|uid1] name2|password2|[folder2][|uid2]
- format
ADDRESS
- external address to which clients can connect for passive ports (optional, should resolve to ftp server ip address)MIN_PORT
- minimum port number to be used for passive connections (optional, default21000
)MAX_PORT
- maximum port number to be used for passive connections (optional, default21010
)
user|password foo|bar|/home/foo
user|password|/home/user/dir|10000
user|password||10000
Do not use this certificate in your production server, you should generate your own certificate using this command
openssl req -x509 -nodes -days 7300 -newkey rsa:2048 -keyout vsftpd.pem -out vsftpd.pem
The image gets big if we add openssl and generate certificate inside container, but it will be easy on host to generate a new certificate.