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

如何将数据库备份到阿里云的OSS上,第1张

第一步:将我们数据库备份到某目录下,注明时间:

运行备份脚本(注意在备份目录下,我的在/home/dbback/下)

查看目录是否生成备份文件,心细的同学可能发现我这个mysqldump没有指定用户名和密码,为啥我运行的时候费用输入密码呢?莫着急,马上为你揭晓答案,因为mysql56后(具体版本编号不记得了),如果你把密码写到脚本里,运行会有警告,告诉你不要把密码写到脚本里,会有危险,那我的小伙伴该怎么办呢,官方给了解决方案,期望你是配置到mycnf文件中,所以,现在打开你的mycnf,加入如下字段:

有了以上这两条,运行脚本时就不会在提示要输入密码了,马上测试下,看是否成功,如果没问题,我们进入下一步。

第二步:如何自动备份到oss中,开始前我们要做两件事,

1、登录阿里云控制台,点右上“管理控制台”,然后点左上“产品与服务”,在第二列中点击“对象存储OSS”,如果没开通就要开通,如果开通了直接点击右上的“新建bucket”,来创建一个bucket,记住buket的名字。(注:其实通过api也是可以直接创建bucket的,因为这个 *** 作不多,所以我就用控制台来创建了,降低理解的难度。)

2、开始写上传脚本,因为要导入oss的sdk,所以要下安装下,比较简单,跟安装其他python包没啥区别,解压进入目录,然后运行python setuppy install 就安装完毕了,接下来看我们如何使用它,全部代码如下:

#!/usr/bin/python env

#autor:glacier

#date:2015-11-16

import os,ospath,time

import operator

import time

from ossoss_api import

prefix = '/home/dbback'

logtime = timestrftime(timectime())

#filelist = [ file for file in oslistdir(ospathdirname(ospathabspath(__file__))) if ospathisfile(file) ]

filelist = [ file for file in oslistdir(prefix) if ospathisfile(prefix + '/' + file) ]

def get_time(filename):

ft = osstat(filename)

return ftst_ctime

#def get_max():

# flist = []

# for file in filelist:

# flistappend(osstat(file)st_ctime)

# return max(flist)

def get_dist():

d = {}

for file in filelist:

d[file] = get_time(prefix + '/' + file)

return d

if __name__ == '__main__':

#maxtime = get_max()

d = get_dist()

#dic= sorted(diteritems(), key=lambda d:d[1], reverse = True)

upfile = max(diteritems(), key=operatoritemgetter(1))[0]

endpoint = "your aliyun endpoint"

accessKeyId, accessKeySecret="your accessKeyId","your accessKeySecret "

oss = OssAPI(endpoint, accessKeyId, accessKeySecret)

res = ossput_object_from_file("bucketname",upfile,prefix + '/' + upfile)

if resstatus != 200:

with open('/var/log/dbbacklog', 'a+') as f:

fwrite(logtime + ' back failed' + '\n')

我们接下来分析下脚本内容,其中脚本中注释的行都不用看,是我编写过程中测试用的,最开始我们设定了备份文件的目录和记录日志的时间,然后生成了一个备份目录所有文件的列表(列表其实不是最好的方式,我是用最简单的方式了,因为文件多了,列表会慢),然后定义了两个函数,get_time()函数是获取文件的创建时间戳,get_dist()函数是获取文件名和时间戳的字典,主函数部分比较难理解的根据字典value排序获得文件名了,diteritems()获得字典中的每个key,value对,key指定了一个函数,operatoritemgetter(1)表示用value来排序(因为就两个元素,key 是0,value就是1了),就是时间戳,排序完后返回key,最后的[0]做了这个工作,脚本其它部分的内容我就不多说了,都是很常见的用法,没什么难于理解的,好,脚本就介绍到这里,接下来进入我们最后一步。

第三步:将脚本写入crontab中,具体什么时候执行,就根据大家各自业务不同来设置了,没什么特别的。

是会收费的,具体规则如下:

数据管理DMS导出行数按量付费说明:

1、针对免费版用户,每个用户每个自然日通过DMS导出的行数上限:20万,超过限制不允许导出。

2、针对高级版用户,每个用户每个自然日通过DMS导出的行数上限:1000万,超过限制按照3元/1000万计费。

3、每个用户每个自然日导出行数,以导出结束时间所在自然日计算行数,例如:用户购买了高级版,在实例A上导出行数400万,在实例B上导出行数700万,则该用户导出行数1100万。

4、针对免费版用户,每个自然日首个超过上限的任务暂时允许导出,后续会做限制,超过上限后当天无法再导出数据。

oracle数据库导出:exp用户名/密码@数据库标识file=D:文件名dmpgrants=nlog=D:文件名txt

Sql数据库导出,通过 *** 作界面,选中数据库,右键,导出,根据提示 *** 作即可

安装一个phpmyadmin的数据库管理软件,导出sql脚本,然后登录RDS管理面板,导入或执行SQL脚本即可,记住使用推荐码 TZ2DHZ 新开ECS或RDS是可以打90折的。

SQL

SERVER

可以搜索下

相关备份信息

MYSQL

导出

只需要把对应的数据库文件备份即可

Oracle

导出

需要exp

用户名

将数据库TEST完全导出,用户名system

密码manager

导出到D:\daochudmp中

 exp

system/manager@TEST

file=d:\daochudmp

full=y

购买阿里云服务器,可以联系我们优惠一些哦。另外免费提供数据搬家迁移。这样子专业的事情交给我们做,简单高效一些。

关闭现在网站(删除掉解析) ,检查域名所有人是否和备案主体一致,不一致需要先过户域名,一致的话,进行下一步

进行网站备案。

等待备案通过后,即可恢复使用。

备案期间,域名由于没有备案号码不可以访问,可以使用阿里云的IP进行临时访问。

以上就是关于如何将数据库备份到阿里云的OSS上全部的内容,包括:如何将数据库备份到阿里云的OSS上、阿里云数据库规定每天导出20万行,超出会收费吗、如何将数据库中的表导出等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://www.outofmemory.cn/sjk/9512207.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-29
下一篇 2023-04-29

发表评论

登录后才能评论

评论列表(0条)

保存