Skip to content

Latest commit

 

History

History
254 lines (191 loc) · 8.97 KB

README-CN.md

File metadata and controls

254 lines (191 loc) · 8.97 KB

English | 简体中文

UCloud CLI

UCloud CLI为管理UCloud平台上的资源和服务提供了一致性的操作接口,它使用ucloud-sdk-go调用UCloud OpenAPI,从而实现对资源和服务的操作,兼容Linux, macOS和Windows平台 https://docs.ucloud.cn/developer/cli/index

在macOS或Linux平台安装UCloud-CLI

通过Homebrew安装(在macOS平台上推荐此方式)

Homebrew 是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的发布页面,找到适合您平台的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的发布页面下载源代码并解压,您也可以通过git下载源代码,打开Git Bash, 执行命令git clone https://github.com/ucloud/ucloud-cli.git。 切换到源代码所在的目录,编译源代码(执行命令 go build -mod=vendor -o ucloud.exe),然后把可执行文件ucloud.exe所在目录添加到PATH环境变量中,具体操作可参看文档 配置完成后,打开终端(cmd或power shell),执行命令ucloud --version检查是否安装成功。

下载二进制可执行文件

打开ucloud-cli的发布页面,找到适合您平台的ucloud-cli压缩包。点击链接进行下载并解压,然后把可执行文件ucloud.exe所在目录添加到PATH环境变量中,添加环境变量的操作可参考文档

在Docker容器中使用UCloud-CLI

如果您已安装Docker, 通过如下命令拉取已打包UCloud-CLI的镜像。镜像打包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 <new-profie-name>  --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 [email protected]
[email protected]'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 <APIName>  --Param1 <value> --Param2 <value> ...

或者把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"
        }
    ]
}