1
0
mirror of https://github.com/vimagick/dockerfiles.git synced 2024-11-28 09:08:50 +02:00
dockerfiles/pure-ftpd
2016-05-01 09:06:20 +08:00
..
docker-compose.yml use relative local path for volumes 2015-09-02 11:52:53 +08:00
Dockerfile switch to new domain: easypi.info 2016-05-01 09:06:20 +08:00
README.md update 2015-06-10 01:12:43 +08:00

Pure-FTPd is a free (BSD), secure, production-quality and standard-conformant FTP server. It doesn't provide useless bells and whistles, but focuses on efficiency and ease of use. It provides simple answers to common needs, plus unique useful features for personal users as well as hosting providers.

~/fig/pureftpd/docker-compose.yml

pureftpd:
  image: vimagick/pure-ftpd
  ports:
    - "21:21"
  volumes:
    - ftpuser:/home/ftpuser
    - pure-ftpd:/etc/pure-ftpd
  privileged: true
  restart: always

We only need to expose port 21 to accept client ftp connection. Pure-FTPd will open random port to accept client ftp-data connection. At this time, host machine is a router for DNAT.

server

$ cd ~/fig/pureftpd/
$ fig up -d
$ fig ps
$ docker exec -it pureftpd_pureftpd_1 bash
>>> pure-pw useradd kev -u ftpuser -d /home/ftpuser/kev -t 1024 -T 1024 -y 1 -m
>>> pure-pw list
>>> pure-pw show kev
>>> pure-pw passwd kev -m
>>> pure-pw userdel kev -m
>>> pure-ftpwho -n
>>> exit
$ tree -F
.
├── docker-compose.yml
├── ftpuser/
│   └── kev/
│       └── file.txt
└── pure-ftpd/
    ├── pureftpd.passwd
    └── pureftpd.pdb

client

$ ftp remote-server
Name: kev
Password: ******
ftp> !touch file.txt
ftp> !ls
ftp> put file.txt
ftp> !rm file.txt
ftp> get file.txt
ftp> del file.txt
ftp> ls
ftp> bye