https://github.com/ucloud/ucloud-cli
UCloud Command Line Interface
https://github.com/ucloud/ucloud-cli
Last synced: 11 months ago
JSON representation
UCloud Command Line Interface
- Host: GitHub
- URL: https://github.com/ucloud/ucloud-cli
- Owner: ucloud
- License: apache-2.0
- Created: 2018-08-30T12:28:56.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2024-09-20T06:38:25.000Z (over 1 year ago)
- Last Synced: 2025-03-14T19:15:00.401Z (12 months ago)
- Language: Go
- Size: 8.25 MB
- Stars: 98
- Watchers: 24
- Forks: 43
- Open Issues: 2
-
Metadata Files:
- Readme: README-CN.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
[English](./README.md) | 简体中文
## UCloud CLI

UCloud CLI为管理UCloud平台上的资源和服务提供了一致性的操作接口,它使用[ucloud-sdk-go](https://github.com/ucloud/ucloud-sdk-go)调用[UCloud OpenAPI](https://docs.ucloud.cn/api/summary/overview),从而实现对资源和服务的操作,兼容Linux, macOS和Windows平台 https://docs.ucloud.cn/developer/cli/index
## 在macOS或Linux平台安装UCloud-CLI
**通过Homebrew安装(在macOS平台上推荐此方式)**
[Homebrew](https://docs.brew.sh/Installation) 是macOS平台上非常流行的包管理工具,您可以通过如下命令轻松安装或升级UCloud-CLI
安装UCloud-CLI
```
brew install ucloud
```
升级到最新版本
```
brew upgrade ucloud
```
如果安装过程中遇到错误,请先执行如下命令更新Homebrew
```
brew update
```
如果问题依然存在,执行如下命令获取更多帮助
```
brew doctor
```
**基于源代码编译(需要本地安装golang)**
如果您已经安装了git和golang在您的平台上,您可以使用如下命令下载源代码并编译
```
git clone https://github.com/ucloud/ucloud-cli.git
cd ucloud-cli
make install
```
升级到最新版本
```
cd /path/to/ucloud-cli
git pull
make install
```
**下载已编译好的二进制可执行文件(Linux上如果选不到非常方便的安装方式,推荐用此办法安装)**
打开ucloud-cli的[发布页面](https://github.com/ucloud/ucloud-cli/releases),找到适合您平台的ucloud-cli压缩包。点击链接进行下载,下载后,通过比对sha256摘要来检验下载文件未被劫持,然后把ucloud-cli可执行文件解压到$PATH环境变量包含的目录,操作命令如下:
举个例子
```
curl -OL https://github.com/ucloud/ucloud-cli/releases/download/0.1.23/ucloud-cli-linux-0.1.23-amd64.tgz
echo "b480f8621e8d0bd2c121221857029320eb49be708f4d7cb1b197cdc58b071c09 *ucloud-cli-linux-0.1.23-amd64.tgz" | shasum -c //检查下载的tar包是否被劫持,从发布页面获取sha256摘要
tar zxf ucloud-cli-linux-0.1.23-amd64.tgz -C /usr/local/bin/
```
## 在Windows平台上安装UCloud-CLI
**基于源代码编译**
从UCloud-CLI的[发布页面](https://github.com/ucloud/ucloud-cli/releases)下载源代码并解压,您也可以通过git下载源代码,打开Git Bash, 执行命令```git clone https://github.com/ucloud/ucloud-cli.git```。
切换到源代码所在的目录,编译源代码(执行命令 ```go build -mod=vendor -o ucloud.exe```),然后把可执行文件ucloud.exe所在目录添加到PATH环境变量中,具体操作可参看[文档](https://www.java.com/en/download/help/path.xml)
配置完成后,打开终端(cmd或power shell),执行命令```ucloud --version```检查是否安装成功。
**下载二进制可执行文件**
打开ucloud-cli的[发布页面](https://github.com/ucloud/ucloud-cli/releases),找到适合您平台的ucloud-cli压缩包。点击链接进行下载并解压,然后把可执行文件ucloud.exe所在目录添加到PATH环境变量中,添加环境变量的操作可参考[文档](https://www.java.com/en/download/help/path.xml)
## 在Docker容器中使用UCloud-CLI
如果您已安装Docker, 通过如下命令拉取已打包UCloud-CLI的镜像。镜像打包[Dockerfile](./Dockerfile)
```
docker pull uhub.service.ucloud.cn/ucloudcli/ucloud-cli:source-code
```
基于此镜像创建容器
```
docker run --name ucloud-cli -it -d uhub.service.ucloud.cn/ucloudcli/ucloud-cli:source-code
```
连接到容器,开始使用UCloud-CLI
```
docker exec -it ucloud-cli zsh
```
## 开启命令补全(bash或zsh shell)
UCloud-CLI支持命令自动补全,开启后,您只需要输入命令的部分字符,然后敲击Tab键即可自动补全命令的其余字符。
**Bash shell**
把如下代码添加到文件~/.bash_profile 或 ~/.bashrc中,然后source <~/.bash_profile|~/.bashrc>,或打开一个新终端,命令补全即生效
```
complete -C $(which ucloud) ucloud
```
**Zsh shell**
把如下代码添加到文件~/.zshrc中,然后source ~/.zshrc,或打开一个新终端,命令补全即生效
```
autoload -U +X bashcompinit && bashcompinit
complete -F $(which ucloud) ucloud
```
Zsh内置命令bashcompinit有可能在某些操作系统中不生效,如果以上脚本不生效,尝试用如下脚本替换
```
_ucloud() {
read -l;
local cl="$REPLY";
read -ln;
local cp="$REPLY";
reply=(`COMP_SHELL=zsh COMP_LINE="$cl" COMP_POINT="$cp" ucloud`)
}
compctl -K _ucloud ucloud
```
## 初始化配置
UCloud CLI支持多个命名配置,这些配置存储在本地文件config.json和credential.json中,位于~/.ucloud目录。
您可以使用```ucloud config add ```命令添加多个配置,使用--profile指定配置名称,或者直接在本地文件config.json和credential.json中添加配置。
在本地没有已生效的配置的情况下,```ucloud init```命令会添加一个配置并命名为default,此命令尽可能简化了配置过程,适合第一次使用UCloud CLI的时候初始化配置。
总共有10个配置项
- Profile: 配置名称, 此名称不允许重复。执行命令时可以被参数--profile覆盖
- Active: 标识此配置是否生效,生效的配置只有一个
- ProjectID: 默认项目ID,执行命令时可以被参数--project-id覆盖
- Region: 默认地域,执行命令时可以被参数--region覆盖
- Zone: 默认可用区,执行命令时可以被参数--zone覆盖
- BaseURL: 默认的UCloud Open API地址,执行命令时可以被参数--base-url覆盖
- Timeout: 默认的请求API超时时间,单位秒,执行命令是可以被参数--timeout覆盖
- PublicKey: 账户公钥,执行命令时可以被参数--public-key覆盖
- PrivateKey: 账户私钥,执行命令是可以被参数--private-key覆盖
- MaxRetryTimes: 默认最大的API请求失败重试次数,只对幂等API生效,所谓幂API等是指不会因为多次调用而产生副作用,比如释放EIP(ReleaseEIP),执行命令时可以被参数--max-retry-times覆盖
添加或修改配置的命令如下
首次使用,初始化配置
```
$ ucloud init
```
查看所有配置
```
$ ucloud config list
Profile Active ProjectID Region Zone BaseURL Timeout PublicKey PrivateKey MaxRetryTimes
default true org-oxjwoi cn-bj2 cn-bj2-05 https://api.ucloud.cn/ 15 YSQGIZrL*****nCRQ= jtma2eqQ*****+Avms 3
uweb false org-bdks4e cn-bj2 cn-bj2-05 https://api.ucloud.cn/ 15 4E9UU0Vh*****PWQ== 694581ea*****a0d45 3
```
添加配置
```
$ ucloud config add --profile --public-key xxx --private-key xxx
```
修改某个配置的配置项
```
$ ucloud config update --profile xxx --region cn-sh2
```
更多信息,请参考命令帮助
```
$ ucloud config --help
```
## 举例说明
用UCloud CLI在尼日利亚创建数据中心创建一台主机并绑定一个外网IP,然后配置GlobalSSH加速,加速中国大陆到目的主机的SSH登陆
首先,创建云主机
```
$ ucloud uhost create --cpu 1 --memory-gb 1 --password **** --image-id uimage-fya3qr
uhost[uhost-zbuxxxx] is initializing...done
```
*备注*
执行以下命令查看创建主机命令的各参数含义
```
$ ucloud uhost create --help
```
其次,申请一个EIP,然后绑定到刚刚创建的主机上
Secondly, we're going to allocate an EIP and then bind it to the uhost created above.
```
$ ucloud eip allocate --bandwidth-mb 1
allocate EIP[eip-xxx] IP:106.75.xx.xx Line:BGP
$ ucloud eip bind --eip-id eip-xxx --resource-id uhost-xxx
bind EIP[eip-xxx] with uhost[uhost-xxx]
```
以上操作也可以用一个命令完成
```
$ ucloud uhost create --cpu 1 --memory-gb 1 --password **** --image-id uimage-fya3qr --create-eip-bandwidth-mb 1
```
配置GlobalSSH,然后通过GlobalSSH登陆主机
```
$ ucloud gssh create --location Washington --target-ip 152.32.140.92
gssh[uga-0psxxx] created
$ ssh root@152.32.140.92.ipssh.net
root@152.32.140.92.ipssh.net's password: password of the uhost instance
```
使用"ucloud api"命令调用任意API,根据API文档把某个API的参数依次填入。此命令比较特殊,不支持--public-key,--private-key,--debug,--profile,--timeout-sec等公共参数,如果要开启debug模式,可以设置环境变量$UCLOUD_CLI_DEBUG=on
```
$ ucloud api --Action --Param1 --Param2 ...
```
或者把API参数写到JSON文件中,举例如下
```
$ ucloud api --local-file ./create_uhost.json
//create_uhost.json文件内容
{
"Action":"CreateUHostInstance",
"Region":"cn-bj2",
"Zone":"cn-bj2-02",
"ImageId":"uimage-gk2x3x",
"NetworkInterface": [{
"EIP":{
"Bandwidth":1,
"OperatorName":"Bgp",
"PayMode": "Bandwidth"
}
}],
"LoginMode":"Password",
"Password":"dGVzdGx4ajEy",
"CPU":1,
"Memory":2048,
"Disks":[
{
"Size":20,
"Type":"LOCAL_NORMAL",
"IsBoot":"true"
}
]
}
```