การสร้างองค์กร สภาพแวดล้อม และโฮสต์เสมือน

Edge for Private Cloud เวอร์ชัน 4.17.05

การสร้างองค์กร สภาพแวดล้อม และโฮสต์เสมือนพร้อมกัน

ก่อนสร้างพร็อกซี API ใน Apigee Edge คุณต้องสร้างองค์กรอย่างน้อย 1 องค์กร และสร้างสภาพแวดล้อมและโฮสต์เสมือนอย่างน้อย 1 รายการภายในแต่ละองค์กร

โดยทั่วไปแล้ว ระบบจะสร้างองค์กรและสภาพแวดล้อมพร้อมกัน หากต้องการทำให้กระบวนการง่ายขึ้น ให้ใช้ยูทิลิตี apigee-provision เรียกใช้จากบรรทัดคำสั่งในเซิร์ฟเวอร์การจัดการ Edge ดังนี้

> /opt/apigee/apigee-service/bin/apigee-service apigee-provision setup-org -f configFile

ไฟล์การกําหนดค่าประกอบด้วย

# Set Edge sys admin credentials.
ADMIN_EMAIL=your@email.com
APIGEE_ADMINPW=adminPword     # If omitted, you are prompted for it.
NEW_USER="y"
USER_NAME=orgAdmin@myCo.com
FIRST_NAME=foo
LAST_NAME=bar
USER_PWD="userPwrod"
ORG_NAME=example  # lowercase only, no spaces, underscores, or periods.
ENV_NAME=prod
VHOST_PORT=9001
VHOST_NAME=default
VHOST_ALIAS="$IP1:9001"
# Optionally configure TLS/SSL for virtual host.
# VHOST_SSL=y     # Set to "y" to enable TLS/SSL on the virtual host.
# KEYSTORE_JAR=   # JAR file containing the cert and private key.
# KEYSTORE_NAME=  # Name of the keystore. 
# KEYSTORE_ALIAS= # The key alias.
# KEY_PASSWORD=   # The key password, if it has one. 
# Optionally set the base URL displayed by the Edge UI for an
# API proxy deployed to the virtual host.
# VHOST_BASEURL="http://myCo.com"
# AXGROUP=axgroup-001 # Default value is axgroup-001 

จากนั้นคำสั่งจะดำเนินการดังนี้

  • สร้างองค์กร
    หมายเหตุ: คุณเปลี่ยนชื่อองค์กรไม่ได้หลังจากสร้างแล้ว
  • เชื่อมโยงองค์กรกับพ็อด โดยค่าเริ่มต้นจะเชื่อมโยงองค์กรกับ "เกตเวย์" พ็อด
  • เพิ่มผู้ใช้ที่ระบุเป็นผู้ดูแลระบบขององค์กร หากผู้ใช้ไม่อยู่ ให้สร้างผู้ใช้
  • สร้างสภาพแวดล้อมอย่างน้อย 1 รายการ
  • สร้างโฮสต์เสมือนอย่างน้อย 1 รายการสำหรับแต่ละสภาพแวดล้อม
  • เชื่อมโยงสภาพแวดล้อมกับโปรแกรมประมวลผลข้อความทั้งหมด
  • เปิดใช้ Analytics

โปรดดูไฟล์การกําหนดค่าแบบเงียบที่สมบูรณ์ที่หัวข้อเริ่มต้นใช้งานองค์กร

โดยค่าเริ่มต้น ความยาวสูงสุดสำหรับชื่อองค์กรและชื่อสภาพแวดล้อมคือ 20 อักขระ เมื่อใช้ apigee-provision ยูทิลิตี ขีดจำกัดนี้จะไม่มีผลหากคุณใช้ Edge API โดยตรงเพื่อสร้างองค์กร หรือ ของคุณ

สร้างองค์กร

ใช้คำสั่ง create-org เพื่อสร้างองค์กร

