docker 部署 sftp

部署

1)配置 users.conf

规则:

ruby 复制代码
<username>:<passwd>:<用户id>:<用户组id>:<用户子目录>

用户子目录说明:

假设用户名为:sftpUser

  1. 用户目录:/home/sftpUser 目录的权限默认所属为 root:root;并且其他用户以及用户组只有读和执行的权限

2)当使用 sftpUser 用户登录后;默认进入的目录是 /home/sftpUser;但是 atmoz/sftp 的 chroot 会把 /home/sftpUser 当作"虚拟根目录" /

3)所以当 / 目录下没有任何目录的时候,就会出现创建目录也创建不了

users.conf 示例:

ruby 复制代码
# sftp 的用户名为:sftpUser; 密码为: 8ff$hk90NM4@oyF;
# 中间的 :: 点,没有写;就是让系统自己去分配
# 用户子目录为 upload
sftpUser:8ff$hk90NM4@oyF:::upload
sftpUser2:8ff$hk90NM4@oyF:::upload

2) 运行 sftp 容器

/app/docker/sftp/users.conf:这个 users.conf 是让 sftp 在初始化的时候创建用户

/app/docker/sftp/upload:这个是 映射的 sftp 的/home 的目录,sftp 存储都是在用户目录下,所以这里映射着所有上传的文件

bash 复制代码
docker run \
  -v /app/docker/sftp/conf/users.conf:/etc/sftp/users.conf:ro \
  -v /app/docker/sftp/upload:/home \
  -p 2222:22 -d atmoz/sftp

上传目录说明

sftpUser:8ff$hk90NM4@oyF:::upload 用户子目录为 upload ;实际目录为 /home/sftpUser/upload

那么程序上传的路径就要配置为 /upload

atmoz/sftp 的 chroot 会把 /home/sftpUser当作"虚拟根目录" /使用 sftpUser 账号登录后当然只看到 /upload 目录

验证方式:

yaml 复制代码
# sftpUser 为对应的用户名
sftp -P 2222 sftpUser@<host-ip>

测试上传

远程上传地址从 /upload 开始,因为 用户子目录为 upload(实际路径:/home/sftpUser/upload)

ini 复制代码
import paramiko

def sftp_upload(local_path, remote_path, host, port, username, password):
    # 创建SSH客户端
    ssh = paramiko.SSHClient()
    ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
    
    try:
        # 连接服务器
        ssh.connect(hostname=host, port=port, username=username, password=password)
        
        # 创建SFTP客户端
        sftp = ssh.open_sftp()
        
        # 上传文件
        sftp.put(local_path, remote_path)
        print(f"文件上传成功: {local_path} -> {remote_path}")
        
    except Exception as e:
        print(f"上传失败: {e}")
    finally:
        # 关闭连接
        if 'sftp' in locals():
            sftp.close()
        ssh.close()

# 使用示例
if __name__ == "__main__":
    # 配置信息
    host = "你的ip"
    port = 2222
    username = "sftpUser"
    password = "8ff$hk90NM4@oyF"
    
    # 文件路径
    local_file = "E://1.txt"
    # sftp 存储位置
    remote_file = "/upload/1.txt"
    
    # 执行上传
    sftp_upload(local_file, remote_file, host, port, username, password)

执行后:

相关推荐
开开心心就好9 分钟前
发票合并打印工具,多页布局设置实时预览
linux·运维·服务器·windows·pdf·harmonyos·1024程序员节
火车叼位29 分钟前
脚本伪装:让 Python 与 Node.js 像原生 Shell 命令一样运行
运维·javascript·python
迎仔1 小时前
06-存储设备运维进阶:算力中心的存储管家
运维
?re?ta?rd?ed?1 小时前
linux中的调度策略
linux·运维·服务器
全栈工程师修炼指南1 小时前
Nginx | stream content 阶段:TCP 协议四层反向代理浅析与实践
运维·网络·网络协议·tcp/ip·nginx
hweiyu001 小时前
Linux 命令:tr
linux·运维·服务器
Trouvaille ~1 小时前
【Linux】应用层协议设计实战(一):自定义协议与网络计算器
linux·运维·服务器·网络·c++·http·应用层协议
allway21 小时前
基于华为taishan200服务器、arm架构kunpeng920 cpu的虚拟化实战
linux·运维·服务器
CSCN新手听安1 小时前
【linux】高级IO,I/O多路转接之poll,接口和原理讲解,poll版本的TCP服务器
linux·运维·服务器·c++·计算机网络·高级io·poll
熊文豪1 小时前
服务器炸了才知道?Ward+cpolar让异常无处藏
运维·服务器·cpolar