使用 apigee-adminapi.sh 公用程式

私有雲的邊緣 4.17.09 版

使用 apigee-adminapi.sh 公用程式,執行呼叫 Edge Management API 後執行的相同 Edge 設定工作。apigee-adminapi.sh 公用程式的優點如下:

  • 使用簡單的指令列介面
  • 實作以 Tab 鍵為基礎的指令
  • 提供說明和使用資訊
  • 如果您決定試用 API,可以顯示對應的 API 呼叫

apigee-adminapi.sh 公用程式無法取代 apigee-provision 公用程式。apigee-provision 公用程式實際上會使用 apigee-adminapi.sh 公用程式執行其工作。

兩者的主要差異如下:

  • apigee-adminapi.sh 公用程式可執行完整函式來取代個別 Edge API 呼叫。舉例來說,如要建立機構、環境和虛擬主機,就需要三個對應至三個 API 呼叫的個別 apigee-adminapi.sh 指令。
  • apigee-provision 公用程式是用來透過單一指令執行完整的高階作業。舉例來說,只要傳送一個內含所有必要資訊的設定檔,即可使用單一 apigee-provision 指令來建立機構、環境和虛擬主機。

Edge 說明文件會視情況使用這兩種公用程式。

安裝 apigee-adminapi.sh

當您安裝 apigee-provisionapigee-validate 公用程式時,系統會自動安裝 apigee-adminapi.sh 公用程式。

系統會在以下位置安裝該公用程式:

/opt/apigee/apigee-adminapi/bin/apigee-adminapi.sh

apigee-adminapi.sh 語法

apigee-adminapi.sh 公用程式採用簡單的指令列語法。您隨時可以使用 Tab 鍵顯示列出可用指令選項的提示。

如要查看所有可能的指令,請在不使用選項的情況下叫用公用程式:

> apigee-adminapi.sh 

如果您在輸入 apigee-adminapi.sh 後按下 Tab 鍵,系統會顯示可能的選項清單:

analytics  classification  logsessions  regions  securityprofile  userroles
buildinfo  GET             orgs         runtime  servers          users

Tab 鍵會根據指令內容顯示選項。如果您在輸入後進入 Tab 鍵:

> apigee-adminapi.sh orgs

畫面會顯示完成 orgs 指令的可能選項:

add  apis  apps  delete  envs  list  pods  userroles

使用 -h 選項顯示任何指令的說明。例如,如果您使用 -h 選項,如下所示:

> apigee-adminapi.sh orgs -h

公用程式會針對 orgs 指令顯示所有可能選項的完整說明資訊。輸出內容的第一個項目顯示 "orgs add" 指令的說明:

+++++++++++++++++++++++++++++++++++++++++++
orgs add
  Required:
    -o ORG Organization name
  Optional:
    -H HEADER add http header in request
    --admin ADMIN_EMAIL admin email address
    --pwd ADMIN_PASSWORD admin password
    --host EDGE_SERVER edge server to make request to
    --port EDGE_PORT port to use for the http request
    --ssl set EDGE_PROTO to https, defaults to http
    --debug ( set in debug mode, turns on verbose in curl )
    -h      Displays Help

使用指令列切換按鈕和環境變數設定參數

您必須使用指令列切換按鈕或使用環境變數,在指令中輸入所有參數。視需要在指令列切換鈕前方加上單破折號 (-) 或雙破折號 (--)。

例如,根據上方說明中的「orgs add」指令,您可以透過下列任一方式指定機構名稱:

  • 使用 -o 指令列切換鈕:
    > apigee-adminapi.sh orgs -o testOrg
  • 設定名為 ORG 的環境變數:
    > export ORG=testOrg
    > apigee-adminapi.sh orgs

如果您在指令中省略任何必要參數,公用程式會顯示錯誤訊息,說明缺少的參數。舉例來說,如果您在建立機構時省略 --hostEDGE_SERVER 環境變數來指定 Edge Management Server,就會看到以下錯誤訊息:

Error with required variable or parameter
ADMIN_PASSWORD....OK
ADMIN_EMAIL....OK
EDGE_SERVER....null

您經常設為環境變數的兩個常見參數為管理伺服器的系統管理員電子郵件地址和 IP 位址:

> export ADMIN_EMAIL=foo@bar.com
> export EDGE_SERVER=192.168.56.101

將檔案傳送至 apigee-adminapi.sh 公用程式

部分 apigee-adminapi.sh 公用程式指令會對應至會接受要求主體的 PUT 和 POST API 呼叫。舉例來說,建立虛擬主機對應的 POST API 呼叫,要求主體中需要虛擬主機的相關資訊。

使用 apigee-adminapi.sh 公用程式來建立虛擬主機,或任何接受要求主體的指令時,您可以將所有必要資訊傳送至指令列,如下所示:

> apigee-adminapi.sh orgs envs virtual_hosts add -e prod -o testOrg --host localhost --admin foo@bar.com -v myVHostUtil -p 9005 -a 192.168.56.101:9005

或者,您也可以傳送檔案包含與 POST 要求內文中相同的資訊。舉例來說,以下指令使用定義虛擬主機的檔案:

> apigee-adminapi.sh orgs envs virtual_hosts add -e prod -o testOrg --host localhost --admin foo@bar.com -f vhostcreate

其中 vhostcreate 檔案包含呼叫的 POST 主體。本例是 XML 格式的要求主體:

<VirtualHost name="myVHostUtil">
   <HostAliases>
     <HostAlias>192.168.56.101:9005</HostAlias>
   </HostAliases>
   <Interfaces/>
   <Port>9005</Port>
</VirtualHost>

顯示偵錯和 API 資訊

使用 --debug 選項至 apigee-adminapi.sh 公用程式,顯示該指令的詳細資訊。這項資訊包括執行該作業的 apigee-adminapi.sh 公用程式產生的 cURL 指令。

舉例來說,這個指令使用 --debug 選項:

> apigee-adminapi.sh orgs add -o testOrg2 --admin foo@bar.com --host localhost --debug

並顯示下列輸出內容,包括產生的 cURL 指令:

curl -H Content-Type: application/xml -v -X POST     -s -k -w \n==> %{http_code} 
-u ***oo@bar.com:*****     http://localhost:8080/v1/o -d <Organization name="testOrg2" 
type="paid"/>
* About to connect() to localhost port 8080 (#0)
*   Trying ::1... connected
* Connected to localhost (::1) port 8080 (#0)
* Server auth using Basic with user 'foo@bar.com'
> POST /v1/o HTTP/1.1
> Authorization: Basic c2dp234234NvbkBhcGlnZ2342342342342341Q5
> User-Agent: curl/7.19.7 (x86_64-redhat-linux-gnu) libcurl/7.19.7 NSS/3.19.1
Basic ECC zlib/1.2.3 libidn/1.18 libssh2/1.4.2
> Host: localhost:8080
> Accept: */*
> Content-Type: application/xml
> Content-Length: 43
>
} [data not shown]
< HTTP/1.1 201 Created
< Content-Type: application/json
< Date: Tue, 03 May 2016 02:08:32 GMT
< Content-Length: 291
<
{ [data not shown]
* Connection #0 to host localhost left intact
* Closing connection #0