> /opt/apigee/apigee-service/bin/apigee-service apigee-provision create-org -f configFile

สคริปต์นี้จะสร้างองค์กร แต่ไม่เพิ่มหรือกําหนดค่าสภาพแวดล้อมและโฮสต์เสมือนที่จําเป็นสําหรับองค์กรในการจัดการการเรียก API

ไฟล์การกำหนดค่ามีชื่อขององค์กรและอีเมลของผู้ดูแลระบบขององค์กร อักขระที่คุณใช้ในแอตทริบิวต์ชื่อได้ถูกจํากัดไว้ที่ a-z0-9\-$% อย่าเว้นวรรค ใช้จุด หรือใช้อักษรตัวพิมพ์ใหญ่ในชื่อ

APIGEE_ADMINPW=adminPword    # If omitted, you are prompted for it.
ORG_NAME=example  # lowercase only, no spaces, underscores, or periods.
ORG_ADMIN=orgAdmin@myCo.com

จากนั้นคำสั่ง

  • สร้างองค์กร
  • เชื่อมโยงองค์กรกับพ็อด โดยค่าเริ่มต้นจะเชื่อมโยงกับพ็อด "เกตเวย์"
  • เพิ่มผู้ใช้ที่ระบุเป็นผู้ดูแลระบบขององค์กร ผู้ใช้ต้องมีอยู่ก่อน มิเช่นนั้นสคริปต์จะแสดงข้อผิดพลาด
<Error>
    <Code>organizations.OrganizationAlreadyExists</Code>
    <Message>Organization : test already exists</Message>
    <Contexts/>
</Error>

สร้างองค์กรโดยใช้ การเรียก API

หรือจะใช้การเรียก API ต่อไปนี้เพื่อสร้างองค์กรก็ได้ การเรียกแรกจะสร้าง องค์กร:

curl -H "Content-Type:application/xml" -u <sysAdminEmail>:<adminPasswd> \
-X POST http://<ms-ip>:8080/v1/organizations \
-d '<Organization name="<org-name>" type="paid"/>'

การเรียกครั้งถัดไปจะเชื่อมโยงองค์กรกับพ็อด:

curl -H "Content-Type:application/x-www-form-urlencoded" \
-u <sysAdminEmail>:<adminPasswd> -X POST \
http://<ms-ip>:8080/v1/organizations/<org-name>/pods \
-d "region=default&pod=gateway" 

คุณเรียกใช้การเรียกนี้หลายครั้งเพื่อเชื่อมโยงองค์กรกับพ็อดหลายรายการได้

การเรียกใช้ครั้งสุดท้ายจะเพิ่มผู้ใช้ที่มีอยู่เป็นผู้ดูแลระบบขององค์กร

curl -H "Content-Type:application/xml" -u <sysAdminEmail>:<adminPasswd> \
-X POST \
http://<ms-ip>:8080/v1/organizations/<org-name>/users/<user-email>/userroles/ \
-d '<Roles><Role name="orgadmin"/></Roles>'

หากไม่มีผู้ใช้ดังกล่าว คุณสามารถใช้การเรียกต่อไปนี้เพื่อสร้างผู้ใช้ตามที่อธิบายไว้ในส่วนการเพิ่มผู้ใช้

สร้างสภาพแวดล้อม

ใช้คำสั่ง add-env เพื่อ สร้างสภาพแวดล้อมในองค์กรที่มีอยู่

> /opt/apigee/apigee-service/bin/apigee-service apigee-provision add-env -f configFile

ไฟล์การกำหนดค่านี้ประกอบด้วยข้อมูลที่จำเป็นสำหรับการสร้างสภาพแวดล้อมและระบบเสมือน เจ้าภาพ:

