问题:现在项目中每天都有从其它各个系统发过来的数据文件(存放在/var/data目录下,以.txt结尾),虽然很久以前的文件很少用到,占用了很多空间,却不能删除。于是,想把一个月以前的文件都压缩了传到备份服务器上。目前想到的实现方式有FTP和NFS两种。


具体实现步骤如下:
1. 找到一个月以前的数据文件,然后压缩;
2. 把压缩好的文件上传到备份服务器。此处有2种途径:a.通过ftp上传; b.mount备份到NFS服务器;
3. 上传成功后删除数据文件;


1、ftp实现远程备份的完整shell
[root@toughhou ftp]# cat ftp_bakup.sh 
#!/bin/bash
cd /var/data

#获取备份时间
BAKUP_DATE=$(date +%Y%m%d)

#找出满足条件(30天以前创建,以.txt结尾)的数据文件,并压缩
find ./ -mtime +30 -name "*.txt" -exec tar -cvf $BAKUP_DATE.tar {} \;

#以非交谈模式登陆,进入到存放备份文件的目录(/home/tough/ftp),进入到本地数据文件目录(/var/data),上传所有*.tar文件,最后退出ftp
ftp -n 192.168.0.100 << EOF
user tough tough
bin
lcd /var/data
prompt
mput *.tar
bye
EOF

#进入到本地数据文件目录,删除30天以前修改过的数据文件及压缩文件
cd /var/data
find /var/data -mtime +30 -name "*.txt" -exec rm -rf {} \;
find /var/data -name "*.tar" -exec rm -rf {} \;


2、NFS实现远程备份完整shell
[root@toughhou ftp]# cat nfs_bakup.sh 
#!/bin/bash
cd /var/data

#获取备份时间
BAKUP_DATE=$(date +%Y%m%d)

#找出满足条件(30天以前创建,以.txt结尾)的数据文件,并压缩
find ./ -mtime +30 -name "*.txt" -exec tar -cvf $BAKUP_DATE.tar {} \;

#将NFS服务器的192.168.0.100:/var/nfs挂载到本机的/mnt/remote目录下,通过cp命令备份*.tar到远程
mount -t nfs 192.168.0.100:/var/nfs /mnt/remote
cp *.tar /mnt/remote

#备份完成后卸载远程nfs目录(用完后卸载以免给NFS服务过多压力)
unmount /mnt/remote

#进入到本地数据文件目录,删除30天以前修改过的数据文件及压缩文件
cd /var/data
find /var/data -mtime +30 -name "*.txt" -exec rm -rf {} \;
find /var/data -name "*.tar" -exec rm -rf {} \;


3、FTP和NFS远程备份比较
nfs使用UDP协议,效率相对较高,它的代码都是集成在内核里的,而且为性能做了很多优化。但如果做远程备份的话,可能会出现mount不上的问题。
ftp使用TCP协议,更可靠,但性能稍差点。


关于Linux下ftp服务器安装可以参考:Linux下vsftp服务器—上传、下载

关于Linux下NFS服务器安装可以参考:Fedora 17安装NFS​

