概述
之前测试写的一个脚本,主要是为了实现FTP自动上传和下载文件。大家可以参考下:
基础环境配置
[root@pxzxdm01 ~]# useradd -d /home/ftp1 ftp1 [root@pxzxdm01 ~]# passwd ftp1 (密码123456)[root@pxzxdm01 ~]# usermod -s /sbin/nologin ftp1 (限定用户ftp1只能ftp登陆)
登录FTP实现下载文件功能
FTP服务器:xx.xx.xx.A
FTP路径:/home/ftp1/down
本地路径(xx.xx.xx.B): /home/scripts/down
用户名密码:ftp1/123456
1、批量下载脚本
#从FTP上批量下载文件到本地 #!/bin/sh ftp -v -n xx.xx.xx.A<<EOF user ftp1 123456 binary cd down lcd /home/scripts/down prompt mget * bye EOF echo "download from ftp successfully"
2、下载单个文件脚本
#从FTP上下载单文件到本地 #!/bin/sh ftp -v -n xx.xx.xx.A<<EOF user ftp1 123456 binary cd down lcd /home/scripts/down prompt #get down.txt,并改名成note.txt get down.txt note.txt bye EOF echo "download from ftp successfully"
登录FTP实现上传文件功能
FTP服务器:xx.xx.xx.A
FTP路径:/home/ftp1/up
本地路径: /home/scripts/up
将文件从本地传到FTP的脚本如下:
1、批量上传脚本代码
#从本地向FTP批量上传文档 #!/bin/sh ftp -v -n xx.xx.xx.A<<EOF user ftp1 123456 binary hash cd up lcd /home/scripts/up prompt mput * bye #here document EOF echo "commit to ftp successfully"
2、上传单个文件脚本
#从本地向FTP上传单个文档 #!/bin/sh PUTFILE=up.txt ftp -v -n xx.xx.xx.A<<EOF user ftp1 123456 binary cd up lcd /home/scripts/up prompt put $PUTFILE bye #here document EOF echo "commit to ftp successfully"
自动上传文件
1、十分钟内/home/scripts/up变动的文件内容统一上传/home/ftp1/up下脚本
#!/bin/sh filename=`find /home/scripts/up -type f -mmin -10|awk -F '/' '{print $NF}'` for i in $filename; do ftp -v -n xx.xx.xx.A<<-EOF user ftp1 123456 binary cd up lcd /home/scripts/up prompt put $i bye EOF echo "commit to ftp successfully" done
2、二十分钟内/home/scripts/up下变动的文件上传/home/ftp1/up下对应的文件夹下脚本
路径:find /home/scripts/up -type f -mmin -120 -exec dirname {} ;
#!/bin/sh #切换到上传根目录下 cd /home/scripts/up file=`find ./ -type f -mmin -20` for i in $file; do #获取文件名 filename=`find $i|awk -F '/' '{print $NF}'` #获取路径名 dirname=`find $i -exec dirname {} ;` ftp -v -n xx.xx.xx.A<<-EOF user ftp1 123456 binary cd up cd $dirname pwd lcd $dirname prompt pwd put $filename bye EOF echo "commit to ftp successfully" done
注意:sftp可以通过put -r 递归创建目录,ftp不行
上面是之前分开写的几个脚本,这个还是看需求吧,整体难度不大,大家可以自己测试下。后面会分享更多关于devops和DBA方面内容,感兴趣的朋友可以关注下!!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至2705686032@qq.com 举报,一经查实,本站将立刻删除。原文转载: 原文出处: