本篇为备份篇。

因为装的东西不多,所以需要备份的只有mysql和wordpress的文件夹。

备份mysql

  1. mysql备份命令

    使用mysqldump命令,格式如下:

    # 这是格式
    mysqldump -u${username} -p${dbrootpwd} --databases ${DBname} > ${DumpFile}
    # 这是例子
    mysqldump -uroot -proot --databases wordpress > /home/backup.sql

    使用${}代表的是变量,请自行替换

    username:数据库用户名

    dbrootpwd:数据库用户的密码

    DBname:需要备份的数据库

    DumpFile:输出的文件路径+文件名

  2. 搭配docker使用

    因为mysql使用的是docker安装的,服务器所在的Centos中是没有mysql的相关命令的,执行命令需要到mysql的docker容器中。

    # 这是格式
    docker exec -it ${container} ${sqlCmd}
    # 这是例子
    docker exec -it 123321 mysqldump -uroot -proot --databases wordpress > /home/backup.sql

    使用${}代表的是变量,请自行替换

    container:docker容器的别名或id

    sqlCmd:需要执行的备份命令

  3. 备份脚本

    此脚本是基于oneinstack修改的

    逻辑是:

    • mysqldump生成xxx.sql文件
    • 压缩xxx.sql为xxx.tgz
    • 删除xxx.sql和旧的压缩文件

    新建db_bk.sh文件,以下是内容:

    #!/bin/bash
    # 引用同目录下的options.conf文件
    . ./options.conf # 传递参数
    DBname=$1
    # 日志
    LogFile=${backup_dir}/db.log
    # 临时文件
    DumpFile=${backup_dir}/DB_${DBname}_$(date +%Y%m%d_%H).sql
    # 新的压缩文件
    NewFile=${backup_dir}/DB_${DBname}_$(date +%Y%m%d_%H).tgz
    # 旧的压缩文件
    OldFile=${backup_dir}/DB_${DBname}_$(date +%Y%m%d --date="${expired_days} days ago")*.tgz
    # 备份目录不存在则创建
    [ ! -e "${backup_dir}" ] && mkdir -p ${backup_dir} # 使用mysql的show databases判断数据库是否存在
    DB_tmp=`docker exec -it mysql mysql -uroot -p${dbrootpwd} -e "show databases\G" | grep ${DBname}`
    [ -z "${DB_tmp}" ] && { echo "[${DBname}] not exist" >> ${LogFile} ; exit 1 ; } # 删除旧的压缩文件
    if [ -n "`ls ${OldFile} 2>/dev/null`" ]; then
    rm -f ${OldFile}
    echo "[${OldFile}] Delete Old File Success" >> ${LogFile}
    else
    echo "[${OldFile}] Delete Old Backup File" >> ${LogFile}
    fi # 判断新的压缩文件是否已存在
    if [ -e "${NewFile}" ]; then
    echo "[${NewFile}] The Backup File is exists, Can't Backup" >> ${LogFile}
    else
    # 生成临时备份文件
    docker exec -it mysql mysqldump -uroot -p${dbrootpwd} --databases ${DBname} > ${DumpFile}
    # 进入到备份目录
    pushd ${backup_dir} > /dev/null
    # 压缩临时文件
    tar czf ${NewFile} ${DumpFile##*/} >> ${LogFile} 2>&1
    # 输出日志
    echo "[${NewFile}] Backup success ">> ${LogFile}
    # 删除临时文件
    rm -f ${DumpFile}
    # 退回之前的目录
    popd > /dev/null
    fi

    以下是options.conf文件的部分内容

    # mysql相关
    backup_dir=/home/backup
    dbrootpwd='root'
    expired_days=5
  4. 执行脚本

    # 这是格式
    ./db_bk.sh #{DBname}
    # 这是例子,数据库名为wordpress
    ./db_bk.sh wordpress

备份wordpress

  1. 编写脚本

    备份wordpress其实只需要备份wordpress所在的html目录即可。

    所以脚本也很简单,就是压缩相关目录,删除旧的压缩文件。

    新建website_bk.sh文件,以下是内容:

    #!/bin/bash
    
    . ./options.conf
    
    # 变量定义
    WebSite=$1
    LogFile=${backup_dir}/web.log
    NewFile=${backup_dir}/Web_${WebSite}_$(date +%Y%m%d_%H).tgz
    OldFile=${backup_dir}/Web_${WebSite}_$(date +%Y%m%d --date="${expired_days} days ago")*.tgz
    # 备份文件夹不存在则创建
    [ ! -e "${backup_dir}" ] && mkdir -p ${backup_dir}
    # 需要备份的目录不存在则退出
    [ ! -e "${wwwroot_dir}/${WebSite}" ] && { echo "[${wwwroot_dir}/${WebSite}] not exist" >> ${LogFile} ; exit 1 ; } # 判断大小,如果小于1024m
    if [ `du -sm "${wwwroot_dir}/${WebSite}" | awk '{print $1}'` -lt 1024 ]; then
    if [ -n "`ls ${OldFile} 2>/dev/null`" ]; then
    rm -f ${OldFile}
    echo "[${OldFile}] Delete Old File Success" >> ${LogFile}
    else
    echo "[${OldFile}] Delete Old Backup File" >> ${LogFile}
    fi # 如果文件已存在,则不重复备份
    if [ -e "${NewFile}" ]; then
    echo "[${NewFile}] The Backup File is exists, Can't Backup" >> ${LogFile}
    else
    pushd ${wwwroot_dir} > /dev/null
    tar czf ${NewFile} ./${WebSite} >> ${LogFile} 2>&1
    echo "[${NewFile}] Backup success ">> ${LogFile}
    popd > /dev/null
    fi
    else
    rsync -crazP --delete ${wwwroot_dir}/${WebSite} ${backup_dir}
    fi

    以下是options.conf文件的部分内容

    backup_dir=/home/backup
    wwwroot_dir=/home/docker-workspace/wordpress
    website_name=html
    expired_days=5
  2. 执行脚本

    ./website_bk.sh html

备份OSS

使用的是ossutil

以下是相关命令:

# 上传文件
./ossutil64 cp -f file_url cloud_url
# 删除命令
./ossutil64 rm oss://bucketname[/prefix]

定时执行

备份的脚本需要定时执行,这里用的是crontab。

  1. 安装

    一般centos都有安装crontab,检查是否安装:

    rpm -qa | grep crontab

    安装命令:

    yum -y install vixie-cronyum -y install crontabs
  2. 使用

    crontab -e进入编辑页或者vi /etc/crontab

    区别在于:前者配置是针对当前用户的,后者是针对系统的

    添加执行脚本的定时任务:

    # 这是格式
    ${cron} ${cmd}
    # 这是例子
    0 0 * * 1 /home/xxx.sh > /dev/null 2>&1

    使用${}代表的是变量,请自行替换

    cron:cron表达式,注意,crontab所使用的cron表达式,与java使用的cron有所区别,是不包含秒的,看 /etc/crontab的注释就知道了

    cmd:需要执行的命令

从零开始在centos搭建博客(二)的更多相关文章

  1. 从零开始在centos搭建博客(一)

    本篇为安装篇. 基于centos 7.9,大部分东西使用docker安装. 软件列表:docker + mysql + wordpress 安装docker yum install -y yum-ut ...

  2. hexo零基础搭建博客系列(一)

    关于其他搭建 [hexo4快速搭建博客(二)更换主题](https://blog.csdn.net/weixin_41800884/article/details/103750634)[hexo4快速 ...

  3. hexo搭建博客系列(三)美化主题

    文章目录 其他搭建 1. 添加博客图标 2. 鼠标点击特效(二选一) 2.1 红心特效 2.2 爆炸烟花 3. 设置头像 4. 侧边栏社交小图标设置 5. 文章末尾的标签图标修改 6. 访问量统计 7 ...

  4. 手把手教从零开始在GitHub上使用Hexo搭建博客教程(二)-Hexo参数设置

    前言 前文手把手教从零开始在GitHub上使用Hexo搭建博客教程(一)-附GitHub注册及配置介绍了github注册.git相关设置以及hexo基本操作. 本文主要介绍一下hexo的常用参数设置. ...

  5. 手把手教从零开始在GitHub上使用Hexo搭建博客教程(四)-使用Travis自动部署Hexo(2)

    前言 前面一篇文章介绍了Travis自动部署Hexo的常规使用教程,也是个人比较推荐的方法. 前文最后也提到了在Windows系统中可能会有一些小问题,为了在Windows系统中也可以实现使用Trav ...

  6. 手把手教从零开始在GitHub上使用Hexo搭建博客教程(三)-使用Travis自动部署Hexo(1)

    前言 前面两篇文章介绍了在github上使用hexo搭建博客的基本环境和hexo相关参数设置等. 基于目前,博客基本上是可以完美运行了. 但是,有一点是不太好,就是源码同步问题,如果在不同的电脑上写文 ...

  7. 手把手教从零开始在GitHub上使用Hexo搭建博客教程(一)-附GitHub注册及配置

    前言 有朋友问了我关于博客系统搭建相关的问题,由于是做开发相关的工作,我给他推荐的是使用github的gh-pages服务搭建个人博客. 推荐理由: 免费:github提供gh-pages服务是免费的 ...

  8. flask tutorial => make a blog :) flask 搭建博客系统从零开始!

    please follow the tutorial from the official site :) http://flask.pocoo.org/docs/ You could download ...

  9. Django搭建博客网站(二)

    Django搭建自己的博客网站(二) 这里主要讲构建系统数据库Model. Django搭建博客网站(一) model 目前就只提供一个文章model和一个文章分类标签model,在post/mode ...

