sql备份的时候改变名称_git备份wordpress

git备份wordpress

git备份wordpress​www.wolfdan.cn

登陆网站目录初始化git仓库 并且 与远程仓库对接上传

首先使用ssh工具(Xshell或者putty等)登入之后进入到自己wordpress网站的根目录

然后初始化仓库

git init

在远程coding或gitee上面新建私有仓库上面,土豪可以在在GitHub上面建私有仓库

7ddf115bcb6e605bcfb1a173ac03db93.png

把自己网站所在的vps的公钥放到coding或gitee的ssh密钥管理里面

添加公钥

839651c4108add6572feb937ff5eb8d3.png

把本地仓库文件传到远程仓库

# 一定要把下面的ssh路径改成你的ssh路径啊,然后origin也可以改成其他名字(对应本地对远程的一种称呼)
git remote add origin git@git.dev.tencent.com:username/wordpreessbackup.git
# git 本地远程推送三连击
git add --all
git commit -m "你的注释"
git push -u origin master

272b047573bb27be66bfb2c4e9f3d4b6.png

我们想把数据库也备份怎么办?

那就干啊,直接在网站根目录下面执行数据库备份,先来看看数据库备份通用的语句

# hostname直接是本机,所以我们不用写
# username是我们的数据库的用户名
# mypwd是我们的数据库密码
# databasename就是要备份的数据名字
mysqldump -hhostname -uusername -pmypwd databasename > /path to backup/bakname.sql

# 所以我的语句应该是如下,你们也可以看着改动,这些数据的信息可以登陆宝塔面板看,或者找到你以前建网站的时候保存的一些重要信息
mysqldump -uwolfdanDB -ppassword wolfdanDB > wolfdanDB2019_7_6.sql

然后就成功了,再次推送到远程即可

b1afd12f3382667bed0583fa6e1c11bb.png

如果你出了一些问题可以看这里,否则可以直接看下一步:

注: 其实wolfdan我是先犯了下面的错误然后才有上面一条龙正确的,所以下面的这些错误修正意见基本上是说把上面步骤完善好,233 - 没有生成密钥且不会生成密钥的朋友可以看我以前发的文章,虽然当时写得比较水,但还是能看图解决问题的 - 更新仓库发现没有访问权限则检查自己有没有做上面 生成密钥添加公钥

9f7f5767b6d819522b4c0bac844b165e.png

- 上传文件被告知src refspec master does not match any,我们使用git status检查发现是没有git add --all -- > 也就是说我们要先本地commit

f695110564f4d5f3e1cc0c252c4ddd84.png

写bash代码,并且使用crontab定时执行备份 并定时 清理一个月前备份的sql文件(节省内存呀)

如果每次都手动执行,难免会有忘记的时候,而且就算你博闻强识,你不嫌花时间吗?我们的追求当然是全 自动化当然现在不想折腾了可以保存页面下次来继续折腾

写出backup.sh文件--> 当然要把一些变量改成你的 变量值

#!/bin/bash

#this is where
path=/home/www/wolfdan.cn

#数据库名称
sqlName=wolfdanDB

#用户名称
userName=wolfdanDB

#用户密码
userPasswd=root

#当前时间
DATE=`date +"%Y-%m-%d"`

#Log存放路径
LogFile=$path/backupLog/$DATE.log

#新建日志文件
touch $LogFile

#追加日志到日志文件
echo "wolfdan.cn git auto backup to coding server, start at  $(date +"%Y-%m-%d %H:%M:%S")" >>  $LogFile
echo "---------------------------------------------------------------------------" >> $LogFile


# 原本我以为执行bash会自动把目录切换,直到crond自动检测bash的log文件,并在log文件中告知我没有 .git文件,我才知道要自己手动cd
cd $path

mysqldump -u$userName -p$userPasswd $sqlName > wolfdanDB$DATE.sql

git add --all
git commit -m "`date '+%Y-%m-%d %H:%M:%S'`"
git push origin master

echo -e  "---Have a nice day in www.wolfdan.cn----welcome to contact me by VX:wolf_dan2--------n">> $LogFile

41e29b1f6307f3fbbda8fd33e8c92b00.png

赋予backup.sh执行权限并且测试一下

chmod 777 backup.sh

sh backup.sh

我自己之前bash没写好出现的一些问题

bash变量赋值不能为空

4326d1757e2197a418ed86f7ab34c6dd.png

数据库名称和密码什么的不能出错

使用crontab定时