APIGEE_ADMINPW=adminPword    # If omitted, you are prompted for it.
ORG_NAME=example  # lowercase only, no spaces, underscores, or periods.
ENV_NAME=prod
VHOST_PORT=9001
VHOST_NAME=default
VHOST_ALIAS="$IP1:9001"
# Optionally configure TLS/SSL for virtual host.
# VHOST_SSL=y     # Set to "y" to enable TLS/SSL on the virtual host.
# KEYSTORE_JAR=   # JAR file containing the cert and private key.
# KEYSTORE_NAME=  # Name of the keystore. 
# KEYSTORE_ALIAS= # The key alias.
# KEY_PASSWORD=   # The key password, if it has one. 
# Optionally set the base URL displayed by the Edge UI for an
# API proxy deployed to the virtual host.
# VHOST_BASEURL="http://myCo.com"
# AXGROUP=axgroup-001 # Default value is axgroup-001

คำสั่ง:

  • สร้างสภาพแวดล้อม
  • สร้างโฮสต์เสมือนรายการเดียวสำหรับสภาพแวดล้อม
  • เชื่อมโยงสภาพแวดล้อมกับตัวประมวลผลข้อความทั้งหมดในพ็อดที่เชื่อมโยงกับ องค์กรที่มีสภาพแวดล้อมนั้นๆ ไว้
  • เปิดใช้ข้อมูลวิเคราะห์
    หมายเหตุ: หากเปิดใช้ข้อมูลวิเคราะห์สําหรับสภาพแวดล้อมหนึ่งในองค์กร คุณต้องเปิดใช้ข้อมูลวิเคราะห์สําหรับทุกสภาพแวดล้อมในองค์กร

สร้างสภาพแวดล้อมโดยใช้ การเรียก API

หรือจะใช้การเรียก API ต่อไปนี้เพื่อสร้างสภาพแวดล้อมก็ได้ การโทรครั้งแรก สร้างสภาพแวดล้อม

curl -H "Content-Type:application/xml" -u <sysAdminEmail>:<adminPasswd> \
-X POST http://<ms-ip>:8080/v1/organizations/<org-name>/environments \
-d  '<Environment name="<env-name>"/>' 

การเรียกครั้งถัดไปจะเชื่อมโยงสภาพแวดล้อมกับตัวประมวลผลข้อความ โทรการประชุมนี้สำหรับแต่ละ ตัวประมวลผลข้อความที่คุณต้องการเชื่อมโยงกับสภาพแวดล้อม:

curl -H "Content-Type:application/x-www-form-urlencoded" \
-u <sysAdminEmail>:<adminPasswd> -X POST \
http://<ms-ip>:8080/v1/organizations/<org-name>/environments/<env-name>/servers \
-d "action=add&uuid=<uuid>"

โดยที่ "&lt;uuid&gt;" คือ UUID ของโปรแกรมประมวลผลข้อความ คุณรับ UUID ได้โดยใช้คําสั่งต่อไปนี้

> curl http://<mp-ip>:8082/v1/servers/self

โดยที่ "&lt;mp-ip&gt;" คือ ที่อยู่ IP ของเครื่องประมวลผลข้อความ

การเรียก API ครั้งถัดไปจะเปิดใช้ Analytics สําหรับสภาพแวดล้อมหนึ่งๆ โดยจะตรวจสอบการมีอยู่ของเซิร์ฟเวอร์ Qpid และ Postgres ใน POD ของศูนย์ข้อมูลทั้งหมด จากนั้นจะเป็นการเริ่มต้นการเริ่มต้นใช้งาน Analytics สำหรับองค์กรและสภาพแวดล้อมนั้นๆ

> /opt/apigee/apigee-service/bin/apigee-service apigee-provision enable-ax -f configFile

ไฟล์การกำหนดค่านี้ประกอบด้วย

ORG_NAME=orgName  # lowercase only, no spaces, underscores, or periods.
ENV_NAME=envName
curl -H "Content-Type:application/json" -u <sysAdminEmail>:<adminPasswd> 
-X POST http://<ms-ip>:8080/v1/organizations/<org-name>/environments/<env-name>/analytics/admin -d "@sample.json"

