前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >基础网络CDB使用API批量切换私有网络

基础网络CDB使用API批量切换私有网络

原创
作者头像
vic@TX
修改2022-11-03 21:56:28
2.4K0
修改2022-11-03 21:56:28
举报
文章被收录于专栏:云内架构优化最佳实践

一、迁移方案

基础网络CDB切换到私有网络,有两种方式:

1、在控制台修改切换网络(单次修改1台),可配置原ip保留168小时:云数据库 MySQL 切换网络-操作指南-文档中心-腾讯云

2、通过API切换网络(单次修改1台):云数据库 MySQL 修改云数据库实例的IP和端口号-API 文档-文档中心-腾讯云

本文以python为例,介绍使用腾讯云SDK来批量切换基础网络CDB到私有网络的方法。

二、环境准备

1、安装python(2.7或3.0以上版本都可以);

2、安装腾讯云最新SDK:

pip install tencentcloud-sdk-python

或pip3 install tencentcloud-sdk-python

三、操作步骤

1、准备待迁移实例列表

从控制台筛选导出实例信息

按照如下格式整理成csv表格(实例id、内网ip、目标vpc和子网)

2、准备迁移脚本

修改API密钥

修改目标实例所在地域,参考:云服务器 地域和可用区-产品简介-文档中心-腾讯云

从csv表格中读取实例id、内网ip、目标vpc、目标子网等参数:

调切换接口从基础网络切换到私有网络:

3、执行情况

批量切换私有网络

四、脚本示例(python,供参考)

代码语言:javascript
复制
import os
from re import A
import sys
import csv
import json
import time
from tencentcloud.common import credential
from tencentcloud.common.profile.client_profile import ClientProfile
from tencentcloud.common.profile.http_profile import HttpProfile
from tencentcloud.common.exception.tencent_cloud_sdk_exception import TencentCloudSDKException
from tencentcloud.cdb.v20170320 import cdb_client, models
try:
    # 实例化一个认证对象,入参需要传入腾讯云账户secretId,secretKey,此处还需注意密钥对的保密
    # 密钥可前往https://console.cloud.tencent.com/cam/capi网站进行获取
    cred = credential.Credential("AKIxxxx", "dChxxx")
    # 实例化一个http选项,可选的,没有特殊需求可以跳过
    httpProfile = HttpProfile()
    httpProfile.endpoint = "cdb.tencentcloudapi.com"

    # 实例化一个client选项,可选的,没有特殊需求可以跳过
    clientProfile = ClientProfile()
    clientProfile.httpProfile = httpProfile
    # 实例化要请求产品的client对象,clientProfile是可选的
    client = cdb_client.CdbClient(cred, "ap-guangzhou", clientProfile)

except TencentCloudSDKException as err:
    print(err)


if __name__ == '__main__':
    #读取csv文件中的实例id、内网ip等信息
    with open("/Users/vicjiang/Desktop/cdb_list.csv",encoding="utf-8",mode="r") as f:
        reader = csv.DictReader(f)
        for row in reader:
            print(row["实例ID"],row["内网 IP"],row["目标VPC"],row["目标子网"])
            # 实例化一个请求对象,每个接口都会对应一个request对象
            req = models.ModifyDBInstanceVipVportRequest()
            params = {
                "InstanceId": row["实例ID"],
                "DstIp": row["内网 IP"],
                "UniqVpcId": row["目标VPC"],
                "UniqSubnetId": row["目标子网"],
                # 保留基础网络ip 168小时(7天)
                "ReleaseDuration": 168
            }
            req.from_json_string(json.dumps(params))

            # 返回的resp是一个ModifyDBInstanceVipVportResponse的实例,与请求对象对应
            resp = client.ModifyDBInstanceVipVport(req)
            # 输出json格式的字符串回包
            print(resp.to_json_string())
            # 加1秒等待时间,每秒切换1台
            time.sleep( 1 )

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、迁移方案
  • 二、环境准备
  • 三、操作步骤
    • 1、准备待迁移实例列表
      • 2、准备迁移脚本
        • 3、执行情况
          • 批量切换私有网络
      • 四、脚本示例(python,供参考)
      相关产品与服务
      私有网络
      私有网络(Virtual Private Cloud,VPC)是基于腾讯云构建的专属云上网络空间,为您在腾讯云上的资源提供网络服务,不同私有网络间完全逻辑隔离。作为您在云上的专属网络空间,您可以通过软件定义网络的方式管理您的私有网络 VPC,实现 IP 地址、子网、路由表、网络 ACL 、流日志等功能的配置管理。私有网络还支持多种方式连接 Internet,如弹性 IP 、NAT 网关等。同时,您也可以通过 VPN 连接或专线接入连通腾讯云与您本地的数据中心,灵活构建混合云。
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档