详解通过API管理或定制开发ECS实例


Posted in Python onSeptember 30, 2018

弹性管理 ECS 实例

获取 RAM 子账号 AK 密钥

使用API管理ECS实例,您需要能访问ECS资源的API密钥(AccessKey ID 和 AccessKey Secret)。为了保证云服务的安全,您需要创建一个能访问ECS资源的RAM用户,获取该用户的AccessKey密钥,并使用这个RAM用户和API管理ECS实例。

以下是获取RAM用户AccessKey密钥的操作步骤:

创建RAM用户并获取AccessKey密钥。

直接给RAM用户授权,授予RAM用户 管理云服务器服务(ECS)的权限。

安装 ECS Python SDK

首先确保您已经具备Python的Runtime,本文中使用的Python版本为2.7+。

pip install aliyun-python-sdk-ecs

如果提示您没有权限,请切换sudo继续执行。

sudo pip install aliyun-python-sdk-ecs

本文使用的SDK版本为 2.1.2。

Hello Alibaba Cloud

创建文件 hello_ecs_api.py。为了使用SDK,首先实例化AcsClient对象,这里需要RAM用户的AccessKey ID和AccessKey Secret。

AccessKey ID和AccessKey Secret是RAM用户访问阿里云ECS服务API的密钥,具有该账户完全的权限,请妥善保管。

from aliyunsdkcore import client
from aliyunsdkecs.request.v20140526.DescribeInstancesRequest import DescribeInstancesRequest
from aliyunsdkecs.request.v20140526.DescribeRegionsRequest import DescribeRegionsRequest
clt = client.AcsClient('Your Access Key Id', 'Your Access Key Secrect', 'cn-beijing')

完成实例化后可以进行第一个应用的开发。查询当前账号支持的地域列表。具体的文档参见 查询可用地域列表。

def hello_aliyun_regions():
  request = DescribeRegionsRequest()
  response = _send_request(request)
  region_list = response.get('Regions').get('Region')
  assert response is not None
  assert region_list is not None
  result = map(_print_region_id, region_list)
  logging.info("region list: %s", result)
def _print_region_id(item):
  region_id = item.get("RegionId")
  return region_id
def _send_request(request):
  request.set_accept_format('json')
  try:
    response_str = clt.do_action(request)
    logging.info(response_str)
    response_detail = json.loads(response_str)
    return response_detail
  except Exception as e:
    logging.error(e)
hello_aliyun_regions()

在命令行运行 python hello_ecs_api.py 会得到当前支持的 Region列表。类似的输出如下:

[u'cn-shenzhen', u'ap-southeast-1', u'cn-qingdao', u'cn-beijing', u'cn-shanghai', 
u'us-east-1', u'cn-hongkong', u'me-east-1', u'ap-southeast-2', u'cn-hangzhou', u'eu-central-1',
 u'ap-northeast-1', u'us-west-1']

查询当前的 Region 下的 ECS 实例列表

查询实例列表和查询 Region 列表非常类似,替换入参对象为DescribeInstancesRequest 即可,更多的查询参数参考 查询实例列表。

def list_instances():
  request = DescribeInstancesRequest()
  response = _send_request(request)
  if response is not None:
    instance_list = response.get('Instances').get('Instance')
    result = map(_print_instance_id, instance_list)
    logging.info("current region include instance %s", result)
def _print_instance_id(item):
  instance_id = item.get('InstanceId');
  return instance_id

输出结果为如下:

