Использование утилиты apigee-adminapi.sh

apigee-adminapi.sh вызывает API управления Edge для выполнения многих задач обслуживания.

О apigee-adminapi.sh

Вызов apigee-adminapi.sh

Вы вызываете 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

В любой момент используйте клавишу табуляции, чтобы отобразить подсказку со списком доступных параметров команды.

Чтобы просмотреть все возможные команды, вызовите утилиту без параметров:

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

Если вы нажмете клавишу Tab после ввода apigee-adminapi.sh, вы увидите список возможных опций:

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

Клавиша табуляции отображает параметры в зависимости от контекста команды. Если вы введете клавишу табуляции после ввода:

/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 . В результате некоторые команды соответствуют вызовам API PUT и POST , которые принимают тело запроса. Например, создание виртуального хоста соответствует вызову 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