vim /etc/crontab 没有vim可以sudo apt-get install vim(Debian/Ubuntu用户)-sudo yum install vim(CentOS用户)下载或者暂时用 vi 代替

在注释下面添加你要的任务就行

SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root

# For details see man 4 crontabs

# Example of job definition:
# .---------------- minute (0 - 59)
# |  .------------- hour (0 - 23)
# |  |  .---------- day of month (1 - 31)
# |  |  |  .------- month (1 - 12) OR jan,feb,mar,apr ...
# |  |  |  |  .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat
# |  |  |  |  |
# *  *  *  *  * user-name  command to be executed

# 我的wolfdan.cn 每周备份
0 3 * * 0 root /home/www/wolfdan.cn/backup.sh

# 自动删除一个月前的sql,下周git的时候会同步到云端删除
0 4 * * 0 root /home/www/wolfdan.cn/auto_rm.sh

重载配置并启让配置生效

#重新加载cron配置文件
sudo /usr/sbin/service cron reload
#重启cron服务
sudo /usr/sbin/service cron restart

crontab测试和auto_rm.sh放一起了,所以不妨继续往下看

写auto_rm.sh文件

编码

bash文件一定要小心写cpp时的习惯性变量赋值的空格!

#!/bin/bash

# 路径
Dir=/home/www/wolfdan.cn

#当前时间
DATE=`date +"%Y-%m-%d"`

#Log存放位置
LogFile=$Dir/backupLog/$DATE.log

#新建日志文件(其实backup的脚本已经建立了,不过建立同名的会直接输出到那里,所以没有关系)
touch $LogFile

#追加日志信息
echo "wolfdan,cn auto_rm .sql file a monoth ago. Start at $(date +"%Y-%m-%d %H:%M:%S")" >> $LogFile
echo "------------------------------------------------------------------------------" >> $LogFile

# 查找备份路径下,超过30天 且文件后缀为.sql 的 sql备份文件 然后删除
find $Dir -type f -mtime +30 -name '*.sql*' -exec rm {} ;


echo -e "----Done!Welcome to www.wolfdan.cn and add my VX:wolf_dan2---have a nice day!-------n" >> $LogFile

赋予权限并且测试执行

chmod 777 auto_rm.sh

# 这里我们先创建1些一个月前的文件
touch -t 201905011230 test1.sql
touch -t 201906011230 test2.sql
touch -t 201907011230 test3.sql
# 查看目录下文件  当然也可以用   ll 详细查看带时间的文件信息
ls
#  然后 测试
sh auto_rm.sh
# 再次查看  当然也可以用   ll 详细查看带时间的文件信息
ls

0789f3b0bd8f452665b2b63b69a954cd.png

crontab定时测试

细心用户可能看到我定时文件里面以及写上了auto_rm.sh任务了,没有写上的朋友快去写上吧

先修改crontabe配置vim /etc/contab

假设我们现在是11:15,那么我们把日,月,周全打成*号,然后min设置成17,hour设置成11,这样就定时在2mins后了,然后auto_rm设置比backup多1mins

SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root

# For details see man 4 crontabs

# Example of job definition:
# .---------------- minute (0 - 59)
# |  .------------- hour (0 - 23)
# |  |  .---------- day of month (1 - 31)
# |  |  |  .------- month (1 - 12) OR jan,feb,mar,apr ...
# |  |  |  |  .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat
# |  |  |  |  |
# *  *  *  *  * user-name  command to be executed

# 我的wolfdan.cn 每周备份
17 11 * * * root /home/www/wolfdan.cn/backup.sh

# 自动删除一个月前的sql,下周git的时候会同步到云端删除
18  11 * * root /home/www/wolfdan.cn/auto_rm.sh

当然要重载并重启服务啦啦啦

#重新加载cron配置文件
sudo /usr/sbin/service cron reload
#重启cron服务
sudo /usr/sbin/service cron restart

当然我们又要创建一个月前的测试文件

# 这里我们先创建1些一个月前的文件
touch -t 201905011230 test1.sql
touch -t 201906011230 test2.sql
touch -t 201907011230 test3.sql

然后在11:18的时候去ls查看是否还有test1.sql 和 test2.sql

4098c298c0be0b5fc91ff1ed4df6a932.png

以及输出日志

0a622e88a18b6b03855a12f55090c573.png

输出日志是以前的

参考的大佬文章:

[大佬文章]

知乎删了我三次这篇文章,然后现在是第四次.. 仔细阅读了知乎的一些用户守则,如果再不过,知乎就拜拜了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值