การใช้ยูทิลิตี apigee-adminapi.sh

Edge for Private Cloud v. 4.17.05

ใช้ยูทิลิตี apigee-adminapi.sh เพื่อทํางานกําหนดค่า Edge เดียวกันกับที่คุณทําโดยการเรียกใช้ API การจัดการ Edge ข้อดีของยูทิลิตี apigee-adminapi.sh คือ ยูทิลิตีนี้

  • ใช้อินเทอร์เฟซบรรทัดคำสั่งที่ใช้งานง่าย
  • ใช้การเติมคำสั่งอัตโนมัติแบบ Tab
  • ให้ความช่วยเหลือและข้อมูลการใช้งาน
  • แสดงการเรียก API ที่เกี่ยวข้องได้หากคุณตัดสินใจลองใช้ API

ยูทิลิตี apigee-adminapi.sh ไม่ได้มาแทนที่ยูทิลิตี apigee-provision ยูทิลิตี apigee-provision จะใช้ยูทิลิตี apigee-adminapi.sh เพื่อทำงาน

ความแตกต่างหลักๆ ระหว่าง 2 แคมเปญมีดังนี้

  • ยูทิลิตี apigee-adminapi.sh จะทํางานแบบอะตอมแทนการเรียกใช้ Edge API แต่ละรายการ ตัวอย่างเช่น หากต้องการสร้างองค์กร สภาพแวดล้อม และโฮสต์เสมือน คุณต้องใช้คำสั่ง apigee-adminapi.sh แยกกัน 3 รายการ ซึ่งสอดคล้องกับการเรียก API 3 ครั้ง
  • ยูทิลิตี apigee-provision ออกแบบมาเพื่อดำเนินการระดับสูงอย่างสมบูรณ์ในคำสั่งเดียว เช่น คุณสามารถสร้างองค์กร สภาพแวดล้อม และโฮสต์เสมือนด้วยคำสั่ง apigee-provision เพียงคำสั่งเดียวโดยส่งไฟล์การกําหนดค่าที่มีข้อมูลที่จําเป็นทั้งหมด

เอกสารประกอบของ Edge ใช้ยูทิลิตีทั้ง 2 รายการตามความเหมาะสม

การติดตั้ง apigee-adminapi.sh

ระบบจะติดตั้งยูทิลิตี apigee-adminapi.sh โดยอัตโนมัติเมื่อคุณติดตั้งยูทิลิตี apigee-provision หรือ apigee-validate

ระบบจะติดตั้งเครื่องมือในตำแหน่งต่อไปนี้

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

ไวยากรณ์ apigee-adminapi.sh

ยูทิลิตี apigee-adminapi.sh ใช้ไวยากรณ์บรรทัดคำสั่งแบบง่าย คุณใช้แป้น Tab เพื่อแสดงพรอมต์ที่แสดงรายการตัวเลือกคำสั่งที่ใช้ได้ได้ทุกเมื่อ

หากต้องการดูคำสั่งที่ใช้ได้ทั้งหมด ให้เรียกใช้ยูทิลิตีโดยไม่มีตัวเลือก

> apigee-adminapi.sh 

หากกดแป้น Tab หลังจากพิมพ์ apigee-adminapi.sh คุณจะเห็นรายการตัวเลือกที่เป็นไปได้ดังนี้

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

การตั้งค่าพารามิเตอร์โดยใช้สวิตช์บรรทัดคำสั่งและตัวแปรสภาพแวดล้อม

คุณต้องป้อนพารามิเตอร์ทั้งหมดในคําสั่งโดยใช้สวิตช์บรรทัดคําสั่ง หรือใช้ตัวแปรสภาพแวดล้อม ใส่เครื่องหมายขีดกลาง (-) หรือขีดกลาง 2 ขีด (--) ไว้หน้าสวิตช์บรรทัดคำสั่งตามที่จำเป็น

ตัวอย่างเช่น จากความช่วยเหลือที่แสดงด้านบนสำหรับคําสั่ง "orgs add" คุณสามารถระบุชื่อองค์กรได้ดังนี้

  • การใช้บรรทัดคำสั่ง -o switch:
    > apigee-adminapi.sh orgs -o testOrg
  • การตั้งค่าตัวแปรสภาพแวดล้อมชื่อ ORG
    > export ORG=testOrg
    > apigee-adminapi.sh orgs

หากคุณละเว้นพารามิเตอร์ที่จำเป็นในคำสั่ง ยูทิลิตีจะแสดงข้อความแสดงข้อผิดพลาดที่อธิบายพารามิเตอร์ที่ขาดหายไป เช่น หากคุณละเว้นตัวแปรสภาพแวดล้อม --host หรือ EDGE_SERVER ที่ระบุเซิร์ฟเวอร์การจัดการ Edge เมื่อสร้างองค์กร คุณจะเห็นข้อความแสดงข้อผิดพลาดต่อไปนี้

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

พารามิเตอร์ทั่วไป 2 รายการที่คุณมักตั้งค่าเป็นตัวแปรสภาพแวดล้อมคืออีเมลของผู้ดูแลระบบและที่อยู่ IP ของเซิร์ฟเวอร์การจัดการ

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

ส่งไฟล์ไปยังยูทิลิตี apigee-adminapi.sh

คำสั่งยูทิลิตี apigee-adminapi.sh บางรายการจะสอดคล้องกับการเรียก API ประเภท PUT และ POST ที่ใช้เนื้อความของคำขอ ตัวอย่างเช่น การสร้างโฮสต์เสมือนจะสอดคล้องกับการเรียก API แบบ POST ที่ต้องระบุข้อมูลเกี่ยวกับโฮสต์เสมือนในเนื้อหาคำขอ

เมื่อใช้ยูทิลิตี 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 จะมีข้อมูลใน Body ของ 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

> 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