Rancher-API使用珠玑-创新互联
功能
成都创新互联公司是一家集网站建设,章贡企业网站建设,章贡品牌网站建设,网站定制,章贡网站建设报价,网络营销,网络优化,章贡网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。使用 rancher-api 能带来什么:
可以自定义 rancher-UI
可以在自有的业务系统中触发对 rancher 的各种操作
可以定制一些自己的自动化脚本
分类
Rancher-api 目前包括两大类:
http://
/v1 主要服务的 api http://
/v1-catalog 分离出来的catalog api
在已经登录 Rancher UI 的情况下,直接访问上面的地址就可以看到 API 页面。
语言
在实际的开发中,我们更喜欢调用 Client SDk 来使用 API,Rancher 提供了以下几种语言的Client:
Python:gdapi-python / cattle-cli
Golang:go-rancher
Java:gdapi-java-server
认证方式
1. 使用 jwt-token
向 v1/token 发送 post 请求生成 token:
然后把 token 设置到 cookie 中,在浏览器端后续请求会自动带上 token,目前 rancher UI 使用的是这种方式。
2. 使用api key (access_key & access_secret)
Api key 的生成
此处有两种key:作用域在某个env下的env-key,和作用域在该用户下所有env下的global-key。
这里 advanced options UI 上默认是不展开的。
生成好的 api key,配合 cattle-cli/gdapi 之类的 client 库就可以使用。
3. 使用Basic auth方式
这种方式同样需要api key,但是使用方式略不一样,先对 api key 进行编码 Base64.encode(“key: secret”)
为什么要提这种方式?
因为目前 catalog api 还不能用 client lib 直接调用,但是可以用这种方式调用。
Rancher 的高级选项
在 V1/setting 下面,有很多可配置的高级选项,可以进行手动编辑。
可以修改 jwt token 的有效时间,默认是 16 小时内 token 有效。
Auditlog 是 Rancher 审计日志,一般频繁操作 Rancher 会导致 Auditlog 激增,Rancher 提供了以周期性的 purge 机制,可以根据自己数据库容量调整这个周期。
Rancher-compose 的各种下载地址,尤其是在国内可以把这个改成自己的地址,方便下载。
Rancher 私有网络的 cidr 也可以修改 :
Rancher 目前兼容 docker1.10.3,所以 Rancher 提供了一个安装该版本的 shell 脚本,这个脚本会在 Add Host 使用其他 driver 时用到,我们可以把里面的内容源指定到国内,提高 dockerengine 的安装速度,从而快速部署 Host。
v1/settings 的高级功能等待大家细细挖掘,最后 Rancher-api有一个说明文档可以看这里:
https://github.com/rancher/api-spec/blob/master/specification.md
其中的语义定义和 api 的组织结构等,都是值得学习的。
另外 api-v2 之前也启动过https://github.com/rancher/v2-api,但是后来由于 GA 发布和多编排引擎的支持,这件事暂时搁置了,相信不久后会重启 v2 的开发,V2 版本是基于Golang的。
最后提醒大家需要注意的是,v1版本的api的语义和UI上有歧义,rancher-docs 里也有提到这部分。
原文来源:Rancher Labs
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
分享题目:Rancher-API使用珠玑-创新互联
文章位置:http://myzitong.com/article/cejgic.html