Python實(shí)現(xiàn)騰訊云CDB備份文件自動(dòng)上傳到COS

一评雌、背景

  • 需求:目前遇到的客戶需求為將騰訊云CDB備份文件自動(dòng)上傳到騰訊云COS內(nèi),再次拋磚引玉,還有很多類似的需求均可以采用此類方法解決,線下IDC數(shù)據(jù)文件備份至云端COS內(nèi)川背,或根據(jù)文件下載地址url將文件上傳至COS內(nèi)。
  • 思路:首先獲取到CDB的備份下載url蛤袒,通過(guò)COS的API上傳文件熄云,大佬如有更好的方法歡迎一塊討論。

二妙真、技術(shù)細(xì)節(jié)

  • COS:COS有API同時(shí)有SDK皱碘,這就很方便我們來(lái)通過(guò)Python對(duì)COS進(jìn)行各類操作,COS SDK for Python

  • CDB:CDB有API但是CDB的查詢備份下載沒(méi)有對(duì)應(yīng)的SDK隐孽,此時(shí)只能通過(guò)API來(lái)進(jìn)行獲取,騰訊云API的簽名很復(fù)雜健蕊,要進(jìn)行:構(gòu)造參數(shù)字典->對(duì)dict排序->拼接sign->對(duì)sign編碼->拼接完成最終url->完成調(diào)用菱阵,簽名方法查詢備份API

  • requirements:

cos-python-sdk-v5==1.5.2
requests==2.19.1
tencentcloud-sdk-python==3.0.15
urllib3==1.23
  • 文件目錄結(jié)構(gòu)


    image

三缩功、代碼

github地址

3.1 配置文件

# auth:kaliarch
# func:將騰訊云cdb備份文件上傳至cos制定的bucket內(nèi)
# python version:python3+
# cos version:v5
# https://console.cloud.tencent.com/cos5/bucket

# 騰訊云公共信息配置段
[common]
# 騰訊云 secretid
secret_id = AKIDMdjegcmoGxxxxxxxxxxxxxxxxxxxx
# 騰訊云 secretkey
secret_key = d5MRL4VoxyvlQvxxxxxxxxxxxxxx

# 騰訊云cos信息配置段
[cosinfo]
# cos所在地域
cos_region = ap-chengdu

# 騰訊云bucket名字(cos v5 bucket名稱組成:bucket+appid)
bucket_name = xuel-test-bucket-125396xxxx

# 騰訊云cdb信息配置段
[cdbinfo]
# cdb實(shí)例id
cdb_instanceid = cdb-rqaxxxxx

# cdb所在地域
cdb_region = ap-shanghai

# cdb 日志備份類型晴及,coldbackup(冷備),binlog(二進(jìn)制日志)和slowlog_day(慢查詢?nèi)罩荆?cdb_bak_type = coldbackup

# 日志文件信息配置段
[loginfo]
#日志文件目錄名稱
logdir_name = rds_to_cos
#日志文件名稱
logfile_name = rdsbak_to_cos.log

3.2 CDB API核心操作代碼

#構(gòu)建字典
keydict = {
        'Action': self.cdb_action,
        'Timestamp': str(int(time.time())),
        'Nonce': str(int(random.random() * 1000)),
        'Region': self.cdb_region,
        'SecretId': self.secret_id,
        # 'SignatureMethod': SignatureMethod,
        'cdbInstanceId': self.cdb_instanceid,
        'type': self.cdb_bak_type
}
#字典排序
sorted(zip(keydict.keys(), keydict.values()))
#字符串拼接
sign_str_init = ''
for value in sortlist:
        sign_str_init += value[0] + '=' + value[1] + '&'
sign_str = 'GET' + self.cdb_api_url + sign_str_init[:-1]
return sign_str, sign_str_init
#獲取簽名串并編碼
secretkey = self.secret_key
signature = bytes(sign_str, encoding='utf-8')
secretkey = bytes(secretkey, encoding='utf-8')
my_sign = hmac.new(secretkey, signature, hashlib.sha1).digest()
my_sign = base64.b64encode(my_sign)
parse.quote(my_sign)
#獲取最終url
result_url = 'https://' + self.cdb_api_url + sign_str + '&Signature=' + result_sign

單獨(dú)運(yùn)行此模塊可以得到以下信息:


image

3.3 COS SDK核心操作代碼

#根據(jù)文件大小自動(dòng)選擇簡(jiǎn)單上傳或分塊上傳嫡锌,分塊上傳具備斷點(diǎn)續(xù)傳功能
with open(filename, 'wb') as localfile:
        localfile.write(requests.request('get', url).content)