Linux远程备份—ftp方式、NFS方式的更多相关文章

  1. Linux文件共享服务 FTP,NFS 和 Samba

    Linux 系统中,存储设主要有下面几种: DAS DAS 指 Direct Attached Storage,即直连附加存储,这种设备直接连接到计算机主板总线上,计算机将其识别为一个块设备,例如常见 ...

  2. Linux笔记③(ftp、nfs、ssh服务器搭建)

    1.ftp服务器搭建(利用vsftpd这个工具) 作用:文件的上传和下载 服务器端: 修改配置文件,配置文件目录:/etc/vsftpd.conf ,修改里面的允许匿名访问.指定匿名访问目录等操作,根 ...

  3. Linux 远程和本地的一些解决方式

     有的小伙伴想Linux 远程登录 两台机器同一时候root登录.事实上能够同一时候多个用户的. Linux是多用户的多任务系统,能够同一时候多个用户登录到系统,也能够一个用户通过不同终端登录到一个系 ...

  4. Linux操作系统备份之三:通过二进制拷贝(dd)方式实现Linux操作系统数据的备份

    前面有两篇文章,<Linux操作系统备份之一:使用LVM快照实现Linux操作系统数据的在线备份>和<Linux操作系统备份之二:通过tar拷贝分区实现Linux操作数据的在线备份& ...

  5. CentOS Linux自动备份MySQL数据库到远程FTP服务器并删除指定日期前的备份Shell脚本

    说明: 我这里要把MySQL数据库存放目录/var/lib/mysql下面的pw85数据库备份到/home/mysql_data里面,并且保存为mysqldata_bak_2011_11_03.tar ...

  6. 向linux服务器上传下载文件方式收集

    向linux服务器上传下载文件方式收集 1. scp [优点]简单方便,安全可靠:支持限速参数[缺点]不支持排除目录[用法] scp就是secure copy,是用来进行远程文件拷贝的.数据传输使用 ...

  7. mini2440 uboot使用nfs方式引导内核,文件系统

    mini2440 uboot使用nfs方式引导内核,文件系统 成于坚持,败于止步 看了一段时间的u-boot了,到今天才真正完全实现u-boot引导内核和文件系统,顺利开机,在此记录完整过程 1.首先 ...

  8. 【RMAN】Oracle中如何备份控制文件?备份控制文件的方式有哪几种?

    真题1. 如何备份控制文件?备份控制文件的方式有哪几种? 答案:备份控制文件的方式有多种. ① 备份控制文件可以在线进行: SQL> ALTER DATABASE BACKUP CONTROLF ...

  9. mysql备份的4种方式

    mysql备份的4种方式 转载自:https://www.cnblogs.com/SQL888/p/5751631.html 总结: 备份方法 备份速度 恢复速度 便捷性 功能 一般用于 cp 快 快 ...

随机推荐

  1. 转:android git开源项目列表

    1. 知乎的合集说明 https://www.zhihu.com/question/19804692 2. http://p.codekk.com/

  2. java-分页之页面分页

    import java.util.ArrayList; import java.util.List; /** * * @author cheney * * @date Aug 31, 2012 */ ...

  3. 关于CSS的一些总结

    通过对CSS基础一天的学习以及练习,觉得自己以前还是蛮无知的,一直以为CSS样式是别人写好的,自己只需要像导包一样拿过来用就可以.直到自己认真学了之后才直到是什么样的.自己如果不去敲代码感觉永远都学不 ...

  4. Ehcache(2.9.x) - API Developer Guide, Cache Exception Handlers

    About Exception Handlers By default, most cache operations will propagate a runtime CacheException o ...

  5. SQL<>0查询不到NUll的值

    这几天遇到这样一个问题,sql中写<>0,刚好某个记录是NULL,道理上是满足<>0的啊,可是就是抽不出来,关于这个问题,到处找了点资料,算是这里 写一个总结出来. 用java ...

  6. 动态加载JS代码

    到处查资料研究js动态脚本的加载,找到以下7种方法,总有一种适合你! 首先我们需要一个被加载的js文件,我在一个固定文件夹下创建了一个package.js,打开后在里面写一个方法functionOne ...

  7. ORACLE多表查询优化

    ORACLE有个高速缓冲的概念,这个高速缓冲就是存放执行过的SQL语句,那oracle在执行sql语句的时候要做很多工作,例如解析sql语句,估算索引利用率,绑定变量,读取数据块等等这些操作.假设高速 ...

  8. IOS UI 笔记整理回顾

    注意手势会冒泡上抛,一个view没有实现的手势,如果父类view有实现,父视图就处理,如果不想让父视图处理,就把本视图添加到底层window上 setMasksToBounds:YES imageVi ...

  9. 4月8日学习笔记(js基础)

    <script>标签放在<body>和<head> 放在 <head></head> 里的会比放在 <body></bod ...

  10. [zz]pg_hba.conf 一种安全地配置策略

    PostgreSQL默认只监听本地端口,用netstat -tuln只会看到“tcp 127.0.0.1:5432 LISTEN”.修改postgresql.conf中的listen_address= ...