โดย sample.json ประกอบด้วยข้อมูลต่อไปนี้

{
  "properties" : {
    "samplingAlgo" : "reservoir_sampler",
    "samplingTables" : "10=ten;1=one;",
    "aggregationinterval" : "300000",
    "samplingInterval" : "300000",
    "useSampling" : "100",
    "samplingThreshold" : "100000"
  },
  "servers" : {
    "postgres-server" : [ "1acff3a5-8a6a-4097-8d26-d0886853239c", "f93367f7-edc8-4d55-92c1-2fba61ccc4ab" ],  
    "qpid-server" : [ "d3c5acf0-f88a-478e-948d-6f3094f12e3b", "74f67bf2-86b2-44b7-a3d9-41ff117475dd"] 
  }
}

พร็อพเพอร์ตี้ postgres-servers มีรายการ UUID ของ Postgres ที่คั่นด้วยคอมมา และพร็อพเพอร์ตี้ qpid-server มี UUID ของ Qpid หากต้องการรับ UUID เหล่านี้ ให้ใช้คำสั่งต่อไปนี้

สำหรับ Qpid ให้เรียกใช้คำสั่ง:

curl -u <sysAdminEmail>:<passwd> http://<ms-ip>/v1/servers?pod=central

เอาต์พุตของคำสั่งนี้คือออบเจ็กต์ JSON สำหรับเซิร์ฟเวอร์ Qpid แต่ละรายการ คุณจะเห็นเอาต์พุตใน แบบฟอร์ม:

"type" : [ "qpid-server" ],
"uUID" : "d3c5acf0-f88a-478e-948d-6f3094f12e3b"

สำหรับ Postgres ให้เรียกใช้คำสั่งดังนี้

curl -u <sysAdminEmail>:<passwd> http://<ms-ip>/v1/servers?pod=analytics

สำหรับเซิร์ฟเวอร์ Postgres แต่ละเซิร์ฟเวอร์ คุณจะเห็นเอาต์พุตในแบบฟอร์มดังนี้

"type" : [ "postgres-server" ],
"uUID" : "d3c5acf0-f88a-478e-948d-6f3094f12e3b"

สร้างโฮสต์เสมือน

คุณสร้างโฮสต์เสมือนในสภาพแวดล้อมที่มีอยู่ขององค์กรได้ โดยทั่วไปแล้ว สภาพแวดล้อมจะรองรับโฮสต์เสมือนหลายรายการ ตัวอย่างเช่น โฮสต์เสมือนหนึ่งอาจรองรับโปรโตคอล HTTP ขณะที่โฮสต์เสมือนอีกตัวหนึ่งในสภาพแวดล้อมเดียวกันรองรับโปรโตคอล HTTPS ที่เข้ารหัส

ใช้การเรียก API ต่อไปนี้เพื่อสร้างโฮสต์เสมือนเพิ่มเติม หรือสร้างโฮสต์เสมือนสําหรับสภาพแวดล้อมที่ไม่มีโฮสต์เสมือน

curl -H "Content-Type:application/xml" -u <sysAdminEmail>:<adminPasswd> \
-X POST \
http://<ms-ip>:8080/v1/organizations/<org-name>/environments/<env-name>/virtualhosts \
-d '<VirtualHost name="default"> \
    <HostAliases> \
      <HostAlias>myorg-test.apigee.net</HostAlias> \ 
    </HostAliases> \
    <Interfaces/> \
    <Port>443</Port> \
  </VirtualHost>' 

ดูคำอธิบายการสร้างโฮสต์เสมือนอย่างละเอียด รวมถึงการสร้างโฮสต์เสมือนที่ปลอดภัยซึ่งใช้ TLS/SSL ผ่าน HTTPS ได้ที่การกำหนดค่าการเข้าถึง TLS ไปยัง API สำหรับระบบคลาวด์ส่วนตัว