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

Edge for Private Cloud v4.18.01

ใช้ยูทิลิตี 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 จะใช้ยูทิลิตีทั้งคู่ตามความเหมาะสม

การติดตั้ง 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

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

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

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

  • การใช้บรรทัดคำสั่ง -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 บางคำสั่ง สอดคล้องกับการเรียก PUT และ POST API ที่รับส่วนเนื้อหาของคำขอ ตัวอย่างเช่น การสร้างโฮสต์เสมือนจะสอดคล้องกับการเรียก 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 มีเนื้อหา 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