阿里云centos7服务器怎么备份mysql数据库

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了阿里云centos7服务器怎么备份mysql数据库相关的知识,希望对你有一定的参考价值。

参考技术A 在服务器上安装一个phpmyadmin,就可以通过网页的方式进行管理mysql
或者是直接备份mysql的数据文件夹
centos系统的话,数据文件夹在mysql安装目录下的var目录
直接将此目录下的文件copy一份到本地,就可以了。

Linux(CentOS7)设置自动备份数据库到阿里云OSS

环境:阿里云服务器CentOS7.4 + MySQL5.6

基本思路:

1、编写shell脚本,备份数据库到指定目录下

2、编写Python脚本,把文件上传到OSS

3、把shell脚本和Python脚本添加Linux的crontab定时器,设置定时执行

 

首先,环境要配置好,Python环境,centos 7 自带Python,一般可以直接使用

查看Python版本:python -V

技术分享图片  

在创建一个目录/opt/backMySQL/xxx,在目录/opt/backMySQL下编写一个shell脚本backup.sh

 1 #!/bin/sh
 2 cd /opt/backMySQL/xxx
 3 echo "You are in /opt/backMySQL/xxx"
 4 
 5 Now=$(date +"%Y-%m-%d")
 6 File=fileName-$Now.sql
 7 mysqldump -urooot -ppassword databaseName > $File
 8 echo "Your database backup successfully completed"
 9 #删除昨天的文件
10 SevenDays=$(date -d -1day +"%Y-%m-%d")
11 
12 if [ -f /opt/backMySQL/xxx/fileName-$SevenDays.sql  ]
13 then
14  rm -rf /opt/backMySQL/xxx/fileName-$SevenDays.sql
15  echo "You have delete 1 tays ago bak file"
16 else
17  echo "1 days ago bak file not exist"
18 fi

把第6、12、14行中的fileName替换成你想要的文件名,第7行换成数据库的用户和密码

执行这个脚本,就可以把数据库备份到/opt/backMySQL/xxx目录下了

再编写一个Python脚本backupToOSS.py

# -I- coding: utf-8 -*-
import os
import oss2

path = /opt/backMySQL/naner_zhongkong/

auth = oss2.Auth(您的AccessKeyId,您的AccessKeySecret)
bucket = oss2.Bucket(auth,您的Endpoint,您的Bucket名)

#获取目录下的所有文件
f_list = os.listdir(path)

for i in f_list:
    # os.path.splitext():分离文件名与扩展名
    if os.path.splitext(i)[1] == .sql:
        fileName = i
        bucket.put_object_from_file(remote.txt‘,content of object‘)    
注意:Python语言缩进有规定语法,不能随意缩进,记住缩进增加只用在以:结束的语句之后,缩进4个空格,而之后必须恢复到之前的缩进格式

执行:python backupToOSS.py

可以把文件上传到OSS上了

设置定时器
crontab -e
技术分享图片
表示在每天1:05执行backup.sh、每天1:15执行backupToOSS.py
 
 
定时具体设置参考
 
Linux定时执行Python脚本

 

以上是关于阿里云centos7服务器怎么备份mysql数据库的主要内容,如果未能解决你的问题,请参考以下文章

如何将阿里云的mysql(RDS)数据备份到本地

如何将数据库备份到阿里云的OSS上

阿里云centos7.3下安装mysql5.7.19

阿里云的centos7.2版怎么安装mysql

阿里云服务器CentOS7.3上通过Docker安装MySQL

如何将阿里云的数据库备份RDS文件在本地恢复