Skip to content

create aliyun spot auto. 自动创建阿里云抢占式实例,支持自动释放或手动释放。

Notifications You must be signed in to change notification settings

zlxzfg/aliyun_spot

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

7 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

aliyun_spot

自动创建阿里云抢占式实例。

背景

阿里云抢占式实例应该属于阿里云的一种闲置资源利用,性价比非常高,每小时的价格在 0.01 ~ 0.05 每小时,具体根据不同的配置和地域有差别,流量价格小于 1元/G.

抢占式实例最高可以以一折的价格购买 ECS 实例,并能稳定持有该实例至少一个小时。一个小时后,当市场价格高于您的出价或资源供需关系变化时,抢占式实例会被自动释放,请做好数据备份工作。

非常适合爬虫

非常适合爬虫

非常适合爬虫

也适合程序员个人日常开发使用,上班来创建,下班释放,开销基本可以控制在在 1毛 ~ 2 毛。

对于我来说,最近在写一个爬虫,看了很多代理都很贵,免费的又不稳定,正好了解到阿里云的抢占式实例,所以非常满足我的需求。

但是要注意,这个实例是有可能被释放的,但是不用担心,比如香港地区的释放率最近(2020-08-19)小于 3%. 另外,每个人可以最大创建 100 个实例,所以还是不用太担心。

脚本功能

自动创建阿里云抢占式实例

支持以下一些参数:

  • 实例所属地域
  • 创建的实例数量
  • 公网出口带宽最大值
  • 实例付费的策略和每小时最大价格
  • 系统盘大小
  • 释放时间(hours)
  • 实例规格(cpu/mem/localdisk/net/ipv6)

手动释放一个或者多个实例

可以使用脚本提前释放一个或者多个实例。

创建的时候可以设置自动释放时间,当然也支持随时手动释放

如何使用

$ python run_aliyunspot.py
usage: run_aliyunspot.py [-h] [-c [CREATE]] [-r [RELEASE]] [-l [LIST]] [-s [SPOTID [SPOTID ...]]]

aliyunspot, 自动创建阿里云抢占式实例,支持自动/手动释放

optional arguments:
  -h, --help            show this help message and exit
  -c [CREATE], --create [CREATE]
                        create aliyun spot instance and run instance
  -r [RELEASE], --release [RELEASE]
                        release aliyun spot instance
  -l [LIST], --list [LIST]
                        list local record aliyun spot instance
  -s [SPOTID [SPOTID ...]], --spotid [SPOTID [SPOTID ...]]
                        aliyun spot instance_id for release, you can give more than one

1 克隆仓库

$ git clone https://github.com/smaugx/aliyun_spot.git
$ cd aliyun_spot
$ virtualenv -p python3 vv
$ source vv/bin/activate
$ pip install -r requirements.txt

2 调整配置

$ cp test_config.py config.py
# 打开配置文件,根据你自己的需求修改里面的配置选项
$ vim config.py

当然你也可以不用修改其他配置,只需要把你的 access_idaccess_secret 填进去就可以,以及 key_pair_name 填进去。(见后文章节 #阿里云官网操作#

默认创建的是香港地区的抢占式实例,内存 500MB, 1 CPU, 系统盘 20GB, 按流量计费(1元/G), 公网出口带宽 10Mbps, 1 小时候自动释放。

2020-08-19 上述默认配置的实例价格在 ¥ 0.018 /时。

如果你觉得这个配置(cpu/mem)无法满足你的要求,那么可以调整 instance_type 这个参数,表示实例规格,详细可以查看阿里云官网页面 云服务器 ECS > 实例 > 实例规格族

3 创建实例

$ python run_aliyunspot.py -c
will create and run aliyun spot instance, please wait...
Success. Instance creation succeed. InstanceIds: i-j6cfhcbb3o2pepduwgfk
Instance boot successfully: i-j6cfhcbb3o2pepduwgfk
Instances all boot successfully


InstanceId:i-j6cfhcbb3o2pepduwgfk
InstanceName:smaug-000-aliyun-8242148
HostName:smaug-000-aliyun-8242148
PublicIp:47.242.33.179
KeyPairName:aliyunspot
CreationTime:2020-08-24T13:48Z
AutoReleaseTime:2020-08-24T22:48Z


instance info saved in file:./ecs/ecs.i-j6cfhcbb3o2pepduwgfk
now you can use ssh: ssh -i ~/.ssh/aliyunspot.pem [email protected]

如上,创建成功。然后接下来就可以使用 ssh 登录:

$ ssh -i ~/.ssh/~/.ssh/aliyunspot.pem [email protected]

4 列出实例

$ python run_aliyunspot.py -l
list all local record instance:
['i-j6caz353cisgl3fzenwi', 'i-j6cbyis12fb1fpzk59fv', 'i-j6cfhcbb3o2pepduwgfk']

注意,上面仅仅是把之前创建并保存的实例信息从文件当中读取出来,并没有与 aliyun 交互。

5 释放实例

$ python run_aliyunspot.py -r -s i-j6caz353cisgl3fzenwi i-j6cbyis12fb1fpzk59fv
will release aliyun spot instance:
['i-j6caz353cisgl3fzenwi', 'i-j6cbyis12fb1fpzk59fv']
please wait...

release instance:["i-j6caz353cisgl3fzenwi", "i-j6cbyis12fb1fpzk59fv"] done

上面提到了几个配置是需要在阿里云官网操作的。

阿里云官网的使用还是挺复杂的,因为功能太多了,花费了我至少一个上午的时间才熟悉了整个操作,完成了整个脚本

所以整理了这个脚本方便大家使用,对阿里云的操作只需要下面几个:

  • 注册一个阿里云账号,这个不用说了吧
  • 充值 100 元以上,比如 130 元。因为创建实例账号里至少要 100 元
  • 点击 https://ram.console.aliyun.com/overview 创建一个用户组,分配权限 AliyunECSFullAccess 和 AliyunVPCFullAccess
  • 还是上一步的页面,添加 ram 子账号,添加到刚才创建的用户组,这个账号会用来编程访问 aliyun API
  • 还是上一步的页面,为这个ram 子账号创建 AccessKey。记得保存好
  • https://ecs.console.aliyun.com/ 页面选择 网络与安全-密钥对,创建密钥对 aliyunspot (名字任意),会自动下载这个私钥,记得保存好,一般要放到 ~/.ssh 目录下,并且记得 chmod 600 aliyunspot.pem

OK, 到这里基本上得到了我们脚本里需要的几个配置:

  • access_id
  • access_secret
  • key_pair_name

把上述几个配置填到 config.py 中即可。

然后开始创建和管理你的实例吧!!

然后开始创建和管理你的实例吧!!

然后开始创建和管理你的实例吧!!

About

create aliyun spot auto. 自动创建阿里云抢占式实例,支持自动释放或手动释放。

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%