关于vsftp全部文章:
1、vsftp服务搭建(虚拟账号+被动访问)
2、通过公网登录vsftp服务
3、vsftp容器搭建+go开发web用户管理界面(更新于2022.02.23)
vsftp采用虚拟账号+被动访问配置
默认账号密码:company/Tenez.cn
1、磁盘划分完成
df -h
部分:
/dev/mapper/DB-DBlv 1007G 36G 921G 4% /u01
2、安装docker,配置存储磁盘
cat /usr/lib/systemd//system/docker.service |grep ExecStart
部分:
ExecStart=/usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock --graph=/u01/docker/data
部署
1、启动容器
创建vsftp容器
映射的目录根据实际情况修改,我的磁盘划分挂载位置是在/u01
,所以映射的是/u01/
目录下
docker run -id --name=vsftp --network=host --privileged=true -v /u01/vsftp/data:/ftp/data swr.ap-southeast-3.myhuaweicloud.com/softwares/vsftp:3.2 /usr/sbin/init
创建mysql容器
这里的数据库只是一个记录账号的作用,不存用户文件,没有做持久化
docker run -itd --name vsftp-mysql -p 13306:3306 -e MYSQL_ROOT_PASSWORD=password mysql:8
现在我们可以使用xftp等ftp工具,测试链接下:
ip:宿主机ip
端口号:10021
用户名:company
密码:Tenez.cn
把vsftp-web3.0.zip
安装包解压后存放到宿主机的/u01/vsftp/data
目录下
目录层级:
ls /u01/vsftp/data/vsftp-web3.0
2.sh ftp.go ftp.sql go.mod go.sum nohup.out pages statics templates
把backupdata.zip
安装包解压后存放到宿主机的/u01/vsftp/data
目录下
目录层级:
ls /u01/vsftp/data/backupdata/
backup.sh
进入到vsftp
容器内部,检查crond定时任务,每30分钟将打包备份一次容器内部/ftp/company
目录下的所有文件,7天滚动保留
docker exec -it vsftp bash
crontab -l
30 * * * * sh /ftp/data/backupdata/backup.sh >> /ftp/data/backupdata/backupdata.log 2>&1
进入到vsftp
容器内部,运行前端go程序
运行之前需要修改数据库连接信息,把ip修改成实际数据库ip
cd /ftp/data/vsftp-web3.0
cat ftp.go |grep mysql
db, err := gorm.Open("mysql", "root:password@(172.xx.xx.xx:13306)/db?charset=utf8mb4&parseTime=True&loc=Local")
db, err := gorm.Open("mysql", "root:password@(172.xx.xx.xx:13306)/db?charset=utf8mb4&parseTime=True&loc=Local")
db, err := gorm.Open("mysql", "root:password@(172.xx.xx.xx:13306)/db?charset=utf8mb4&parseTime=True&loc=Local")
nohup go run ftp.go &
现在浏览器访问:http://172.xx.xx.xx:9090
将得到如下界面
使用容器部署
容器名称 | 映射目录 | 端口号 | 服务 |
---|---|---|---|
vsftp | /u01/vsftp/data:/ftp/data | 主机网络。主端口号9090,10021 | ftp服务,用于上传下载文件 |
vsftp-mysql | 无 | 13306:3306 | 数据引擎服务,用于存放ftp账号密码信息 |
*注:以下提到的路径全部为容器内部路径
账号说明账号名称 | 密码 | 权限 |
---|---|---|
company | Tenez.cn | 可以查看所有ftp账户数据 |
FTP管理:http://172.xx.xx.xx:9090,可以增删账号(只适合用于内网)
数据存放说明全部ftp用户数据路径:/ftp/company/
单个ftp账号数据路径:/ftp/company/账号名称
ftp关于账号密码信息:vsftp-mysql 容器中的db数据库ftpuserlist表
数据备份说明每30分钟会备份所有账号数据到/ftp/data/backupdata目录,滚动保留7天
数据删除说明1、当一个ftp账号被删除后,账号内的数据将不会被清除,重新创建相同账号后将恢复数据
2、当ftp账号被删除后,已创建成功的ftp链接将不会被强制中断,仍然可以传输数据
数据限制说明1、每个账号最大速率5m/s
2、最大建立连接400个(指定了端口号范围10180-10580)
3、每个账号之间相互看不到数据(除了管理员账号)
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)