|
@@ -2,9 +2,13 @@ import logging
|
|
|
import json
|
|
|
import sys
|
|
|
import time
|
|
|
+from asyncio import wait_for
|
|
|
+
|
|
|
import requests
|
|
|
import asyncio
|
|
|
+import time
|
|
|
|
|
|
+from alibabacloud_tea_util.client import Client as UtilClient
|
|
|
from aliyunsdkcore.client import AcsClient
|
|
|
from aliyunsdkslb.request.v20140515.AddBackendServersRequest import AddBackendServersRequest
|
|
|
from aliyunsdkslb.request.v20140515.RemoveBackendServersRequest import RemoveBackendServersRequest
|
|
@@ -23,6 +27,9 @@ from alibabacloud_tea_openapi import models as open_api_models
|
|
|
from alibabacloud_alb20200616 import models as alb_models
|
|
|
from alibabacloud_alb20200616 import models as alb_20200616_models
|
|
|
from alibabacloud_tea_util import models as util_models
|
|
|
+from aliyunsdkalb.request.v20200616.ListServerGroupServersRequest import ListServerGroupServersRequest
|
|
|
+from aliyunsdkcore.acs_exception.exceptions import ClientException, ServerException
|
|
|
+
|
|
|
|
|
|
logging.basicConfig(level=logging.INFO,
|
|
|
format='%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s',
|
|
@@ -59,6 +66,25 @@ def connect_client(access_key_id, access_key_secret, region_id):
|
|
|
sys.exit()
|
|
|
|
|
|
|
|
|
+def connect_alb_client(access_key_id, access_key_secret, endpoint):
|
|
|
+ """
|
|
|
+ 初始化ALB客户端
|
|
|
+ :param access_key_id: access key Id, type-string
|
|
|
+ :param access_key_secret: access key secret, type-string
|
|
|
+ :return: alb_client
|
|
|
+ """
|
|
|
+ config = open_api_models.Config(
|
|
|
+ access_key_id=access_key_id,
|
|
|
+ access_key_secret=access_key_secret,
|
|
|
+ endpoint=endpoint
|
|
|
+ )
|
|
|
+ alb_client = Alb20200616Client(config)
|
|
|
+ return alb_client
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
def build_create_instances_request(image_id, vswitch_id, security_group_id, zone_id, instance_type, instance_name,
|
|
|
disk_size, disk_category, key_pair_name, tags):
|
|
|
"""
|
|
@@ -89,25 +115,6 @@ def build_create_instances_request(image_id, vswitch_id, security_group_id, zone
|
|
|
return request
|
|
|
|
|
|
|
|
|
-def send_request(ecs_client, request):
|
|
|
- """
|
|
|
- 发送API请求
|
|
|
- :param ecs_client: 客户端连接
|
|
|
- :param request: 请求配置
|
|
|
- :return: response
|
|
|
- """
|
|
|
- request.set_accept_format('json')
|
|
|
- try:
|
|
|
- response = ecs_client.do_action_with_exception(request)
|
|
|
- response = json.loads(response)
|
|
|
- # logging.info(response)
|
|
|
- return response
|
|
|
- except Exception as e:
|
|
|
- # 失败,记录报错信息,发送通知,停止并退出
|
|
|
- logging.error(e)
|
|
|
- sys.exit()
|
|
|
-
|
|
|
-
|
|
|
def send_req(client, request):
|
|
|
"""
|
|
|
发送API请求
|
|
@@ -128,6 +135,7 @@ def send_req(client, request):
|
|
|
#logging.error(e)
|
|
|
#sys.exit()
|
|
|
|
|
|
+
|
|
|
def check_instance_running(ecs_client, instance_ids):
|
|
|
"""
|
|
|
检查服务器运行状态
|
|
@@ -159,6 +167,22 @@ def check_instance_running(ecs_client, instance_ids):
|
|
|
sys.exit()
|
|
|
|
|
|
|
|
|
+def get_ip_address(ecs_client, instance_id):
|
|
|
+ """
|
|
|
+ 获取实例IP地址
|
|
|
+ :param ecs_client: 客户端连接
|
|
|
+ :param instance_id: 实例id, type-string
|
|
|
+ :return: ip_address, type-string
|
|
|
+ """
|
|
|
+ request = DescribeNetworkInterfacesRequest()
|
|
|
+ request.set_accept_format('json')
|
|
|
+ request.set_InstanceId(instance_id)
|
|
|
+ response = send_request(ecs_client=ecs_client, request=request)
|
|
|
+ ip_address = response['NetworkInterfaceSets']['NetworkInterfaceSet'][0]['PrivateIpAddress']
|
|
|
+ return ip_address
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
def create_multiple_instances(amount, ecs_client,
|
|
|
image_id, vswitch_id, security_group_id, zone_id, instance_type, instance_name,
|
|
|
disk_size, disk_category, key_pair_name, tags):
|
|
@@ -208,116 +232,128 @@ def create_multiple_instances(amount, ecs_client,
|
|
|
sys.exit()
|
|
|
|
|
|
|
|
|
-def run_command(ecs_client, instance_ids, command):
|
|
|
+
|
|
|
+def release_instances(ecs_client, instance_ids, force=False):
|
|
|
"""
|
|
|
- 批量执行命令
|
|
|
- :param ecs_client: 客户端连接
|
|
|
- :param instance_ids: 实例id列表, type-list, 最多能指定50台ECS实例ID
|
|
|
- :param command: 命令 type-string
|
|
|
+ 释放实例
|
|
|
+ :param ecs_client:
|
|
|
+ :param instance_ids: instance_id, type-list
|
|
|
+ :param force: 是否强制释放, True-强制释放, False-正常释放, type-bool
|
|
|
:return:
|
|
|
"""
|
|
|
- for i in range(len(instance_ids) // 50 + 1):
|
|
|
- instance_id_list = instance_ids[i * 50:(i + 1) * 50]
|
|
|
- if len(instance_id_list) == 0:
|
|
|
- return
|
|
|
- request = RunCommandRequest()
|
|
|
- request.set_accept_format('json')
|
|
|
- request.set_Type("RunShellScript")
|
|
|
- request.set_CommandContent(command)
|
|
|
- request.set_InstanceIds(instance_id_list)
|
|
|
- response = send_request(ecs_client=ecs_client, request=request)
|
|
|
- logging.info(response)
|
|
|
+ request = DeleteInstancesRequest()
|
|
|
+ request.set_InstanceIds(instance_ids)
|
|
|
+ request.set_Force(force)
|
|
|
+ response = send_request(ecs_client=ecs_client, request=request)
|
|
|
+ return response
|
|
|
+
|
|
|
+
|
|
|
|
|
|
-def run_per_command(client, instance, command):
|
|
|
+def get_instances_status(ecs_client, instance_ids):
|
|
|
"""
|
|
|
- 批量执行命令
|
|
|
- :param client: 客户端连接
|
|
|
- :param instance_ids: 实例id列表, type-list, 最多能指定50台ECS实例ID
|
|
|
- :param command: 命令 type-string
|
|
|
+ 获取实例运行状态
|
|
|
+ :param ecs_client:
|
|
|
+ :param instance_ids: instance_id, type-liist
|
|
|
:return:
|
|
|
"""
|
|
|
- #for i in range(len(instance_ids) // 50 + 1)
|
|
|
- request = RunCommandRequest()
|
|
|
- request.set_accept_format('json')
|
|
|
- request.set_Type("RunShellScript")
|
|
|
- request.set_CommandContent(command)
|
|
|
- request.set_InstanceIds([instance])
|
|
|
- response = send_req(client=client, request=request)
|
|
|
- logging.info(response)
|
|
|
+ request = DescribeInstanceStatusRequest()
|
|
|
+ request.set_InstanceIds(instance_ids)
|
|
|
+ request.set_PageSize(50)
|
|
|
+ response = send_request(ecs_client=ecs_client, request=request)
|
|
|
return response
|
|
|
|
|
|
|
|
|
-def get_instance_ids(alb_client, server_group_id):
|
|
|
+
|
|
|
+def stop_instances(ecs_client, instance_ids, force_stop=False):
|
|
|
"""
|
|
|
- 获取指定服务器组下所有服务器的instanceId
|
|
|
- :param alb_client: 客户端连接
|
|
|
- :param server_group_id: 服务器组ID type-string
|
|
|
- :return: instance_ids type-list
|
|
|
+ 停止实例
|
|
|
+ :param ecs_client:
|
|
|
+ :param instance_ids: 实例ID, type-list
|
|
|
+ :param force_stop: 是否强制关机, True-强制关机, False-正常关机, type-bool
|
|
|
+ :return:
|
|
|
"""
|
|
|
- request = alb_20200616_models.ListServerGroupServersRequest(
|
|
|
- server_group_id=server_group_id
|
|
|
- )
|
|
|
- runtime = util_models.RuntimeOptions()
|
|
|
- response = alb_client.list_server_group_servers_with_options(request, runtime)
|
|
|
+ request = StopInstancesRequest()
|
|
|
+ request.set_InstanceIds(instance_ids)
|
|
|
+ request.set_ForceStop(force_stop)
|
|
|
+ response = send_request(ecs_client=ecs_client, request=request)
|
|
|
+ return response
|
|
|
|
|
|
- instance_ids = [server["ServerId"] for server in response["Servers"]["Server"]]
|
|
|
- return instance_ids
|
|
|
|
|
|
|
|
|
-def get_ip_address(ecs_client, instance_id):
|
|
|
+
|
|
|
+def send_request(ecs_client, request):
|
|
|
"""
|
|
|
- 获取实例IP地址
|
|
|
+ 发送API请求
|
|
|
:param ecs_client: 客户端连接
|
|
|
- :param instance_id: 实例id, type-string
|
|
|
- :return: ip_address, type-string
|
|
|
+ :param request: 请求配置
|
|
|
+ :return: response
|
|
|
"""
|
|
|
- request = DescribeNetworkInterfacesRequest()
|
|
|
request.set_accept_format('json')
|
|
|
- request.set_InstanceId(instance_id)
|
|
|
- response = send_request(ecs_client=ecs_client, request=request)
|
|
|
- ip_address = response['NetworkInterfaceSets']['NetworkInterfaceSet'][0]['PrivateIpAddress']
|
|
|
- return ip_address
|
|
|
+ try:
|
|
|
+ response = ecs_client.do_action_with_exception(request)
|
|
|
+ response = json.loads(response)
|
|
|
+ # logging.info(response)
|
|
|
+ return response
|
|
|
+ except Exception as e:
|
|
|
+ # 失败,记录报错信息,发送通知,停止并退出
|
|
|
+ logging.error(e)
|
|
|
+ sys.exit()
|
|
|
|
|
|
|
|
|
-# def set_weight_for_instances(client, slb_id, instance_id_list, weight):
|
|
|
-# """
|
|
|
-# 同时设置多台服务器的slb权重,权重一样
|
|
|
-# :param client: 客户端连接
|
|
|
-# :param slb_id: slb_id
|
|
|
-# :param instance_id_list: 服务器id list
|
|
|
-# :param weight: 权重值
|
|
|
-# :return: None
|
|
|
-# """
|
|
|
-# for i in range(len(instance_id_list) // 20 + 1):
|
|
|
-# instances_list = instance_id_list[i * 20:(i + 1) * 20]
|
|
|
-# if len(instances_list) == 0:
|
|
|
-# return
|
|
|
-# BackendServers = [{"ServerId": instance_id, "Weight": weight} for instance_id in instances_list]
|
|
|
-# request = CommonRequest()
|
|
|
-# request.set_accept_format('json')
|
|
|
-# request.set_domain('slb.aliyuncs.com')
|
|
|
-# request.set_version('2014-05-15')
|
|
|
-# request.set_method('POST')
|
|
|
-# request.set_action_name('SetBackendServers')
|
|
|
-# request.add_query_param('BackendServers', BackendServers)
|
|
|
-# request.add_query_param('LoadBalancerId', slb_id)
|
|
|
-# response = send_request(client=client, request=request)
|
|
|
+
|
|
|
+def run_command(ecs_client, instance_ids, command):
|
|
|
+ """
|
|
|
+ 批量执行命令
|
|
|
+ :param ecs_client: 客户端连接
|
|
|
+ :param instance_ids: 实例id列表, type-list, 最多能指定50台ECS实例ID
|
|
|
+ :param command: 命令 type-string
|
|
|
+ :return:
|
|
|
+ """
|
|
|
+ for i in range(len(instance_ids) // 50 + 1):
|
|
|
+ instance_id_list = instance_ids[i * 50:(i + 1) * 50]
|
|
|
+ if len(instance_id_list) == 0:
|
|
|
+ return
|
|
|
+ request = RunCommandRequest()
|
|
|
+ request.set_accept_format('json')
|
|
|
+ request.set_Type("RunShellScript")
|
|
|
+ request.set_CommandContent(command)
|
|
|
+ request.set_InstanceIds(instance_id_list)
|
|
|
+ response = send_request(ecs_client=ecs_client, request=request)
|
|
|
+ logging.info(response)
|
|
|
|
|
|
|
|
|
-def connect_alb_client(access_key_id, access_key_secret, endpoint):
|
|
|
+def send_file_to_ecs(ecs_client, instance_id_list, target_dir, name, content):
|
|
|
"""
|
|
|
- 初始化ALB客户端
|
|
|
- :param access_key_id: access key Id, type-string
|
|
|
- :param access_key_secret: access key secret, type-string
|
|
|
- :return: alb_client
|
|
|
+ 发送文件到ecs;alb应用,区分上方clb
|
|
|
+ :param ecs_client:
|
|
|
+ :param instance_id_list: 最多能指定50台ECS实例ID
|
|
|
+ :param target_dir: 文件存放目录 type-string
|
|
|
+ :param name: 文件名 type-string
|
|
|
+ :param content: 文件内容 type-string
|
|
|
+ :return:
|
|
|
"""
|
|
|
- config = open_api_models.Config(
|
|
|
- access_key_id=access_key_id,
|
|
|
- access_key_secret=access_key_secret,
|
|
|
- endpoint=endpoint
|
|
|
- )
|
|
|
- alb_client = Alb20200616Client(config)
|
|
|
- return alb_client
|
|
|
+ if not instance_id_list:
|
|
|
+ logging.warning("实例ID列表为空,无法发送文件。")
|
|
|
+ return
|
|
|
+
|
|
|
+ for i in range(len(instance_id_list) // 50 + 1):
|
|
|
+ instance_ids = instance_id_list[i * 50:(i + 1) * 50]
|
|
|
+ if len(instance_ids) == 0:
|
|
|
+ logging.info("没有更多的实例ID需要发送文件,退出。")
|
|
|
+ return
|
|
|
+ request = SendFileRequest()
|
|
|
+ request.set_Content(content)
|
|
|
+ request.set_TargetDir(target_dir)
|
|
|
+ request.set_Name(name)
|
|
|
+ request.set_Overwrite(True)
|
|
|
+ request.set_InstanceIds(instance_ids)
|
|
|
+ try:
|
|
|
+ logging.info(f"正在向实例 {instance_ids} 发送文件 '{name}' 到目录 '{target_dir}'")
|
|
|
+ response = send_request(ecs_client=ecs_client, request=request)
|
|
|
+ logging.info(f"成功发送文件到实例 {instance_ids},响应: {response}")
|
|
|
+ except Exception as e:
|
|
|
+ logging.error(f"发送文件到实例 {instance_ids} 失败,错误: {str(e)}")
|
|
|
+
|
|
|
|
|
|
|
|
|
def add_servers_to_server_group(alb_client, server_group_id, instance_id, weight):
|
|
@@ -345,6 +381,8 @@ def add_servers_to_server_group(alb_client, server_group_id, instance_id, weight
|
|
|
except Exception as e:
|
|
|
logging.error(f"Failed to add server {instance_id} to server group {server_group_id}: {str(e)}")
|
|
|
|
|
|
+
|
|
|
+
|
|
|
def remove_servers_from_server_group(alb_client, server_group_id, instance_id):
|
|
|
"""
|
|
|
从ALB服务器组中移除服务器
|
|
@@ -368,235 +406,175 @@ def remove_servers_from_server_group(alb_client, server_group_id, instance_id):
|
|
|
except Exception as e:
|
|
|
logging.error(f"Failed to remove server {instance_id} from server group {server_group_id}: {str(e)}")
|
|
|
|
|
|
-
|
|
|
-def send_file_to_ecs(ecs_client, instance_id_list, target_dir, name, content):
|
|
|
- """
|
|
|
- 发送文件到ecs
|
|
|
- :param ecs_client:
|
|
|
- :param instance_id_list: 最多能指定50台ECS实例ID
|
|
|
- :param target_dir: 文件存放目录 type-string
|
|
|
- :param name: 文件名 type-string
|
|
|
- :param content: 文件内容 type-string
|
|
|
- :return:
|
|
|
- """
|
|
|
- if not instance_id_list:
|
|
|
- logging.warning("实例ID列表为空,无法发送文件。")
|
|
|
- return
|
|
|
-
|
|
|
- for i in range(len(instance_id_list) // 50 + 1):
|
|
|
- instance_ids = instance_id_list[i * 50:(i + 1) * 50]
|
|
|
- if len(instance_ids) == 0:
|
|
|
- logging.info("没有更多的实例ID可供处理,退出。")
|
|
|
- return
|
|
|
- request = SendFileRequest()
|
|
|
- request.set_Content(content)
|
|
|
- request.set_TargetDir(target_dir)
|
|
|
- request.set_Name(name)
|
|
|
- request.set_Overwrite(True)
|
|
|
- request.set_InstanceIds(instance_ids)
|
|
|
- try:
|
|
|
- logging.info(f"正在向实例 {instance_ids} 发送文件 '{name}' 到目录 '{target_dir}'")
|
|
|
- response = send_request(ecs_client=ecs_client, request=request)
|
|
|
- logging.info(f"成功发送文件到实例 {instance_ids},响应: {response}")
|
|
|
- except Exception as e:
|
|
|
- logging.error(f"发送文件到实例 {instance_ids} 失败,错误: {str(e)}")
|
|
|
-
|
|
|
-
|
|
|
-# def send_file_to_ecs(ecs_client, instance_id_list, target_dir, name, content):
|
|
|
+#
|
|
|
+# def set_weight_for_instances_alb(alb_client, server_group_id, instance_id_list, weights):
|
|
|
# """
|
|
|
-# 发送文件到ecs
|
|
|
-# :param ecs_client:
|
|
|
-# :param instance_id_list: 最多能指定50台ECS实例ID
|
|
|
-# :param target_dir: 文件存放目录 type-string
|
|
|
-# :param name: 文件名 type-string
|
|
|
-# :param content: 文件内容 type-string
|
|
|
-# :return:
|
|
|
+# 设置ALB服务器组中实例的权重
|
|
|
+# :param alb_client: ALB客户端连接
|
|
|
+# :param server_group_id: 服务器组ID
|
|
|
+# :param instance_id_list: 实例ID列表
|
|
|
+# :param weights: 权重列表
|
|
|
+# :return: None
|
|
|
# """
|
|
|
-# for i in range(len(instance_id_list) // 50 + 1):
|
|
|
-# instance_ids = instance_id_list[i * 50:(i + 1) * 50]
|
|
|
-# if len(instance_ids) == 0:
|
|
|
-# return
|
|
|
-# request = SendFileRequest()
|
|
|
-# request.set_Content(content)
|
|
|
-# request.set_TargetDir(target_dir)
|
|
|
-# request.set_Name(name)
|
|
|
-# request.set_Overwrite(True)
|
|
|
-# request.set_InstanceIds(instance_ids)
|
|
|
-# response = send_request(ecs_client=ecs_client, request=request)
|
|
|
-
|
|
|
-
|
|
|
-def stop_instances(ecs_client, instance_ids, force_stop=False):
|
|
|
- """
|
|
|
- 停止实例
|
|
|
- :param ecs_client:
|
|
|
- :param instance_ids: 实例ID, type-list
|
|
|
- :param force_stop: 是否强制关机, True-强制关机, False-正常关机, type-bool
|
|
|
- :return:
|
|
|
- """
|
|
|
- request = StopInstancesRequest()
|
|
|
- request.set_InstanceIds(instance_ids)
|
|
|
- request.set_ForceStop(force_stop)
|
|
|
- response = send_request(ecs_client=ecs_client, request=request)
|
|
|
- return response
|
|
|
-
|
|
|
-
|
|
|
-def release_instances(ecs_client, instance_ids, force=False):
|
|
|
- """
|
|
|
- 释放实例
|
|
|
- :param ecs_client:
|
|
|
- :param instance_ids: instance_id, type-list
|
|
|
- :param force: 是否强制释放, True-强制释放, False-正常释放, type-bool
|
|
|
- :return:
|
|
|
- """
|
|
|
- request = DeleteInstancesRequest()
|
|
|
- request.set_InstanceIds(instance_ids)
|
|
|
- request.set_Force(force)
|
|
|
- response = send_request(ecs_client=ecs_client, request=request)
|
|
|
- return response
|
|
|
-
|
|
|
-
|
|
|
-def get_instances_status(ecs_client, instance_ids):
|
|
|
- """
|
|
|
- 获取实例运行状态
|
|
|
- :param ecs_client:
|
|
|
- :param instance_ids: instance_id, type-list
|
|
|
- :return:
|
|
|
- """
|
|
|
- request = DescribeInstanceStatusRequest()
|
|
|
- request.set_InstanceIds(instance_ids)
|
|
|
- request.set_PageSize(50)
|
|
|
- response = send_request(ecs_client=ecs_client, request=request)
|
|
|
- return response
|
|
|
-
|
|
|
-
|
|
|
-# def set_instance_weight_process(client, slb_id, instance_id_list, weight_list):
|
|
|
+# servers = []
|
|
|
+# for instance_id, weight in zip(instance_id_list, weights):
|
|
|
+# server = alb_models.AddServersToServerGroupRequestServers( # todo update
|
|
|
+# port=80, # todo
|
|
|
+# server_id=instance_id,
|
|
|
+# server_type='ecs',
|
|
|
+# weight=weight
|
|
|
+# )
|
|
|
+# servers.append(server)
|
|
|
+#
|
|
|
+# request = alb_models.AddServersToServerGroupRequest(
|
|
|
+# server_group_id=server_group_id,
|
|
|
+# servers=servers
|
|
|
+# )
|
|
|
+#
|
|
|
+# runtime = util_models.RuntimeOptions()
|
|
|
+# try:
|
|
|
+# alb_client.add_servers_to_server_group_with_options(request, runtime)
|
|
|
+# logging.info(f"Successfully set weights for instances in server group {server_group_id}.")
|
|
|
+# except Exception as e:
|
|
|
+# logging.error(f"Failed to set weights for instances: {str(e)}")
|
|
|
+#
|
|
|
+#
|
|
|
+# def set_instance_weight_process_with_alb(alb_client, server_group_id_list, instance_id_list, weight_list):
|
|
|
# """
|
|
|
-# 修改服务器的权重值
|
|
|
-# :param client: slb客户端连接·
|
|
|
-# :param slb_id: slb id
|
|
|
-# :param instance_id_list: instance id list
|
|
|
+# 修改ALB服务器组中实例的权重值
|
|
|
+# :param alb_client: ALB客户端连接
|
|
|
+# :param server_group_id_list: 服务器组ID列表
|
|
|
+# :param instance_id_list: 实例ID列表
|
|
|
# :param weight_list: 权重修改列表 type-list [(weight, sleep_time), ...]
|
|
|
# :return:
|
|
|
# """
|
|
|
# for weight, sleep_time in weight_list:
|
|
|
-# logging.info(f"weight = {weight}")
|
|
|
-# flag = True
|
|
|
-# while flag:
|
|
|
-# try:
|
|
|
-# set_weight_for_instances(client=client, slb_id=slb_id, instance_id_list=instance_id_list, weight=weight)
|
|
|
-# time.sleep(sleep_time)
|
|
|
-# flag = False
|
|
|
-# except Exception as e:
|
|
|
-# time.sleep(10)
|
|
|
-# continue
|
|
|
-
|
|
|
-
|
|
|
-# def add_backend_servers(client, slb_id, instances):
|
|
|
-# """
|
|
|
-# 服务器挂载到负载均衡(必须是状态为运行中的后端服务器才可以加入负载均衡实例,每次调用最多可添加20个后端服务器)
|
|
|
-# :param client:
|
|
|
-# :param slb_id:
|
|
|
-# :param instances: 实例列表 [(instance_id, ip), ...]
|
|
|
-# :return:
|
|
|
-# """
|
|
|
-# try:
|
|
|
-# for i in range(len(instances) // 20 + 1):
|
|
|
-# instances_list = instances[i * 20:(i + 1) * 20]
|
|
|
-# if len(instances_list) == 0:
|
|
|
-# return
|
|
|
-# request = AddBackendServersRequest()
|
|
|
-# request.set_accept_format('json')
|
|
|
-# request.set_LoadBalancerId(slb_id)
|
|
|
-# backend_servers = [
|
|
|
-# {"ServerId": instance_id, "Weight": "0", "Type": "ecs", "ServerIp": ip_address}
|
|
|
-# for instance_id, ip_address in instances_list]
|
|
|
-# request.set_BackendServers(backend_servers)
|
|
|
-# response = client.do_action_with_exception(request)
|
|
|
-# return response
|
|
|
-# except Exception as e:
|
|
|
-# logging.error(e)
|
|
|
-# sys.exit()
|
|
|
-
|
|
|
+# logging.info(f"修改权重中: weight = {weight}")
|
|
|
+# for server_group_id in server_group_id_list:
|
|
|
+# flag = True
|
|
|
+# while flag:
|
|
|
+# try:
|
|
|
+# # 使用新的权重设置函数
|
|
|
+# set_weight_for_instances_alb(alb_client, server_group_id, instance_id_list, [weight] * len(instance_id_list))
|
|
|
+# logging.info(f"服务器组: {server_group_id} 权重设置完成!")
|
|
|
+# flag = False
|
|
|
+# except Exception as e:
|
|
|
+# logging.error(f"更新权重失败: {e}, 将重试...")
|
|
|
+# time.sleep(10)
|
|
|
+# continue
|
|
|
+# time.sleep(sleep_time)
|
|
|
+
|
|
|
+
|
|
|
+def list_server_group_servers(alb_client, server_group_id):
|
|
|
+ """
|
|
|
+ 列出服务器组中的服务器并返回实例ID列表
|
|
|
+ @param alb_client: ALB客户端
|
|
|
+ @param server_group_id: 服务器组ID
|
|
|
+ @return: 实例ID列表
|
|
|
+ """
|
|
|
+ list_server_group_servers_request = alb_20200616_models.ListServerGroupServersRequest(
|
|
|
+ server_group_id=server_group_id
|
|
|
+ )
|
|
|
+ runtime = util_models.RuntimeOptions()
|
|
|
|
|
|
-# def remove_backend_servers(client, slb_id, instances):
|
|
|
-# """
|
|
|
-# 服务器从负载均衡移除(一次调用最多可以移除20个后端服务器)
|
|
|
-# :param client:
|
|
|
-# :param slb_id:
|
|
|
-# :param instances: 实例列表 [instance_id, ...]
|
|
|
-# :return:
|
|
|
-# """
|
|
|
-# try:
|
|
|
-# for i in range(len(instances) // 20 + 1):
|
|
|
-# instances_list = instances[i * 20:(i + 1) * 20]
|
|
|
-# if len(instances_list) == 0:
|
|
|
-# return
|
|
|
-# request = RemoveBackendServersRequest()
|
|
|
-# request.set_accept_format('json')
|
|
|
-# request.set_LoadBalancerId(slb_id)
|
|
|
-# backend_servers = [
|
|
|
-# {"ServerId": instance_id, "Weight": "0", "Type": "ecs"}
|
|
|
-# for instance_id in instances_list]
|
|
|
-# request.set_BackendServers(backend_servers)
|
|
|
-# response = client.do_action_with_exception(request)
|
|
|
-# return response
|
|
|
-# except Exception as e:
|
|
|
-# logging.error(e)
|
|
|
-# sys.exit()
|
|
|
+ try:
|
|
|
+ response = alb_client.list_server_group_servers_with_options(list_server_group_servers_request, runtime)
|
|
|
+ instance_ids = [server.server_id for server in response.body.servers]
|
|
|
+ if instance_ids:
|
|
|
+ return instance_ids[0]
|
|
|
+ else:
|
|
|
+ return None
|
|
|
+ # return instance_ids
|
|
|
+ except Exception as error:
|
|
|
+ print(error.message)
|
|
|
+ print(error.data.get("Recommend"))
|
|
|
+ UtilClient.assert_as_string(error.message)
|
|
|
+ return []
|
|
|
|
|
|
|
|
|
-def set_weight_for_instances_alb(alb_client, server_group_id, instance_id_list, weights):
|
|
|
+async def list_server_group_servers_async(alb_client, server_group_id):
|
|
|
"""
|
|
|
- 设置ALB服务器组中实例的权重
|
|
|
- :param alb_client: ALB客户端连接
|
|
|
- :param server_group_id: 服务器组ID
|
|
|
- :param instance_id_list: 实例ID列表
|
|
|
- :param weights: 权重列表
|
|
|
- :return: None
|
|
|
- """
|
|
|
- servers = []
|
|
|
- for instance_id, weight in zip(instance_id_list, weights):
|
|
|
- server = alb_models.AddServersToServerGroupRequestServers(
|
|
|
- port=80,
|
|
|
- server_id=instance_id,
|
|
|
- server_type='ecs',
|
|
|
- weight=weight
|
|
|
- )
|
|
|
- servers.append(server)
|
|
|
-
|
|
|
- request = alb_models.AddServersToServerGroupRequest(
|
|
|
- server_group_id=server_group_id,
|
|
|
- servers=servers
|
|
|
+ 异步列出指定服务器组中的服务器并返回实例ID列表
|
|
|
+ @param alb_client: ALB客户端
|
|
|
+ @param server_group_id: 服务器组ID
|
|
|
+ @return: 实例ID列表
|
|
|
+ """
|
|
|
+ list_server_group_servers_request = alb_20200616_models.ListServerGroupServersRequest(
|
|
|
+ server_group_id=server_group_id
|
|
|
)
|
|
|
-
|
|
|
runtime = util_models.RuntimeOptions()
|
|
|
+
|
|
|
try:
|
|
|
- alb_client.add_servers_to_server_group_with_options(request, runtime)
|
|
|
- logging.info(f"Successfully set weights for instances in server group {server_group_id}.")
|
|
|
- except Exception as e:
|
|
|
- logging.error(f"Failed to set weights for instances: {str(e)}")
|
|
|
+ response = await alb_client.list_server_group_servers_with_options_async(list_server_group_servers_request,
|
|
|
+ runtime)
|
|
|
+ instance_ids = [server.server_id for server in response.body.servers]
|
|
|
+ return instance_ids
|
|
|
+ except Exception as error:
|
|
|
+ print(error.message)
|
|
|
+ print(error.data.get("Recommend"))
|
|
|
+ UtilClient.assert_as_string(error.message)
|
|
|
+ return []
|
|
|
|
|
|
-def set_instance_weight_process_with_alb(alb_client, server_group_id_list, instance_id_list, weight_list):
|
|
|
+
|
|
|
+def update_server_group_servers_attribute(alb_client, server_group_id_list, instance_id_list, weight_list):
|
|
|
"""
|
|
|
- 修改ALB服务器组中实例的权重值
|
|
|
- :param alb_client: ALB客户端连接
|
|
|
+ 更新服务器组中的服务器权重
|
|
|
+ :param alb_client: ALB客户端
|
|
|
:param server_group_id_list: 服务器组ID列表
|
|
|
:param instance_id_list: 实例ID列表
|
|
|
:param weight_list: 权重修改列表 type-list [(weight, sleep_time), ...]
|
|
|
- :return:
|
|
|
"""
|
|
|
- for weight, sleep_time in weight_list:
|
|
|
- logging.info(f"修改权重中: weight = {weight}")
|
|
|
- for server_group_id in server_group_id_list:
|
|
|
- flag = True
|
|
|
- while flag:
|
|
|
+ for server_group_id in server_group_id_list:
|
|
|
+ for instance_id in instance_id_list:
|
|
|
+ for weight, sleep_time in weight_list:
|
|
|
+ server = alb_20200616_models.UpdateServerGroupServersAttributeRequestServers(
|
|
|
+ server_type='Ecs',
|
|
|
+ server_id=instance_id,
|
|
|
+ weight=weight,
|
|
|
+ port=80
|
|
|
+ )
|
|
|
+ request = alb_20200616_models.UpdateServerGroupServersAttributeRequest(
|
|
|
+ servers=[server],
|
|
|
+ server_group_id=server_group_id
|
|
|
+ )
|
|
|
+ runtime = util_models.RuntimeOptions()
|
|
|
+ try:
|
|
|
+ alb_client.update_server_group_servers_attribute_with_options(request, runtime)
|
|
|
+ print(f"Successfully updated server {instance_id} in group {server_group_id} to weight {weight}.")
|
|
|
+ except Exception as error:
|
|
|
+ print(error.message)
|
|
|
+ print(error.data.get("Recommend"))
|
|
|
+ UtilClient.assert_as_string(error.message)
|
|
|
+ time.sleep(sleep_time)
|
|
|
+
|
|
|
+
|
|
|
+async def update_server_group_servers_attribute_async(alb_client, server_group_id_list, instance_ids, weight_list):
|
|
|
+ """
|
|
|
+ 异步更新服务器组中的服务器属性
|
|
|
+ :param alb_client: ALB客户端
|
|
|
+ :param server_group_id_list: 服务器组ID列表
|
|
|
+ :param instance_ids: 实例ID列表
|
|
|
+ :param weight_list: 权重修改列表 type-list [(weight, sleep_time), ...]
|
|
|
+ """
|
|
|
+ for server_group_id in server_group_id_list:
|
|
|
+ for instance_id in instance_ids:
|
|
|
+ for weight, sleep_time in weight_list:
|
|
|
+ server = alb_20200616_models.UpdateServerGroupServersAttributeRequestServers(
|
|
|
+ server_type='Ecs',
|
|
|
+ server_id=instance_id,
|
|
|
+ weight=weight,
|
|
|
+ port=80
|
|
|
+ )
|
|
|
+ request = alb_20200616_models.UpdateServerGroupServersAttributeRequest(
|
|
|
+ servers=[server],
|
|
|
+ server_group_id=server_group_id
|
|
|
+ )
|
|
|
+ runtime = util_models.RuntimeOptions()
|
|
|
try:
|
|
|
- # 使用新的权重设置函数
|
|
|
- set_weight_for_instances_alb(alb_client, server_group_id, instance_id_list, [weight] * len(instance_id_list))
|
|
|
- logging.info(f"服务器组: {server_group_id} 权重设置完成!")
|
|
|
- flag = False
|
|
|
- except Exception as e:
|
|
|
- logging.error(f"更新权重失败: {e}, 将重试...")
|
|
|
- time.sleep(10)
|
|
|
- continue
|
|
|
- time.sleep(sleep_time)
|
|
|
+ await alb_client.update_server_group_servers_attribute_with_options_async(request, runtime)
|
|
|
+ print(f"Successfully updated server {instance_id} in group {server_group_id} to weight {weight} asynchronously.")
|
|
|
+ except Exception as error:
|
|
|
+ print(error.message)
|
|
|
+ print(error.data.get("Recommend"))
|
|
|
+ UtilClient.assert_as_string(error.message)
|
|
|
+ await asyncio.sleep(sleep_time)
|