python云服务技术(Python脚本修改阿里云的访问控制列表的方法)
类别:脚本大全 浏览量:283
时间:2022-01-15 01:30:17 python云服务技术
Python脚本修改阿里云的访问控制列表的方法需求
对于部署在阿里云上的重要系统一般是不让其他人访问的,所以会在负载均衡(SLB)上加上访问控制列表。而使用ASDL拨号上网的宽带来说一般公网IP都不会固定的,会随时变更公网IP,所以此脚本正是解决此需求。
说明
脚本运行前需要先安装aliyun-python-sdk-core 和aliyun-python-sdk-slb 2个sdk,并且在阿里云账户里面创建access_key和access_secret。
脚本会查询到目前的公网IP,如何创建本地一个文件将IP记录到文件里,下次执行时会将查询到的IP和文件里的对比,如果IP和文件里记录的IP不一致则将IP添加到访问控制列表里。
最后只需要在服务器里每隔一段时间执行一次此脚本就OK。
sdk 下载:https://developer.aliyun.com/tools/sdk#/python
提醒
如果是重要的数据在公网传输,还是尽量使用加密传输。毕竟阿里云的SSL 和IPSEC 也很完善了,推荐使用。
|
#!/usr/bin/env python3 #coding:utf-8 from aliyunsdkcore import client import time,requests from aliyunsdkslb.request.v20140515 import AddAccessControlListEntryRequest from aliyunsdkcore.profile import region_provider #region_provider.modify_point('slb', '<regionId>', 'slb.<regionId>.aliyuncs.com') # 名称:阿里云负载均衡白名单自动修改脚本 ### 变量配置 ### # 保存历史IP地址的文件名 file_save_ipaddr = 'ipaddr.txt' # 一些可以获取本机出口IP的API地址 ip_api_list = 'http://icanhazip.com,http://ident.me,http://ifconfig.me,http://ipecho.net/plain,http://whatismyip.akamai.com,http://myip.dnsomatic.com' # SLB 配置,此 Access Key 只需添加 ACL 的权限 aliyun_access_key = 'xxxxxxxxx' aliyun_access_secret = 'xxxxxxxxxxxxxx' # 在这里可以获取region:https://help.aliyun.com/document_detail/40654.html aliyun_region = 'cn-hangzhou' # 访问列表一(acl-bp1792k8uvk11xxpgu5l) # 访问列表二(acl-bp1okd1kud9a41kyjkja) # 需要修改的ACL的ID,进入负载均衡控制台 -> 访问控制 -> 策略ID aliyun_acl_id = [ 'acl-bp1okd1kud9a41kyjkja' , 'acl-bp1792k8uvk11xxpgu5l' ] ### 配置结束 ### def getExitIpAddr(ip_api_list): '''获取出口IP地址''' url_list = str (ip_api_list).split( ',' ) ip = None for url in url_list: resp = requests.get(url,timeout = 3 ) if resp.status_code = = 200 : ip = resp.text.strip() break return ip def setAcl(access_key,access_secret,region,acl_id,ip): '''修改ACL''' clt = client.AcsClient(access_key,access_secret,region) # 设置参数 request = AddAccessControlListEntryRequest.AddAccessControlListEntryRequest() request.set_accept_format( 'json' ) request.add_query_param( 'AclId' ,acl_id) request.add_query_param( 'RegionId' ,region) request.add_query_param( 'Tags' , 'API自动添加' ) request.add_query_param( 'AclEntrys' , '[{{"entry":"{ip}/32","comment":"此处是注释{d}"}}]' . format (ip = ip,d = time.strftime( "%Y-%m-%d" ,time.localtime()))) #添加ip并添加注释 # 发起请求 response = clt.do_action_with_exception(request) print (response) def getSavedIp(filename): '''获取已保存的IP''' try : with open (filename, 'r' ,encoding = 'utf-8' ) as f: return f.readline() except IOError: print ( "文件不存在" ) def saveNewIp(filename,ipaddr): '''保存新IP''' with open (filename, 'w' ,encoding = 'utf-8' ) as f: f.write(ipaddr) def main(): current_ip = getExitIpAddr(ip_api_list) saved_ip = getSavedIp(file_save_ipaddr) print ( '当前IP' ,current_ip) print ( '保存的IP' ,saved_ip) if current_ip = = saved_ip: print ( 'IP无变化' ) exit( 0 ) else : for acl_id in aliyun_acl_id: setAcl(access_key = aliyun_access_key, access_secret = aliyun_access_secret, region = aliyun_region, acl_id = acl_id, ip = current_ip) time.sleep( 5 ) saveNewIp(file_save_ipaddr,current_ip) if __name__ = = '__main__' : main() |
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持开心学习网。
原文链接:https://blog.51cto.com/billy98/2358807
您可能感兴趣
- 阿里云服务器加载镜像操作手册(阿里云、腾讯云、小鸟云服务器中安装wdcp图文教程)
- docker添加mq基础镜像(Docker阿里云RocketMQ 4.5.1部署流程详解)
- 阿里云服务器怎么搭建环境(阿里云服务器快速配置php环境的方法)
- 阿里云对象存储oss请求次数(阿里云服务器本地上传到OSS对象存储节点)
- filezilla搭建ftp服务教程(FileZilla 425 无法连接FTP的解决方法阿里云服务器)
- 普通人如何申请阿里云账号(怎么注册阿里云账号 阿里云帐号怎么申请)
- docker 更新容器到镜像(Docker容器如何更新打包并上传到阿里云)
- 阿里云网站cdn加速(阿里云CDN刷新链接接口实践)
- 阿里云服务ecs操作系统(阿里云ECS服务器CentOS7上安装服务器安全狗Linux版)
- 阿里云轻量级服务器怎么安装宝塔(阿里云服务器安装宝塔面板和配置安全组图文教程)
- 两个阿里云账号服务器内网通信(阿里云服务器怎么与租用香港服务器组内网?)
- 怎样解除阿里云账号(如何注销阿里云账号 阿里云账号注销图文教程)
- 阿里云的补丁更新应该怎么打(阿里云安骑士企业版有什么作用?)
- 阿里云ecs属于哪种云服务(阿里的轻云服务器、虚拟主机、云服务器ECS的区别?)
- 阿里云ecs和轻量服务器(阿里云ECS服务器入门使用流程推荐)
- docker阿里云服务器教程(Docker安装阿里云服务器和在虚拟机安装遇到的坑问题小结)
- Beyond 版本《无人深空》主线任务攻略 阿特拉斯之道(版本无人深空主线任务攻略)
- 全球科技界最有钱大佬TOP 15 你知道几位(全球科技界最有钱大佬TOP)
- 2主力后腰缺阵 泰山队奇兵有望获重用,赛季0出场,迎来中超首秀(泰山队奇兵有望获重用)
- 三分71 生死战爆发 篮网旧将丁威迪今天成奇兵,助队赢球(三分71生死战爆发)
- 《红 雄安》系列广播剧第一集 水上奇兵雁翎队(雄安系列广播剧第一集)
- 小说 小伙穿越成刘备,用现代知识指挥作战,众谋士都看呆了(小伙穿越成刘备)
热门推荐
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9