随机推荐

  1. IIS方式部署项目发布上线

    VS2019如何把项目部署和发布 这里演示:通过IIS文件publish的方式部署到Windows本地服务器上 第一步(安装IIS) 1.在自己电脑上搜索Windows功能里的[启用或关闭Window ...

  2. (Bezier)贝塞尔曲在路径规划的运用

    前言 之前被安排了活,一个局部区域机器运动控制的工作,大致是一个机器位于一个极限区域时候,机器要进入一个特殊的机制,使得机器可以安全的走出来.其中用到了bezier曲线进行优化路径,今天写一下,正好也 ...

  3. Python技法:用argparse模块解析命令行选项

    1. 用argparse模块解析命令行选项 我们在上一篇博客<Linux:可执行程序的Shell传参格式规范>中介绍了Linux系统Shell命令行下可执行程序应该遵守的传参规范(包括了各 ...

  4. 109_Power Pivot客户ABC(帕累托)分析度量值写法(非计算列)

    博客:www.jiaopengzi.com 焦棚子的文章目录 请点击下载附件 1.背景 客户ABC分析,一般的套路是在计算列中把客户ABC分类,便于后续维度使用.今天用度量值的方式写一个ABC的分类. ...

  5. Similarity calculation

    推荐算法入门(相似度计算方法大全) 一.协同过滤算法简介 在推荐系统的众多方法之中,基于用户的协同过滤是诞最早的,原理也比较简单.基于协同过滤的推荐算法被广泛的运用在推荐系统中,比如影视推荐.猜你喜欢 ...

  6. numpy中shape的部分解释

    转载自:https://blog.csdn.net/qq_28618765/article/details/78081959和https://www.jianshu.com/p/e083512e4f4 ...

  7. TL,你是如何管理项目风险的?

    沙包和打伞的故事 美国在1961年到1972年组织实施的一系列载人登月飞行任务.目的是实现载人登月飞行和人对月球的实地考察,为载人行星飞行和探测进行技术准备,它是世界航天史上具有划时代意义的一项成就. ...

  8. vue根据后端菜单自动生成路由(动态路由)

    vue根据后端菜单自动生成路由(动态路由) router.js import Vue from 'vue' import Router from 'vue-router' import store f ...

  9. VMware 虚拟机安装CentOS镜像详细步骤

    CentOS目前官网提供的下载版本有6.7.8,最新的版本为8,不过个人推荐CentOS 7 的版本,因为相比较于最新版本,版本7更加地稳定.而相比于版本6,版本7新增了很多的功能.CentOS 7 ...

  10. C语言学习之我见-strncat()可调整的字符串拼接函数

    strncat()函数,用于两个字符串的拼接. (1)函数原型 char * strncat(char * Dest,const char * Source,size_t _Count)` (2)头文 ...