使用 apigee-adminapi.sh 公用程式

Private Cloud v4.19.01 版

apigee-adminapi.sh 會呼叫 Edge Management API 來執行多項維護作業 機器學習程式庫提供一系列預先編寫的程式碼 可用來執行機器學習工作

關於 apigee-adminapi.sh

叫用 apigee-adminapi.sh

您從 Management Server 節點叫用 apigee-adminapi.sh。叫用公用程式時,您必須 將以下項目定義為環境變數或指令列選項:

  • ADMIN_EMAIL (對應至 admin 指令列選項)
  • ADMIN_PASSWORD (pwd)
  • EDGE_SERVER (host)

下列範例會叫用 apigee-adminapi.sh,並將必要值做為指令列傳遞 選項:

/opt/apigee/apigee-adminapi/bin/apigee-adminapi.sh buildinfo list --admin user@example.com --pwd abcd1234 --host localhost

以下範例將必要選項定義為暫時環境變數,然後 叫用 apigee-adminapi.sh 公用程式:

export ADMIN_EMAIL=user@example.com
export ADMIN_PASSWORD=abcd1234
export EDGE_SERVER=192.168.56.101
/opt/apigee/apigee-adminapi/bin/apigee-adminapi.sh servers list

如果您沒有將密碼做為選項傳遞或定義為環境變數, apigee-adminapi.sh 會提示你輸入。

設定 apigee-adminapi.sh 參數

您必須使用指令列開關或 環境變數在指令列切換鈕前面加上一個破折號 (-) 或雙破折號 (--)。

舉例來說,您可以透過下列任一方式指定機構名稱:

  • 使用 -o 指令列切換鈕:
    /opt/apigee/apigee-adminapi/bin/apigee-adminapi.sh orgs -o testOrg
  • 設定名為 ORG 的環境變數:
    export ORG=testOrg
    /opt/apigee/apigee-adminapi/bin/apigee-adminapi.sh orgs
,瞭解如何調查及移除這項存取權。

如果您省略指令中的任何必要參數,公用程式會顯示錯誤訊息 說明遺漏的參數例如,如果您省略 --host 選項 (對應至 EDGE_SERVER 環境變數),apigee-adminapi.sh 則會回應 ,錯誤訊息如下:

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

如果收到 HTTP STATUS CODE: 401 錯誤,請輸入錯誤的 密碼。

取得 apigee-adminapi.sh 說明

隨時按下 Tab 鍵即可顯示提示,列出可用指令選項。

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

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

如果在輸入 apigee-adminapi.sh 後按下 Tab 鍵,即可查看可能的清單 選項:

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

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

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

您會看到完成 orgs 指令的可能選項:

add  apis  apps  delete  envs  list  pods  userroles

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

/opt/apigee/apigee-adminapi/bin/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

將檔案傳送至 apigee-adminapi.sh

apigee-adminapi.sh 公用程式是 curl 的包裝函式。因此,有些人 指令會對應至可接受要求主體的 PUTPOST API 呼叫。 舉例來說,建立虛擬主機會對應至需要 30 個 Pod 的 POST API 呼叫 要求主體中的虛擬主機相關資訊。

使用 apigee-adminapi.sh 公用程式時 建立虛擬主機或任何可接收要求主體的指令 所有必要的資訊,如下所示:

/opt/apigee/apigee-adminapi/bin/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 要求的內容例如,下列指令會採用定義虛擬主機的檔案:

/opt/apigee/apigee-adminapi/bin/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 公用程式來顯示 進一步瞭解指令這項資訊包括 curl 指令 為執行該作業而產生的 apigee-adminapi.sh 公用程式。

舉例來說,下列指令使用 --debug 選項。成果 以詳細模式顯示基礎 curl 指令的輸出內容:

/opt/apigee/apigee-adminapi/bin/apigee-adminapi.sh orgs add -o testOrg2 --admin foo@bar.com --host localhost --debug
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