Python實現騰訊雲CDB備份檔案自動上傳到COS
一、背景
需求:目前遇到的客戶需求為將騰訊雲CDB備份檔案自動上傳到騰訊雲COS內,在此拋磚引玉,還有很多類似的需求均可以採用此類方法解決,線下IDC資料檔案備份至雲端COS內,或根據檔案下載地址url將檔案上傳至COS內。
思路:首先獲取到CDB的備份下載url,透過COS的API上傳檔案,大佬如有更好的方法歡迎一塊討論。
二、技術細節
COS:COS有API同時有SDK,這就很方便我們來透過Python對COS進行各類操作,COS SDK for Python
CDB:CDB有API但是CDB的查詢備份下載沒有對應的SDK,此時只能透過API來進行獲取,騰訊雲API的簽名很複雜,要進行:構造引數字典->對dict排序->拼接sign->對sign編碼->拼接完成最終url->完成呼叫,簽名方法,查詢備份API
requirements:
cos-python-sdk-v5==1.5.2
requests==2.19.1
tencentcloud-sdk-python==3.0.15
urllib3==1.23
檔案目錄結構
Python實現騰訊雲CDB備份檔案自動上傳到COS
三、程式碼
github地址
3.1 配置檔案
# auth:kaliarch
# func:將騰訊雲cdb備份檔案上傳至cos制定的bucket內
# python version:python3+
# cos version:v5
#
# 騰訊雲公共資訊配置段
[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例項id
cdb_instanceid = cdb-rqaxxxxx
# cdb所在地域
cdb_region = ap-shanghai
# cdb 日誌備份型別,coldbackup(冷備),binlog(二進位制日誌)和slowlog_day(慢查詢日誌)
cdb_bak_type = coldbackup
# 日誌檔案資訊配置段
[loginfo]
#日誌檔案目錄名稱
logdir_name = rds_to_cos
#日誌檔名稱
logfile_name = rdsbak_to_cos.log
3.2 CDB API核心操作程式碼
#構建字典
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
單獨執行此模組可以得到以下資訊:
Python實現騰訊雲CDB備份檔案自動上傳到COS
3.3 COS SDK核心操作程式碼
#根據檔案大小自動選擇簡單上傳或分塊上傳,分塊上傳具備斷點續傳功能
with open(filename, 'wb') as localfile:
localfile.write(requests.request('get', url).content)
# 進行上傳
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 日誌記錄核心程式碼
#建立目錄
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
四、測試結果
獲取CDB下載連結
Python實現騰訊雲CDB備份檔案自動上傳到COS
完成上傳檢視COS檔案
Python實現騰訊雲CDB備份檔案自動上傳到COS
五、總結
最佳化:可以後期透過配合定時任務完成自動化任務
擴充套件:源端:不僅僅侷限於CDB備份檔案,對於隨便下載url,均可以上傳到COS內。終端:終端也不僅侷限於騰訊雲COS,此思路方法也可用於其他雲平臺如阿里OSS,亞馬遜Amazon S3,百度雲BOS 等。
©著作權歸作者所有:來自51CTO部落格作者KaliArch的原創作品,如需轉載,請註明出處,否則將追究法律責任
每一份讚賞源於懂得
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/2730/viewspace-2821706/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 將 nuxt 打包檔案上傳到騰訊雲 cosUX
- Grails3檔案上傳到騰訊COS(OSS)AIS3
- Spring webflux 整合 Mendmix 上傳元件上傳檔案到阿里雲騰訊雲SpringWebUX元件阿里
- 騰訊cos安裝,上傳圖片實際使用
- 貝殼專案,上傳到cos
- 容災備份 | 看我使用Powershell操作FTP進行資料檔案自動上傳備份FTP
- Tp3如何實現本地視訊檔案上傳到七牛雲
- gitlab自動定時備份檔案,備份失敗傳送郵件Gitlab
- Laravel 騰訊雲 Cos 物件儲存 sdk 使用示例 上傳圖片Laravel物件
- Laravel 使用騰訊雲 cos 進行圖片上傳使用詳解Laravel
- 判斷是否有檔案並設定理性,上傳到cos
- hyperf oss/cos 檔案上傳擴充套件套件
- python+selenium+autoit實現檔案上傳Python
- Python介面自動化——檔案上傳/下載介面Python
- struts動態多檔案上傳實現
- NodeJS+formidable實現檔案上傳加自動重新命名NodeJSORM
- 使用CukeTest建立指令碼自動化備份檔案到網盤指令碼
- shell 備份檔案指令碼+自動清理指令碼
- Python 搭配 Automator 上傳檔案到 GithubPythonGithub
- 七牛雲+外掛實現wordpress自動備份資料庫及檔案(寶塔皮膚)資料庫
- uniapp小程式上傳圖片到騰訊雲APP
- ajax實現檔案上傳
- PHP實現單檔案、多檔案上傳 封裝 物件導向實現檔案上傳PHP封裝物件
- oracle 控制檔案及引數檔案何時自動備份Oracle
- 自動共享和上傳檔案到相容的託管站點
- 檔案上傳原理和實現
- 使用Spring實現上傳檔案Spring
- Spring mvc檔案上傳實現SpringMVC
- HttpFileCollection 實現多檔案上傳HTTP
- Java實現定時備份檔案教程Java
- 騰訊雲CDB的AI技術實踐:CDBTuneAI
- Laravel 使用騰訊雲 cos 儲存物件Laravel物件
- 通過配置檔案(.htaccess)實現檔案上傳
- Ubuntu 每日技巧- 自動備份Ubuntu 14.04到Box雲存Ubuntu
- 使用java的MultipartFile實現layui官網檔案上傳實現全部示例,java檔案上傳JavaUI
- 騰訊雲ClickHouse如何實現自動化的資料均衡?
- iPic 新版:上傳檔案至七牛、又拍、阿里雲、騰訊雲、Amazon S3阿里S3
- python保留7天備份檔案Python