使用 apigee-adminapi.sh 公用程式

Private Cloud v4.18.01 專用 Edge

使用 apigee-adminapi.sh 公用程式,藉由呼叫 Edge 來執行相同的 Edge 設定工作 Management API使用 apigee-adminapi.sh 公用程式的優點是 它:

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

apigee-adminapi.sh 公用程式不是 取代 apigee-provision 公用程式。apigee-provision 公用程式實際使用 使用 apigee-adminapi.sh 公用程式 以執行其工作

兩者的主要差異如下:

  • apigee-adminapi.sh 公用程式 會執行不可分割的函式,以取代個別 Edge API 呼叫。舉例來說 機構、環境和虛擬主機需要三個不同的 apigee-adminapi.sh 指令 會對應三個 API 呼叫
  • apigee-provision 公用程式旨在透過單一指令執行完整的高階作業。適用對象 舉例來說,您可以用單一 Pod 建立機構、環境和虛擬主機 使用 apigee-provision 指令 傳送包含所有必要資訊的設定檔

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

安裝 apigee-adminapi.sh

apigee-adminapi.sh 公用程式是 安裝 apigee-provisionapigee-validate 公用程式時,會自動安裝。

該公用程式會安裝在下列位置:

/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 的環境變數:
    >匯出 ORG=testOrg
    >apigee-adminapi.sh 機構
,瞭解如何調查及移除這項存取權。

如果您省略指令中的任何必要參數,公用程式會顯示錯誤訊息 說明遺漏的參數舉例來說,如果您省略 --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="myVHost>Util<"
   H>ostAli<ases
    > HostAlias192.168.5<6.101:9005>/Hos<tAlias
   /H>ostA<liases
   I>nter<face>s/
 <  Por>t<9005/Port
/V>irtualHost

顯示偵錯和 API 資訊

使用 --debug 選項 使用 apigee-adminapi.sh 公用程式 可顯示有關指令的詳細資訊這些資訊包括 cURL 指令 將由 apigee-adminapi.sh 公用程式產生的 執行作業。

舉例來說,這個指令使用 --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" 
ty>pe="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.co>m'
 POST /v1/o HTTP/1.1
 Authorization: Basic c2dp234234Nv>bkBhcGlnZ2342342342342341Q5
 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: */*
 Co>ntent-Type: applicat>ion/xml
 Content-Len<gth: 43

} [data not s<hown]
 HTTP/1.1 201 Created
 Con<tent-Type: application/json
 Date: Tu<e, 03 May 2016 02:08:<32 GMT
 Content-Length: 291

{ [data not shown]
* Connection #0 to host localhost left intact
* Closing connection #0