# 進(jìn)行上傳
response = cos_client.upload_file(
        Bucket=self.bucket_name,
        LocalFilePath=filename,
        Key=filename,
        PartSize=partsize,
        MAXThread=maxthread
)
# 刪除本地文件
if os.path.exists(filename):
        os.remove(filename)

3.4 日志記錄核心代碼

#創(chuàng)建目錄
def create_dir(self):
        _LOGDIR = os.path.join(os.path.dirname(__file__), self.logdir_name)
        _TIME = time.strftime('%Y-%m-%d', time.gmtime()) + '-'
        _LOGNAME = _TIME + self.logfile_name
        LOGFILENAME = os.path.join(_LOGDIR, _LOGNAME)
        if not os.path.exists(_LOGDIR):
                os.mkdir(_LOGDIR)
        return LOGFILENAME
#定義日志文件
def create_logger(self, logfilename):
        logger = logging.getLogger()
        logger.setLevel(logging.INFO)
        handler = logging.FileHandler(logfilename)
        handler.setLevel(logging.INFO)
        formater = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
        handler.setFormatter(formater)
        logger.addHandler(handler)
        return logger

四虑稼、測(cè)試結(jié)果

獲取CDB下載鏈接


image

完成上傳查看COS文件


image

五、總結(jié)

  • 優(yōu)化:可以后期通過(guò)配合定時(shí)任務(wù)完成自動(dòng)化任務(wù)
  • 擴(kuò)展:源端:不僅僅局限于CDB備份文件势木,對(duì)于隨便下載url蛛倦,均可以上傳到COS內(nèi)。終端:終端也不僅局限于騰訊云COS啦桌,此思路方法也可用于其他云平臺(tái)如阿里OSS,亞馬遜Amazon S3,百度云BOS 等溯壶。
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市甫男,隨后出現(xiàn)的幾起案子且改,更是在濱河造成了極大的恐慌,老刑警劉巖板驳,帶你破解...
    沈念sama閱讀 212,542評(píng)論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件又跛,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡若治,警方通過(guò)查閱死者的電腦和手機(jī)慨蓝,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,596評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門感混,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人菌仁,你說(shuō)我怎么就攤上這事浩习。” “怎么了济丘?”我有些...
    開(kāi)封第一講書(shū)人閱讀 158,021評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵谱秽,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我摹迷,道長(zhǎng)疟赊,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,682評(píng)論 1 284
  • 正文 為了忘掉前任峡碉,我火速辦了婚禮近哟,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘鲫寄。我一直安慰自己吉执,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,792評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布地来。 她就那樣靜靜地躺著戳玫,像睡著了一般。 火紅的嫁衣襯著肌膚如雪未斑。 梳的紋絲不亂的頭發(fā)上咕宿,一...
    開(kāi)封第一講書(shū)人閱讀 49,985評(píng)論 1 291
  • 那天,我揣著相機(jī)與錄音蜡秽,去河邊找鬼府阀。 笑死,一個(gè)胖子當(dāng)著我的面吹牛芽突,可吹牛的內(nèi)容都是我干的试浙。 我是一名探鬼主播,決...
    沈念sama閱讀 39,107評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼寞蚌,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼川队!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起睬澡,我...
    開(kāi)封第一講書(shū)人閱讀 37,845評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤固额,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后煞聪,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體斗躏,經(jīng)...
    沈念sama閱讀 44,299評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,612評(píng)論 2 327
  • 正文 我和宋清朗相戀三年昔脯,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了啄糙。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片笛臣。...
    茶點(diǎn)故事閱讀 38,747評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖隧饼,靈堂內(nèi)的尸體忽然破棺而出沈堡,到底是詐尸還是另有隱情,我是刑警寧澤燕雁,帶...
    沈念sama閱讀 34,441評(píng)論 4 333
  • 正文 年R本政府宣布诞丽,位于F島的核電站,受9級(jí)特大地震影響拐格,放射性物質(zhì)發(fā)生泄漏僧免。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,072評(píng)論 3 317
  • 文/蒙蒙 一捏浊、第九天 我趴在偏房一處隱蔽的房頂上張望懂衩。 院中可真熱鬧,春花似錦金踪、人聲如沸浊洞。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,828評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)法希。三九已至,卻和暖如春姐军,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背尖淘。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,069評(píng)論 1 267
  • 我被黑心中介騙來(lái)泰國(guó)打工奕锌, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人村生。 一個(gè)月前我還...
    沈念sama閱讀 46,545評(píng)論 2 362
  • 正文 我出身青樓惊暴,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親趁桃。 傳聞我的和親對(duì)象是個(gè)殘疾皇子辽话,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,658評(píng)論 2 350

推薦閱讀更多精彩內(nèi)容