Change-Id: I423ad03e63bd38aded3abfcba49079ff2fbb3b74 Signed-off-by: Li Yi <denverdino@gmail.com>
181 lines
9.8 KiB
Markdown
181 lines
9.8 KiB
Markdown
# AliyunGo: Go SDK for Aliyun Services
|
|
|
|
[data:image/s3,"s3://crabby-images/6667d/6667dfd7ffdfd835c4b9e10e36cdde7af3fe24ce" alt="Build Status"](https://travis-ci.org/denverdino/aliyungo) [data:image/s3,"s3://crabby-images/38251/3825180d2804bccd1a07c7d8fc5e1d1438365cd5" alt="CircleCI"](https://circleci.com/gh/denverdino/aliyungo) [data:image/s3,"s3://crabby-images/ebfea/ebfea069703e660d07b139f1094304b715b3396a" alt="Go Report Card"](https://goreportcard.com/report/github.com/denverdino/aliyungo)
|
|
|
|
This is an unofficial Go SDK for Aliyun services. You are welcome for contribution.
|
|
|
|
The official SDK for Aliyun services is published. Please visit https://github.com/aliyun/alibaba-cloud-sdk-go for details
|
|
|
|
## Package Structure
|
|
|
|
* cdn: [Content Delivery Network](https://help.aliyun.com/document_detail/27101.html)
|
|
* cms: [Cloud Monitor Service](https://help.aliyun.com/document_detail/28615.html)
|
|
* cs: [Container Service](https://help.aliyun.com/product/25972.html)
|
|
* dm: [Direct Mail](https://help.aliyun.com/document_detail/29414.html)
|
|
* dns: [DNS](https://help.aliyun.com/document_detail/dns/api-reference/summary.html)
|
|
* ecs: [Elastic Compute Service](https://help.aliyun.com/document_detail/ecs/open-api/summary.html)
|
|
* ess: [Auto Scaling](https://help.aliyun.com/document_detail/25857.html)
|
|
* mns: [Message Service](https://help.aliyun.com/document_detail/27414.html)
|
|
* mq: [Message Queue](https://help.aliyun.com/document_detail/29532.html)
|
|
* nas: [Network Attached Storage](https://help.aliyun.com/document_detail/27518.html)
|
|
* opensearch: [OpenSearch](https://help.aliyun.com/document_detail/29118.html)
|
|
* oss: [Open Storage Service](https://help.aliyun.com/document_detail/oss/api-reference/abstract.html)
|
|
* push: [Cloud Mobile Push](https://help.aliyun.com/document_detail/30049.html)
|
|
* rds: [Relational Database Service](https://help.aliyun.com/document_detail/26226.html)
|
|
* ram: [Resource Access Management](https://help.aliyun.com/document_detail/ram/ram-api-reference/intro/intro.html)
|
|
* slb: [Server Load Balancer](https://help.aliyun.com/document_detail/slb/api-reference/brief-introduction.html)
|
|
* sls: [Logging Service](https://help.aliyun.com/document_detail/sls/api/overview.html)
|
|
* sms: [Short Message Service](https://help.aliyun.com/product/44282.html)
|
|
* sts: [Security Token Service](https://help.aliyun.com/document_detail/28756.html)
|
|
* common: Common libary of Aliyun Go SDK
|
|
* util: Utility helpers
|
|
|
|
## Quick Start
|
|
|
|
```go
|
|
package main
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/denverdino/aliyungo/ecs"
|
|
)
|
|
|
|
const ACCESS_KEY_ID = "<YOUR_ID>"
|
|
const ACCESS_KEY_SECRET = "<****>"
|
|
|
|
func main() {
|
|
client := ecs.NewClient(ACCESS_KEY_ID, ACCESS_KEY_SECRET)
|
|
fmt.Print(client.DescribeRegions())
|
|
}
|
|
|
|
```
|
|
|
|
## Documentation
|
|
|
|
* CDN: [https://godoc.org/github.com/denverdino/aliyungo/cdn](https://godoc.org/github.com/denverdino/aliyungo/cdn)[data:image/s3,"s3://crabby-images/02d82/02d828ce28807953862d2be82f145f98acf19b13" alt="GoDoc"](https://godoc.org/github.com/denverdino/aliyungo/cdn)
|
|
* CMS: [https://godoc.org/github.com/denverdino/aliyungo/cms](https://godoc.org/github.com/denverdino/aliyungo/cms) [data:image/s3,"s3://crabby-images/856f4/856f43f417eb9ad5f6aa7d3f3bd7b0146490735d" alt="GoDoc"](https://godoc.org/github.com/denverdino/aliyungo/cms)
|
|
* CS: [https://godoc.org/github.com/denverdino/aliyungo/cs](https://godoc.org/github.com/denverdino/aliyungo/cs) [data:image/s3,"s3://crabby-images/52dd6/52dd66a783ffb0915bdda51303ae1efa64ef9861" alt="GoDoc"](https://godoc.org/github.com/denverdino/aliyungo/cs)
|
|
* DM: [https://godoc.org/github.com/denverdino/aliyungo/dm](https://godoc.org/github.com/denverdino/aliyungo/dm) [data:image/s3,"s3://crabby-images/f2dff/f2dffdfa56c97cbd64dab832a82131e856fde5c2" alt="GoDoc"](https://godoc.org/github.com/denverdino/aliyungo/dm)
|
|
* DNS: [https://godoc.org/github.com/denverdino/aliyungo/dns](https://godoc.org/github.com/denverdino/aliyungo/dns) [data:image/s3,"s3://crabby-images/22a56/22a56ff3d1d7498a8c0b96223ebc528cb42412f2" alt="GoDoc"](https://godoc.org/github.com/denverdino/aliyungo/dns)
|
|
* ECS: [https://godoc.org/github.com/denverdino/aliyungo/ecs](https://godoc.org/github.com/denverdino/aliyungo/ecs) [data:image/s3,"s3://crabby-images/71361/7136129d98110ba4e2c26cb57d07ca8baa961cde" alt="GoDoc"](https://godoc.org/github.com/denverdino/aliyungo/ecs)
|
|
* ESS: [https://godoc.org/github.com/denverdino/aliyungo/ess](https://godoc.org/github.com/denverdino/aliyungo/ess)[data:image/s3,"s3://crabby-images/50a3e/50a3eeb4e27c305920065235b42ad3e6b7fb05c8" alt="GoDoc"](https://godoc.org/github.com/denverdino/aliyungo/ess)
|
|
* MNS: [https://godoc.org/github.com/denverdino/aliyungo/mns](https://godoc.org/github.com/denverdino/aliyungo/mns)[data:image/s3,"s3://crabby-images/74538/7453885ed4b165b2f37044a4e3cb1dec941ea125" alt="GoDoc"](https://godoc.org/github.com/denverdino/aliyungo/mns)
|
|
* MQ: [https://godoc.org/github.com/denverdino/aliyungo/mq](https://godoc.org/github.com/denverdino/aliyungo/mq) [data:image/s3,"s3://crabby-images/add6c/add6c3e91c28b66c3b7410ce27c47a4ae3dbcf6b" alt="GoDoc"](https://godoc.org/github.com/denverdino/aliyungo/mq)
|
|
* NAS: [https://godoc.org/github.com/denverdino/aliyungo/nas](https://godoc.org/github.com/denverdino/aliyungo/nas) [data:image/s3,"s3://crabby-images/25630/25630547cf2d27cdd8a08f220cd458ee7b2b62e2" alt="GoDoc"](https://godoc.org/github.com/denverdino/aliyungo/nas)
|
|
* OPENSEARCH: [https://godoc.org/github.com/denverdino/aliyungo/opensearch](https://godoc.org/github.com/denverdino/aliyungo/opensearch) [data:image/s3,"s3://crabby-images/d43e7/d43e73c3e66d607681320e78ae3894e5972c0c0a" alt="GoDoc"](https://godoc.org/github.com/denverdino/aliyungo/opensearch)
|
|
* OSS: [https://godoc.org/github.com/denverdino/aliyungo/oss](https://godoc.org/github.com/denverdino/aliyungo/oss) [data:image/s3,"s3://crabby-images/82297/822975f0590c89788a6ad5f8582d0aff1be9e116" alt="GoDoc"](https://godoc.org/github.com/denverdino/aliyungo/oss)
|
|
* PUSH: [https://godoc.org/github.com/denverdino/aliyungo/push](https://godoc.org/github.com/denverdino/aliyungo/push) [data:image/s3,"s3://crabby-images/8eb9e/8eb9e1e7e8d4d3a9562c771bb5a783ee5b8bd0d0" alt="GoDoc"](https://godoc.org/github.com/denverdino/aliyungo/push)
|
|
* RAM: [https://godoc.org/github.com/denverdino/aliyungo/ram](https://godoc.org/github.com/denverdino/aliyungo/ram) [data:image/s3,"s3://crabby-images/dfd6a/dfd6a0f53af9f42286c812e9a295cfa6767ffaae" alt="GoDoc"](https://godoc.org/github.com/denverdino/aliyungo/ram)
|
|
* RDS: [https://godoc.org/github.com/denverdino/aliyungo/rds](https://godoc.org/github.com/denverdino/aliyungo/rds) [data:image/s3,"s3://crabby-images/ad98a/ad98ac6f9dc929ff0f0ccb4f5a148a0ffeee8d1a" alt="GoDoc"](https://godoc.org/github.com/denverdino/aliyungo/rds)
|
|
* SLB: [https://godoc.org/github.com/denverdino/aliyungo/slb](https://godoc.org/github.com/denverdino/aliyungo/slb) [data:image/s3,"s3://crabby-images/37724/3772435ca93e89890b4a832915e0bdeb2e15ce9c" alt="GoDoc"](https://godoc.org/github.com/denverdino/aliyungo/slb)
|
|
* SLS: [https://godoc.org/github.com/denverdino/aliyungo/sls](https://godoc.org/github.com/denverdino/aliyungo/sls) [data:image/s3,"s3://crabby-images/15f17/15f174a57b8da7a91b078123eefa9be5b7b4a5fa" alt="GoDoc"](https://godoc.org/github.com/denverdino/aliyungo/sls)
|
|
* SMS: [https://godoc.org/github.com/denverdino/aliyungo/sms](https://godoc.org/github.com/denverdino/aliyungo/sms) [data:image/s3,"s3://crabby-images/2a4b1/2a4b1cdab2ff60d543e40afdf68782ea3e929333" alt="GoDoc"](https://godoc.org/github.com/denverdino/aliyungo/sms)
|
|
* STS: [https://godoc.org/github.com/denverdino/aliyungo/sts](https://godoc.org/github.com/denverdino/aliyungo/sts) [data:image/s3,"s3://crabby-images/d4594/d4594188a344e4382ed46375c2630d1aef8e05ae" alt="GoDoc"](https://godoc.org/github.com/denverdino/aliyungo/sts)
|
|
|
|
## Build and Install
|
|
|
|
go get:
|
|
|
|
```sh
|
|
go get github.com/denverdino/aliyungo
|
|
```
|
|
|
|
## Test ECS
|
|
|
|
Modify "ecs/config_test.go"
|
|
|
|
```sh
|
|
TestAccessKeyId = "MY_ACCESS_KEY_ID"
|
|
TestAccessKeySecret = "MY_ACCESS_KEY_ID"
|
|
TestInstanceId = "MY_INSTANCE_ID"
|
|
TestIAmRich = false
|
|
```
|
|
|
|
* TestAccessKeyId: the Access Key Id
|
|
* TestAccessKeySecret: the Access Key Secret.
|
|
* TestInstanceId: the existing instance id for testing. It will be stopped and restarted during testing.
|
|
* TestIAmRich(Optional): If it is set to true, it will perform tests to create virtual machines and disks under your account. And you will pay the bill. :-)
|
|
|
|
Under "ecs" and run
|
|
|
|
```sh
|
|
go test
|
|
```
|
|
|
|
## Test OSS
|
|
|
|
Modify "oss/config_test.go"
|
|
|
|
```sh
|
|
TestAccessKeyId = "MY_ACCESS_KEY_ID"
|
|
TestAccessKeySecret = "MY_ACCESS_KEY_ID"
|
|
TestRegion = oss.Beijing
|
|
TestBucket = "denverdino"
|
|
```
|
|
|
|
* TestAccessKeyId: the Access Key Id
|
|
* TestAccessKeySecret: the Access Key Secret.
|
|
* TestRegion: the region of OSS for testing
|
|
* TestBucket: the bucket name for testing
|
|
|
|
Under "oss" and run
|
|
|
|
```sh
|
|
go test
|
|
```
|
|
|
|
## Contributors
|
|
|
|
* Li Yi (denverdino@gmail.com)
|
|
* Boshi Lian (farmer1992@gmail.com)
|
|
* Yu Zhou (oscarrr110@gmail.com)
|
|
* Yufei Zhang
|
|
* linuxlikerqq
|
|
* Changhai Yan
|
|
* Jizhong Jiang (jiangjizhong@gmail.com)
|
|
* Kent Wang (pragkent@gmail.com)
|
|
* ringtail
|
|
* aiden0z (aiden0xz@gmail.com)
|
|
* jimmycmh
|
|
* menglingwei
|
|
* mingang.he (dustgle@gmail.com)
|
|
* Young Chen (chainone@gmail.com)
|
|
* johnzeng
|
|
* spacexnice (445436286@qq.com)
|
|
* xiaoheihero
|
|
* hmgle (dustgle@gmail.com)
|
|
* jzwlqx (jiangjizhong@gmail.com)
|
|
* Linhua Tan (toolchainX@gmail.com)
|
|
* Plutonist (p@vecsight.com)
|
|
* Bin Liu
|
|
* wangyue
|
|
* demonwy
|
|
* yarous224
|
|
* yufeizyf (xazyf9111@sina.cn)
|
|
* keontang (ikeontang@gmail.com)
|
|
* Cholerae Hu (me@cholerae.com)
|
|
* Zach Bergh (berghzach@gmail.com)
|
|
* Bingshen Wang
|
|
* xiaozhu36
|
|
* Russell (yufeiwu@gmail.com)
|
|
* zhuzhih2017
|
|
* cheyang
|
|
* Hobo Chen
|
|
* Shuwei Yin
|
|
* Xujin Zheng (xujinzheng@gmail.com)
|
|
* Dino Lai (dinos80152@gmail.com)
|
|
|
|
## License
|
|
|
|
This project is licensed under the Apache License, Version 2.0. See [LICENSE](https://github.com/denverdino/aliyungo/blob/master/LICENSE.txt) for the full license text.
|
|
|
|
## Related projects
|
|
|
|
* Aliyun ECS driver for Docker Machine: [Pull request](https://github.com/docker/machine/pull/1182)
|
|
|
|
* Aliyun OSS driver for Docker Registry V2: [Pull request](https://github.com/docker/distribution/pull/514)
|
|
|
|
## References
|
|
|
|
The GO API design of OSS refer the implementation from [https://github.com/AdRoll/goamz](https://github.com/AdRoll)
|