• Python:腾讯云-轻量应用服务器-实现自动快照


    Python:腾讯云-轻量应用服务器-实现自动快照 – WhiteNight's Site

    先说一下配置情况:轻量应用服务器+一块系统盘。我没钱加盘,所以不知道多块盘的情况下这个脚本还能不能用。

    官方文档给的代码已经很齐全了,只需要做点补充就能直接用。

    至于为什么要写这么个脚本?主要是轻量应用服务器的快照配额就两个,每次备份快照都是-删快照-新建快照这么个流程。而且如果你和我一样每周甚至每天都要备份个快照,那每次备份快照都要登陆,然后点这点那的,还是蛮麻烦的。所以不如写个自动化脚本,一条命令搞定快照。

    密钥

    小心使用

    API访问密钥链接:https://console.cloud.tencent.com/cam/capi

    考虑到密钥实际上相当于“登陆”,泄漏密钥和把账号拱手送人没多大区别,所以这东西还是小心保管比较好。

    获取快照列表

    传id和key

    这块官方文档都给全了,只需要做些小修改就行。

    考虑到我们只需要获取快照列表,所以我删去了一些用不上的代码。又考虑到直接在代码中保存id和key不太安全,所以我选择通过外部传参数的方式去给出id和key。

    同时或者client的时候需要指定Region,Region参数的说明如下。

    用logging纯属个人兴趣了,直接用print也行。

    Python

    1. def parse():
    2. parser = argparse.ArgumentParser('TencentCloud_Lighthouse_AutoSnapshot',description='腾讯云lighthouse自动快照脚本')
    3. parser.add_argument('--id',help='密钥ID')
    4. parser.add_argument('--key',help='密钥KEY')
    5. parser.add_argument('--server_id',help='服务器的实例ID')
    6. parser.add_argument('--mode',default='info',help='日志级别,默认info,可选debug')
    7. parser.add_argument('--snapshot_mode',default='None',help='快照模式,默认None,可选delete,create')
    8. return parser.parse_args()
    9. def get_snapshot_list(id,key):
    10. try:
    11. cred = credential.Credential(id, key)
    12. client = lighthouse_client.LighthouseClient(cred, "ap-guangzhou")
    13. req = models.DescribeSnapshotsRequest()
    14. params = {}
    15. req.from_json_string(json.dumps(params))
    16. resp = client.DescribeSnapshots(req)
    17. logging.debug(resp.to_json_string())
    18. logging.info('获取快照列表成功')
    19. return resp,client
    20. except TencentCloudSDKException as err:
    21. logging.error('获取快照列表失败')
    22. logging.error(err)
    23. return None,None

    删除快照

    根据快照id删除

    轻量应用服务器-删除快照:https://cloud.tencent.com/document/product/1207/54389

    官方文档也写了,删快照需要传入被删除快照的id,这也是为什么要先去获取快照列表。

    一般来说,删快照删的是最老的那个,所以还要给快照的创建时间排个序,再筛选出最老的那个快照。其他的和获取快照列表的代码都差不多。

    Python

    1. def choose_snapshot(snapshot_list):
    2. # 选择最老的快照
    3. SnapshotSet=snapshot_list.SnapshotSet
    4. SnapshotSet.sort(key=lambda x:x.CreatedTime)
    5. logging.info('选择最老的快照:{}'.format(SnapshotSet[0].SnapshotId)+' 创建时间:{}'.format(SnapshotSet[0].CreatedTime))
    6. return SnapshotSet[0].SnapshotId
    7. def delete_snapshot(client:lighthouse_client.LighthouseClient,snapshot_id:str):
    8. try:
    9. logging.info('删除快照:{}'.format(snapshot_id))
    10. req=models.DeleteSnapshotsRequest()
    11. params={
    12. 'SnapshotIds':[snapshot_id],
    13. }
    14. req.from_json_string(json.dumps(params))
    15. resp=client.DeleteSnapshots(req)
    16. logging.debug(resp.to_json_string())
    17. except TencentCloudSDKException as err:
    18. logging.error('删除快照失败')
    19. logging.error(err)

    新建快照

    需要服务器实例ID

    和删快照不一样,新建快照需要指定在xxx实例(也就是xxx服务器)上新建快照,所以我们还需要服务器的实例id。服务器的实例id在服务器的概要那里就能直接复制。

    很可惜,快照的id无法自定义,只能自定义快照的名称。所以代码如下

    Python

    1. def create_snapshot(client:lighthouse_client.LighthouseClient,snapshot_list,server_id:str):
    2. try:
    3. logging.info('新建快照')
    4. SnapshotName="Snapshot-"+str(time.strftime("%Y%m%d%H%M%S", time.localtime()))
    5. while SnapshotName in [i.SnapshotName for i in snapshot_list.SnapshotSet]:
    6. SnapshotName="Snapshot-"+str(time.strftime("%Y%m%d%H%M%S", time.localtime()))
    7. logging.info('新建快照:'+' 名称:{}'.format(SnapshotName))
    8. req=models.CreateInstanceSnapshotRequest()
    9. params={
    10. "InstanceId":server_id,
    11. "SnapshotName":SnapshotName
    12. }
    13. req.from_json_string(json.dumps(params))
    14. resp=client.CreateInstanceSnapshot(req)
    15. logging.debug(resp.to_json_string())
    16. logging.info('新建快照成功')
    17. except TencentCloudSDKException as err:
    18. logging.error('新建快照失败')
    19. logging.error(err)

    完整代码

    使用说明

    默认是“删一增一”,如果没快照就只作“新建快照”的操作。当然为了方便使用,也能指定只作“新建”或只作“删除”快照的操作。

    Python

    1. import json
    2. import argparse
    3. import logging
    4. import random
    5. import time
    6. from tencentcloud.common import credential
    7. from tencentcloud.common.profile.client_profile import ClientProfile
    8. from tencentcloud.common.profile.http_profile import HttpProfile
    9. from tencentcloud.common.exception.tencent_cloud_sdk_exception import TencentCloudSDKException
    10. from tencentcloud.lighthouse.v20200324 import lighthouse_client, models
    11. def parse():
    12. parser = argparse.ArgumentParser('TencentCloud_Lighthouse_AutoSnapshot',description='腾讯云lighthouse自动快照脚本')
    13. parser.add_argument('--id',help='密钥ID')
    14. parser.add_argument('--key',help='密钥KEY')
    15. parser.add_argument('--server_id',help='服务器的实例ID')
    16. parser.add_argument('--mode',default='info',help='日志级别,默认info,可选debug')
    17. parser.add_argument('--snapshot_mode',default='None',help='快照模式,默认None,可选delete,create')
    18. return parser.parse_args()
    19. def get_snapshot_list(id,key):
    20. try:
    21. cred = credential.Credential(id, key)
    22. client = lighthouse_client.LighthouseClient(cred, "ap-guangzhou")
    23. req = models.DescribeSnapshotsRequest()
    24. params = {}
    25. req.from_json_string(json.dumps(params))
    26. resp = client.DescribeSnapshots(req)
    27. logging.debug(resp.to_json_string())
    28. logging.info('获取快照列表成功')
    29. return resp,client
    30. except TencentCloudSDKException as err:
    31. logging.error('获取快照列表失败')
    32. logging.error(err)
    33. return None,None
    34. def choose_snapshot(snapshot_list):
    35. # 选择最老的快照
    36. SnapshotSet=snapshot_list.SnapshotSet
    37. SnapshotSet.sort(key=lambda x:x.CreatedTime)
    38. logging.info('选择最老的快照:{}'.format(SnapshotSet[0].SnapshotId)+' 创建时间:{}'.format(SnapshotSet[0].CreatedTime))
    39. return SnapshotSet[0].SnapshotId
    40. def delete_snapshot(client:lighthouse_client.LighthouseClient,snapshot_id:str):
    41. try:
    42. logging.info('删除快照:{}'.format(snapshot_id))
    43. req=models.DeleteSnapshotsRequest()
    44. params={
    45. 'SnapshotIds':[snapshot_id],
    46. }
    47. req.from_json_string(json.dumps(params))
    48. resp=client.DeleteSnapshots(req)
    49. logging.debug(resp.to_json_string())
    50. except TencentCloudSDKException as err:
    51. logging.error('删除快照失败')
    52. logging.error(err)
    53. def create_snapshot(client:lighthouse_client.LighthouseClient,snapshot_list,server_id:str):
    54. try:
    55. logging.info('新建快照')
    56. SnapshotName="Snapshot-"+str(time.strftime("%Y%m%d%H%M%S", time.localtime()))
    57. while SnapshotName in [i.SnapshotName for i in snapshot_list.SnapshotSet]:
    58. SnapshotName="Snapshot-"+str(time.strftime("%Y%m%d%H%M%S", time.localtime()))
    59. logging.info('新建快照:'+' 名称:{}'.format(SnapshotName))
    60. req=models.CreateInstanceSnapshotRequest()
    61. params={
    62. "InstanceId":server_id,
    63. "SnapshotName":SnapshotName
    64. }
    65. req.from_json_string(json.dumps(params))
    66. resp=client.CreateInstanceSnapshot(req)
    67. logging.debug(resp.to_json_string())
    68. logging.info('新建快照成功')
    69. except TencentCloudSDKException as err:
    70. logging.error('新建快照失败')
    71. logging.error(err)
    72. def main():
    73. args = parse()
    74. if args.mode == 'debug':
    75. logging_level = logging.DEBUG
    76. else:
    77. logging_level = logging.INFO
    78. logging.basicConfig(level=logging_level,format='%(levelname)s:%(asctime)s %(message)s',datefmt='%Y/%m/%d %H:%M:%S')
    79. if args.snapshot_mode=='delete':
    80. logging.info('删除模式:仅作删除快照操作')
    81. snapshot_list,client=get_snapshot_list(args.id,args.key)
    82. if snapshot_list is None:
    83. return
    84. elif snapshot_list.TotalCount==0:
    85. logging.info('无快照,无法删除')
    86. return
    87. else:
    88. SnapshotId=choose_snapshot(snapshot_list)
    89. delete_snapshot(client,SnapshotId)
    90. return
    91. elif args.snapshot_mode=='create':
    92. logging.info('新建模式:仅作新建快照操作')
    93. snapshot_list,client=get_snapshot_list(args.id,args.key)
    94. if snapshot_list is None:
    95. return
    96. else:
    97. create_snapshot(client,snapshot_list,args.server_id)
    98. return
    99. snapshot_list,client=get_snapshot_list(args.id,args.key)
    100. if snapshot_list is None:
    101. return
    102. elif snapshot_list.TotalCount==0:
    103. logging.info('无快照,新建快照')
    104. create_snapshot(client,snapshot_list,args.server_id)
    105. else:
    106. logging.info('列表中快照数量:{}'.format(snapshot_list.TotalCount))
    107. SnapshotId=choose_snapshot(snapshot_list)
    108. delete_snapshot(client,SnapshotId)
    109. snapshot_list,client=get_snapshot_list(args.id,args.key)
    110. create_snapshot(client,snapshot_list,args.server_id)
    111. if __name__ == '__main__':
    112. main()

  • 相关阅读:
    python---生成器表达式
    Java面试题整理Java基础部分
    一文了解Android App Bundle 格式文件
    resubmit 渐进式防重复提交框架简介
    电路设计 > eMMC应用和PCB layout布局布线参考设计
    节能灯与led灯哪个对眼睛好?分享专业护眼的led灯
    anime4k 在真机租用上的应用尝试
    形式化语言——时序逻辑
    Spring Bean 的作用域(Bean Scope)
    【leetcode】最多可以参加的会议数目
  • 原文地址:https://blog.csdn.net/white_night_SZTU/article/details/137966675