def CreateInstance(ak, sk, region_tag, instance_name, security_id, vpc_id, instance_type, bandout): global instance_id client = AcsClient(ak, sk, region_tag) request = CreateInstanceRequest() request.set_accept_format('json') request.set_InstanceName(instance_name) request.set_SecurityGroupId(security_id) #安全组 request.set_InstanceType(instance_type) #型号 request.set_ImageId("m-bp1a8si7x4swoetbhtgn") #统一镜像 request.set_VSwitchId(vpc_id) #指定VPC的交换机 request.set_KeyPairName("电商平台秘钥") #秘钥 request.set_InstanceChargeType("PrePaid") #预付费 request.set_IoOptimized("optimized") #IO强化 request.set_SystemDiskSize(40) #磁盘容量 request.set_SystemDiskCategory("cloud_ssd") #高效云盘 request.set_PasswordInherit(True) request.set_InternetMaxBandwidthOut(bandout) #出网带宽1M request.set_Period(1) #购买资源的时长 request.set_AutoRenewPeriod(1) #按月续费 request.set_InternetChargeType("PayByTraffic") #按流量计费 request.set_AutoRenew(True) #自动计费 response = client.do_action_with_exception(request) result = str(response, encoding='utf-8') data = json.loads(result) instance_id = data["InstanceId"] print("生成新的ECS的ID号是=======>" + str(instance_id)) return instance_id #返回ID给下面使用
def createInstance(params): request = CreateInstanceRequest() request.set_accept_format('json') if "SecurityGroupId" in params: request.set_SecurityGroupId(params["SecurityGroupId"]) if "ZoneId" in params: request.set_ZoneId(params["ZoneId"]) if "VSwitchId" in params: request.set_VSwitchId(params["VSwitchId"]) request.set_ImageId(params["ImageId"]) request.set_InstanceType(params["InstanceType"]) request.set_InstanceName(params["InstanceName"]) request.set_InternetChargeType(params["InternetChargeType"]) request.set_AutoRenew(params["AutoRenew"]) request.set_InternetMaxBandwidthOut(params["InternetMaxBandwidthOut"]) request.set_Password(params["Password"]) request.set_SystemDiskSize(params["SystemDiskSize"]) request.set_SystemDiskCategory(params["SystemDiskCategory"]) request.set_IoOptimized(params["IoOptimized"]) request.set_InstanceChargeType(params["InstanceChargeType"]) response = client.do_action_with_exception(request) response = json.loads(str(response, encoding='utf-8')) return response["InstanceId"]
def CreateInstance(self, region_id, ZoneId, ImageId, InstanceType, InstanceName, InstanceChargeType, InternetChargeType, InternetMaxBandwidthOut, HostName, DataDisk, Password, VSwitchId, SecurityGroupId, UserData): """ 创建 实例 :param region_id: 地域 :param ZoneId: 可用区 :param ImageId: 镜像 :param InstanceType: 实例模板 :param InstanceName: 实例名字 :param InstanceChargeType: 计费方式 :param InternetChargeType: 网络计费方式 :param InternetMaxBandwidthOut: 出网带宽 :param HostName: 主机名字 :param DataDisk: 数据盘 :param Password: 密码 :param VSwitchId: 交换机 :param SecurityGroupId: 安全组 :param UserData: 机器初始化cloud_init加载脚本 :return: {'InstanceId': 'i-2ze210z0uiwyadm1m7x6'} """ createclt = AcsClient(self.AccessKeyId, self.AccessKeySecret, region_id) createreq = CreateInstanceRequest() createreq.set_action_name('CreateInstance') createreq.set_accept_format('json') createreq.set_ZoneId(ZoneId) createreq.set_ImageId(ImageId) createreq.set_InstanceType(InstanceType) createreq.set_InstanceName(InstanceName) createreq.set_InstanceChargeType(InstanceChargeType) if InstanceChargeType == 'PrePaid': createreq.set_Period('1') if InternetChargeType: createreq.set_InternetChargeType(InternetChargeType) createreq.set_InternetMaxBandwidthOut(InternetMaxBandwidthOut) createreq.set_HostName(HostName) createreq.set_Password(Password) createreq.set_VSwitchId(VSwitchId) createreq.set_SecurityGroupId(SecurityGroupId) '''通用配置 以下配固定不变配置''' createreq.set_KeyPairName('twl-vpc-ecs-key') # 初始化key createreq.set_SecurityEnhancementStrategy('Active') # 安全加固 createreq.set_IoOptimized('optimized') # IO优化 createreq.set_DataDisks(DataDisk) # 数据盘 ''' 通用配置 系统盘 ''' createreq.set_SystemDiskCategory('cloud_efficiency') # 高效云盘 createreq.set_SystemDiskSize(40) # 系统盘大小40G createreq.set_SystemDiskDiskName(HostName + "-sysdisk") # 系统盘命名 ''' 初始化要执行的脚本''' createreq.set_UserData(UserData) # 传入UserData数据,进行开机初始化 createre = json.loads(createclt.do_action_with_exception(createreq), encoding='utf-8') return createre
def _boot_image(self, zone_id, image_id, instance_type, vswitch_id, instance_name, ssh_keyname, security_group_id): request = CreateInstanceRequest() request.set_ImageId(image_id) request.set_SecurityGroupId(security_group_id) request.set_InstanceType(instance_type) request.set_VSwitchId(vswitch_id) request.set_ZoneId(zone_id) request.set_InstanceChargeType('PostPaid') request.set_KeyPairName(ssh_keyname) request.set_InternetMaxBandwidthOut(1) response = self._send_request(request) instance_id = response.get('InstanceId') if instance_id is None: logger.info(response) raise Exception("Instance could not be created.") self.instance_id = instance_id logger.info("Instance %s created" % instance_id) logger.info( "Wait for the instance to appear as stopped so we can continue") max_tries = 10 status = None while max_tries > 0 and status != 'Stopped': max_tries -= 1 time.sleep(5) status = self._get_instance_status_by_id(instance_id) if status != 'Stopped': raise Exception("VM %s not in desired state" % instance_id) logger.info("Allocating public ip for instance %s" % instance_id) request = AllocatePublicIpAddressRequest() request.set_InstanceId(instance_id) ip_address = self._send_request(request) logger.info("Public IP address asssigned to instance: %s" % ip_address) logger.info(json.dumps(ip_address, indent=4)) logger.info("Starting instance %s" % instance_id) request = StartInstanceRequest() request.set_InstanceId(instance_id) self._send_request(request) # wait for instance to be started max_tries = 60 status = "initial" while max_tries > 0 and status != 'Running': max_tries -= 1 time.sleep(10) status = self._get_instance_status_by_id(instance_id) logger.info("Status is %s" % status) if status != 'Running': raise Exception("Instance %s status is %s: failed to start." % (instance_id, status)) return (instance_id, ip_address)
def create_prepay_instance(image_id, instance_type, security_group_id, vswitch_id): request = CreateInstanceRequest() request.set_ImageId(image_id) request.set_SecurityGroupId(security_group_id) request.set_InstanceType(instance_type) request.set_VSwitchId(vswitch_id) request.set_Period(1) request.set_InstanceChargeType('PrePaid') request.set_InstanceName(instance_name) request.set_KeyPairName("saltstack1") response = _send_request(request) instance_id = response.get('InstanceId') logging.info("instance %s created task submit successfully.", instance_id) return instance_id
def create_after_pay_instance(image_id, instance_type, security_group_id, vsw_vswitch_id, zone_id): request = CreateInstanceRequest() request.set_ImageId(image_id) request.set_SecurityGroupId(security_group_id) request.set_InstanceType(instance_type) request.set_IoOptimized('optimized') request.set_VSwitchId(vsw_vswitch_id) request.set_SystemDiskCategory('cloud_ssd') request.set_ZoneId(zone_id) request.set_HostName("flink-console-%s" % REGION_ID) request.set_Password(ECS_PAW) response = _send_request(request) instance_id = response.get('InstanceId') if instance_id: logging.info("instance %s created task submit successfully.", instance_id) else: raise Exception("Invalid instance_id: %s ", instance_id) return instance_id
def create_after_pay_instance(image_id, instance_type, security_group_id, vswitchid): """ :param image_id: You can use public images or custom images. Image specify a OS and related software packages. :param instance_type: The option “one-core 2GiB n1.small” indicates that the input parameter is ecs.n1.small. :param security_group_id: Security group ID. A security group is similar to a firewall and uses security group rules to control network access requests of instances.We recommend that you configure access rules only according to the actual needs. :return: a instance id. """ request = CreateInstanceRequest() request.set_ImageId(image_id) request.set_SecurityGroupId(security_group_id) request.set_InstanceType(instance_type) request.set_IoOptimized('optimized') request.set_VSwitchId(vswitchid) response = _send_request(request) instance_id = response.get('InstanceId') logging.info("instance %s created task submit successfully.", instance_id) return instance_id
def createInstance(self): ret = {} clt = self.createECS_Client() request = CreateInstanceRequest() request.set_ImageId(self.imageID) request.set_InstanceType(self.instanceType) request.set_SecurityGroupId(self.groupID) request.set_SpotPriceLimit(float(self.price)) request.set_KeyPairName(self.keyName) request.set_InternetMaxBandwidthOut(int(self.bandwidth)) request.set_IoOptimized('optimized') request.set_SystemDiskCategory('cloud_efficiency') request.set_InstanceChargeType('PostPaid') request.set_SpotStrategy('SpotWithPriceLimit') request.set_InternetChargeType('PayByTraffic') request.set_VSwitchId(self.vSwitchID) """步骤 1. 创建 ECS 2. 创建 EIP(暂时废弃) 3. 启动 ECS 4. 关联 EIP 到 ECS(暂时废弃) """ response = self._send_request(clt, request) if response['code'] != 0: logger.warn("create instance failed with %s" % response['msg']) return response logger.info("create ecs done.") instanceID = response['msg'].get('InstanceId') associateID = "" """ 申请公网 IP if self.assoID != "" and self.eip != "": logger.debug("use existed eip to asso the ecs.") ret['EipAddress'] = self.eip associateID = self.assoID else: response = self.allocEIP(clt) if response['code'] != 0: logger.warn("alloc EIP failed with %s" % response['msg']) return response logger.info("alloc EIP response done.") ret['EipAddress'] = response['msg']['EipAddress'] associateID = response['msg']['AllocationId'] """ while True: response = self.startInstance(clt, instanceID) if response['code'] == 0: logger.debug("start instance OK, return %s" % response['msg']) break logger.debug("response code: %s", str(response['code'])) if response['code'] != 'IncorrectInstanceStatus': logger.error("start instance failed with %s" % response['msg']) ret['code'] = 1 ret['msg'] = "start instance failed with" + str( response['msg']) return ret logger.warn("start instance failed with IncorrectInstanceStatus") time.sleep(1) logger.debug("start instance done.") """关联公网 IP 到 ECS 上 while True: response = self.associateEIP(clt, associateID, instanceID) if response['code'] == 0: logger.info("associateEIP OK, response: %s" % response['msg']) break if response['msg']['Code'] != "IncorrectInstanceStatus": logger.error("associateEIP failed with %s" % response['msg']) return response logger.warn("start instance failed with IncorrectInstanceStatus") time.sleep(1) logger.info("associateEIP done.") """ response = self.getInstanceDetail(clt, instanceID) logger.info(response) ret['LockReason'] = '' lock_reason = response['msg'].get('Instances').get('Instance')[0].get( 'OperationLocks').get('LockReason') if lock_reason is not None: for reason in lock_reason: if reason == "Recycling": ret['LockReason'] = 'Recycling' break ret['InstanceID'] = instanceID ret['ExpiredTime'] = response['msg'].get('Instances').get( 'Instance')[0].get('ExpiredTime') ret['EipAddress'] = response['msg'].get('Instances').get( 'Instance')[0].get('EipAddress').get('IpAddress') ret['Hostname'] = response['msg'].get('Instances').get( 'Instance')[0].get('HostName') ret['InnerAddress'] = response['msg'].get('Instances').get('Instance')[ 0].get('VpcAttributes').get('PrivateIpAddress').get('IpAddress')[0] ret['msg'] = "Create ECS successfully." ret['code'] = 0 logger.info(ret) return ret