current region include instance [u'i-****', u'i-****'']

更多的API参考 ECS API 概览,您可以尝试作一个 查询磁盘列表,将实例的参数替换为 DescribeDisksRequest。

完整代码示例

以上操作完整的代码示例如下所示。

# coding=utf-8
# if the python sdk is not install using 'sudo pip install aliyun-python-sdk-ecs'
# if the python sdk is install using 'sudo pip install --upgrade aliyun-python-sdk-ecs'
# make sure the sdk version is 2.1.2, you can use command 'pip show aliyun-python-sdk-ecs' to check
import json
import logging
from aliyunsdkcore import client
from aliyunsdkecs.request.v20140526.DescribeInstancesRequest import DescribeInstancesRequest
from aliyunsdkecs.request.v20140526.DescribeRegionsRequest import DescribeRegionsRequest
# configuration the log output formatter, if you want to save the output to file,
# append ",filename='ecs_invoke.log'" after datefmt.
logging.basicConfig(level=logging.INFO,
          format='%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s',
          datefmt='%a, %d %b %Y %H:%M:%S')
clt = client.AcsClient('Your Access Key Id', 'Your Access Key Secrect', 'cn-beijing')
# sample api to list aliyun open api.
def hello_aliyun_regions():
  request = DescribeRegionsRequest()
  response = _send_request(request)
  if response is not None:
    region_list = response.get('Regions').get('Region')
    assert response is not None
    assert region_list is not None
    result = map(_print_region_id, region_list)
    logging.info("region list: %s", result)
# output the instance owned in current region.
def list_instances():
  request = DescribeInstancesRequest()
  response = _send_request(request)
  if response is not None:
    instance_list = response.get('Instances').get('Instance')
    result = map(_print_instance_id, instance_list)
    logging.info("current region include instance %s", result)
def _print_instance_id(item):
  instance_id = item.get('InstanceId');
  return instance_id
def _print_region_id(item):
  region_id = item.get("RegionId")
  return region_id
# send open api request
def _send_request(request):
  request.set_accept_format('json')
  try:
    response_str = clt.do_action(request)
    logging.info(response_str)
    response_detail = json.loads(response_str)
    return response_detail
  except Exception as e:
    logging.error(e)
if __name__ == '__main__':
  logging.info("Hello Aliyun OpenApi!")
  hello_aliyun_regions()
  list_instances()
Python 相关文章推荐
简单介绍Ruby中的CGI编程
Apr 10 Python
在python中pandas的series合并方法
Nov 12 Python
Python线程池模块ThreadPoolExecutor用法分析
Dec 28 Python
python for循环remove同一个list过程解析
Aug 14 Python
Tensorflow 自定义loss的情况下初始化部分变量方式
Jan 06 Python
python匿名函数lambda原理及实例解析
Feb 07 Python
Python中使用socks5设置全局代理的方法示例
Apr 15 Python
Python使用matplotlib绘制圆形代码实例
May 27 Python
Python Selenium模块安装使用教程详解
Jul 09 Python
解析python 类方法、对象方法、静态方法
Aug 15 Python
Python竟然能剪辑视频
May 25 Python
pytorch中的 .view()函数的用法介绍
Mar 17 Python
Python 使用类写装饰器的小技巧
Sep 30 #Python
浅谈django三种缓存模式的使用及注意点
Sep 30 #Python
使用Python实现租车计费系统的两种方法
Sep 29 #Python
Python实现App自动签到领取积分功能
Sep 29 #Python
10个Python小技巧你值得拥有
Sep 29 #Python
实例分析python3实现并发访问水平切分表
Sep 29 #Python
3个用于数据科学的顶级Python库
Sep 29 #Python
You might like
WAR3重制版DOTA 5V5初体验
2020/04/09 DOTA
PHP的autoload机制的实现解析
2012/09/15 PHP
利用php获取服务器时间的实现代码
2013/06/07 PHP
php利用反射实现插件机制的方法
2015/03/14 PHP
php快速排序原理与实现方法分析
2016/05/26 PHP
详解如何在云服务器上部署Laravel
2017/06/30 PHP
PHP实现的最大正向匹配算法示例
2017/12/19 PHP
用roll.js实现的图片自动滚动+鼠标触动的特效
2007/03/18 Javascript
基于jQuery实现表格数据的动态添加与统计的代码
2011/01/31 Javascript
Javascript 判断是否存在函数的方法
2013/01/03 Javascript
js判断undefined类型示例代码
2014/02/10 Javascript
JS获取文本框,下拉框,单选框的值的简单实例
2014/02/26 Javascript
深入探讨JavaScript String对象
2015/03/09 Javascript
JS验证IP,子网掩码,网关和MAC的方法
2015/07/02 Javascript
用户代理字符串userAgent可实现的四个识别
2015/09/20 Javascript
JavaScript实现打开链接页面的方式汇总
2016/06/02 Javascript
模仿password输入框的实现代码
2016/06/07 Javascript
AngularJS实现一次监听多个值发生的变化
2016/08/31 Javascript
Canvas实现放射线动画效果
2017/02/15 Javascript
vue-router 中router-view不能渲染的解决方法
2017/05/23 Javascript
详解在AngularJS的controller外部直接获取$scope
2017/06/02 Javascript
如何去除vue项目中的#及其ie9兼容性
2018/01/11 Javascript
微信小程序实现注册登录功能(表单校验、错误提示)
2019/12/10 Javascript
原生JavaScript创建不可变对象的方法简单示例
2020/05/07 Javascript
使用Python的Treq on Twisted来进行HTTP压力测试
2015/04/16 Python
python开发之文件操作用法实例
2015/11/13 Python
Python多继承原理与用法示例
2018/08/23 Python
详解Python流程控制语句
2020/10/28 Python
python压包的概念及实例详解
2021/02/17 Python
给老婆的婚前保证书
2014/02/01 职场文书
九年级语文教学反思
2014/02/04 职场文书
大学生入党积极分子党校学习思想汇报
2014/10/25 职场文书
领导干部学习三严三实心得体会
2016/01/05 职场文书
教你用Python写一个植物大战僵尸小游戏
2021/04/25 Python
Spring Cloud Gateway去掉url前缀
2021/07/15 Java/Android
使用Java去实现超市会员管理系统
2022/03/18 Java/Android