在Github被微软收购后,私人仓库开始免费了,拿来折腾下用来做为网站数据备份还是非常不错的,都说数据无价,一旦数据丢失便失去了所有。下面就说说 Linux 如何定时备份数据库并且上传到 Git 中的私有库中。
教程
首先你肯定需要一个Github
账号,没有的可以去注册一个,地址:https://github.com。有了账号就继续看。
配置Git SSH密钥
由于本地Git仓库和GitHub仓库之间的传输是通过SSH加密的,所以必须要让github仓库认证你SSH key,在操作之前,需要先在服务器上生成SSH key。
我们先去根目录下使用命令:
cd ~
ssh-keygen -t rsa
这里会要你命名密匙名称(这里建议使用默认名称),然后连续按几次Enter
,这时候会在/root/.ssh
文件夹生成2
个ssh
密钥,然后我们查看公钥id_rsa.pub
。
cat ~/.ssh/id_rsa.pub
查看后,再复制下公钥,然后打开Github
官网,进入https://github.com/settings/ssh/new,Title
随便填,然后Key
填入刚刚复制的密匙,最后点击Add SSH Key
添加即可。
建立私人仓库
我们需要先访问https://github.com/new,新建一个仓库用来存放备份文件,名称自己随意,记得下面一定要勾选Private
,也就是私人仓库。不然你辛辛苦苦备份的小姐姐就要被别人偷走了。
配置本地仓库
由于博主是用来备份网站,所以需要备份文件夹为/home/www.moewah.com
,也就是把该文件夹定为本地仓库,使用命令:
#进入需要备份的文件夹
cd /home/www.moewah.com
#初始化你的github仓库
git init
#关联到远程github仓库
git remote add origin [email protected]:moewah/moewah.git
关联仓库的时候,后面可以用HTTPS
链接也可以用SSH
,这里强烈建议选择SSH
,安全性很高。
初次备份
#进入备份的文件夹
cd /home/www.moewah.com
#把目录下所有文件更改状况提交到暂存区,包括增,删,改。
git add -A
#提交更改的说明,说明随意了,这里为backsite
git commit -m "backsite"
#开始推送到Github
git push -u origin master
推送的时候可能会提示The authenticity of host 'github.com' can't be established.
信息,直进yes
即可。然后可以看到仓库的备份文件了。
设置定时备份
在根目录先新建一个bash
脚本:
nano ~/gitback.sh
代码如下:
#!/bin/bash
#进入到网站根目录,记得修改为自己的站点
cd /home/xxx.com
#将数据库导入到该目录,这里以mysql为例,passwd为数据库密码,typecho为数据库名称,typecho.sql为备份的数据库文件
mysqldump -uroot -ppasswd typecho > typecho.sql
git add -A
git commit -m "backsite"
git push -u origin master
然后编辑好了后,使用ctrl+x
,y
保存退出。再测试下脚本,使用命令:
chmod a+x ~/gitbach.sh
bash ~/gitback.sh
脚本没问题的话,通过crontab
再设置为每天05:15
执行一次:
#并输出名为siteback.log的日志文件
15 05 * * * bash ~/gitback.sh >> /var/log/siteback.log 2>&1 &
最后使用crontab -l
命令查看添加成功没。成功的话,就基本上算完成了。
常见问题
如果你将本地文件夹推送到Github
失败的话,常见原因有2
种,具体如下。
1、邮件问题
报错提示:Your push would publish a private email address.
这里可能是你将你的邮件地址私密了,解决方法如下:
#方法一,如果你想一直保持私密,可以选择方法二
访问https://github.com/settings/emails,将Keep my email address private的勾去掉。
#方法二
1、访问https://github.com/settings/emails,将Block command line pushes that expose my email的勾去掉。
2、设置你的用户名和github邮箱,修改成自己的再运行命令:
git config --global user.email "[email protected]"
git config --global user.name "moewah"
2、密匙问题
报错提示:Permission denied (publickey).
大概的原因就是,你设置密匙的时候改成了其它名称,而ssh
默认只读取id_rsa
,所以会显示没权限。解决方法如下:
#方法一
进入根目录的.ssh文件夹,将你的github密匙文件,重新更名为id_rsa。
#方法二
将github密匙添加到ssh agent,比如密匙名称为github,使用命令:
ssh-agent bash
ssh-add ~/.ssh/github
3、安全问题
此脚本默认将数据库sql文件导出到网站根目录,如果你的Nginx服务器没有做限制,很容易导致文件暴露被人私自下载。
这里以军哥LNMP环境下的Nginx为例,请修改/usr/local/nginx/conf/vhost/
路径下的 www.moewah.com.conf
虚拟主机配置文件(文件路径和名称请根据自己的网站进行修改)在 server
内追加下面的内容:
if ($uri ~ ^/typecho.sql) {
return 403;
}
保存并重启nginx即可。
Apache 可以尝试在域名对应的虚拟主机配置文件中的Directory
目录权限配置内增加Files
选项来控制,比如要不允许访问 .sql 扩展名的文件,保护数据库:
<Files ~ ".sql$">
Order allow,deny
Deny from all
</Files>
然后保存并重启apache。
总结
使用该方法备份网站是个不错的选择,不过别用来备份大文件东西,比如电影什么的,听说有限制,具体多少暂时还没测试。