在Debian Linux搭建rsync备份服务端并在windows使用客户端

作者:V君 发布于:2016-2-24 18:38 Wednesday 分类:折腾手记

和SD卡一样的尿性, U盘也是这么脆.

一直都每周手动复制一次到硬盘, 最近忙成狗偷懒每隔一两个月才复制一次.

这下好了, 赶上U盘挂掉连WinHEX读扇区都读不动, 最近个把月的东西就这样没了...


收假, 回到doge之地. 开始找法子自动备份.

咕狗一圈回来发现rsync, 搞起.


服务器当然是用XX pi,直接apt-get install rsync发现已经装有了, 点个赞继续配置.

编辑文件 /etc/rsyncd.conf

uid = root

gid = root

max connections = 2


[repo1]

  path = /path/to/your/repo1

  auth users = account1,account2,account3

  read only = false

  secrets file = /path/to/your/conf/repo1.secrets

secrets文件格式要求每行一个用冒号隔开的用户名和密码

secrets文件必须将设置权限为600


写好配置文件, 然后是启动服务 rsync rsyncd --daemon

将这个命令加到 rc.local 就可以开机启动了.


接下来是客户端了, windows 可以用 DeltaCopy 这货做客户端.

添加好profile之后右键立即执行, 首次运行会把所有文件发到服务器.

以后运行就只发修改的部分.


关于虚拟目录需要注意的地方

在默认情况下DeltaCopy会自动设置虚拟目录.

如果设置profile目录是驱动器根目录时啥问题都没有, 他就对应repo的根.

当你指定了子文件夹, 那么最后一个子文件夹名会被当做虚拟目录

你要还原也必须用同名文件夹

因此同一个repo如果指定驱动器根目录, 那么就不要再加别的文件夹进来, 不然会混乱.

如果所有的项都是子目录, 那么允许在同一个repo里. 当然你可以手动修改拟路径.


标签: linux 数据备份 rsync

评论(0) 引用(0) 浏览(1720)

通过SSH备份并压缩远程服务器上的文件

作者:V君 发布于:2015-6-23 22:43 Tuesday 分类:折腾手记

既然数据库备份了 那也顺便备份一下文件吧 

备份文件可不像备份数据库那样简单

起初想到的方法是先把远程服务器上的文件拉回本地,接着压缩,再删除

这样做也太新手了吧, 并且还增加了不少IO

于是..., 这次不咕狗了 直接发帖问, 然而 得到回复 tar|gz

立马就被打醒了 ssh远程执行脚本嘛 把输出在本地接收然后xz!

于是一脚深一脚浅的一边咕狗一边写出这样的玩意, 很新手吧 _(:з」∠)_ , 老司机请飘过.

把下面的脚本保存到一个文件比如remote-backup.sh 然后用chmod增加执行权限, 

用法: ./remote-backup.sh 用户@主机 密码 远程路径 本地路径

本地路径会自动加上tar.xz后缀

至于 REMBER CACHE SSH KEY! 的意思是, ssh的key缓存对应不同用户, 

我等新手在摆弄时极容易遇上一会可以一会不行的情况

多半是sudo执行和直接执行的差别, 

因此你需要给每个服务器用sudo ssh连接一次把key缓存起来

嗯 然后就是塞给crontab了 (=゚ω゚)=

 

#!/bin/sh

 

userAtHost="$1"

pass="$2"

remotePath="$3"

localFilename="$4"

 

if [ ! $# -eq 4 ] ;then

        echo useage: $0 \<user@host\> \<pass\> \<remotePath\> \<localFilename\>

        echo \ \ \ \  localFilename will auto add .tar.xz

        echo \ \ \ \  REMBER CACHE SSH KEY!

else

        echo exec\> sshpass -p \*\*\*\*\*\* ssh $userAtHost \"cd $remotePath \; tar -c .\" \| xz \> $localFilename.tar.xz

        sshpass -p $pass ssh $userAtHost "cd $remotePath ; tar -c ." | xz > $localFilename.tar.xz

fi

 

~

ps: 你可能需要 sudo apt-get install sshpass

标签: linux ssh 数据备份

评论(0) 引用(0) 浏览(2301)

自动备份MySQL数据库 [更新bug]

作者:V君 发布于:2015-6-23 22:32 Tuesday 分类:折腾手记

鉴于树莓派是用SD卡作为存储器, 然而SD卡是十分脆弱的, 

稍有不慎就会文件系统损坏,因此完善的备份措施是必不可少.

于是开始咕狗整个数据库的备份方法, 

嗯 mysqldump 这货只要指定数据库名称就能把整个数据库变成SQL输出来

接下来是遍历所有数据库, 还要排除不必要的系统数据库和架构数据库.

参考了咕狗来的一篇文章,按自己的需求改了下代码, 主要还是打日志 (=゚ω゚)=

依然是塞给crontab去执行

 

#!/bin/bash

 

# Add your backup dir location, password, mysql location and mysqldump location

DATE=$(date +%Y-%m-%d_%H-%M-%S)

BACKUP_DIR="/mnt/BackupStore/dbs"

MYSQL_HOST="192.168.***.***"

MYSQL_USER="root"

MYSQL_PASSWORD="********"

MYSQL=mysql

MYSQLDUMP=mysqldump

 

echo $DATE begin backup database

 

# To create a new directory into backup directory location

mkdir -p $BACKUP_DIR/$DATE

 

# get a list of databases

databases=`$MYSQL -h$MYSQL_HOST -u$MYSQL_USER -p$MYSQL_PASSWORD -e "SHOW DATABASES;"|grep -Ev "(information_schema|performance_schema|mysql)"|sed 1d`

# dump each database in separate name

for db in $databases; do

echo backing up $db

$MYSQLDUMP --force --opt --user=$MYSQL_USER -h$MYSQL_HOST -p$MYSQL_PASSWORD --databases $db | xz > "$BACKUP_DIR/$DATE/$db.sql.xz"

done

 

echo done.


update1:修正包含DataBase的数据库被排除


~

标签: 树莓派 数据库 linux 数据备份

评论(0) 引用(0) 浏览(1869)

Powered by emlog 去你妹的备案 sitemap