ในบางครั้ง คุณอาจต้องเลิกใช้งานศูนย์ข้อมูล เช่น หากอัปเกรดระบบปฏิบัติการ คุณจะต้อง ติดตั้งระบบปฏิบัติการใหม่ในศูนย์ข้อมูลใหม่ แล้วจึงเลิกใช้งานศูนย์ข้อมูลเก่า ส่วนต่อไปนี้จะแสดงตัวอย่างการเลิกใช้งานศูนย์ข้อมูล ซึ่งมีศูนย์ข้อมูล 2 แห่ง ได้แก่ dc-1 และ dc-2 ในการติดตั้งคลัสเตอร์แบบ 12 โหนด
- dc-1 คือศูนย์ข้อมูลที่จะเลิกใช้งาน
- dc-2 คือศูนย์ข้อมูลที่ 2 ซึ่งใช้ในขั้นตอนการเลิกใช้งาน
หากคุณกำลังอัปเกรด ระบบปฏิบัติการ dc-2 อาจเป็นศูนย์ข้อมูลที่คุณติดตั้ง ระบบปฏิบัติการ (OS) เวอร์ชันใหม่ อย่างไรก็ตาม คุณไม่จำเป็นต้องติดตั้งระบบปฏิบัติการใหม่ เพื่อเลิกใช้งานศูนย์ข้อมูล
ข้อควรพิจารณาก่อนเลิกใช้งานศูนย์ข้อมูล
โปรดคำนึงถึงข้อควรพิจารณาต่อไปนี้เมื่อเลิกใช้งานศูนย์ข้อมูล
- บล็อกการรับส่งข้อมูลทั้งหมดในรันไทม์และการจัดการไปยังศูนย์ข้อมูลที่เลิกใช้งานแล้ว และเปลี่ยนเส้นทาง ไปยังศูนย์ข้อมูลอื่นๆ
- หลังจากเลิกใช้งานศูนย์ข้อมูลแล้ว คุณจะมีคลัสเตอร์ Apigee ที่มีความจุลดลง หากต้องการชดเชย ให้พิจารณาเพิ่มความจุในศูนย์ข้อมูลที่เหลือหรือเพิ่มศูนย์ข้อมูลหลังจากการเลิกใช้งาน
- ในระหว่างกระบวนการเลิกใช้งาน อาจมีความเสี่ยงที่ข้อมูลวิเคราะห์จะสูญหาย ทั้งนี้ขึ้นอยู่กับ คอมโพเนนต์การวิเคราะห์ที่ติดตั้งในศูนย์ข้อมูลที่กำลังจะเลิกใช้งาน ดูรายละเอียดเพิ่มเติมได้ที่เพิ่มหรือนำโหนด Qpid ออก
- ก่อนที่จะเลิกใช้งานศูนย์ข้อมูล คุณควรทำความเข้าใจวิธีกำหนดค่าคอมโพเนนต์ทั้งหมด ในศูนย์ข้อมูลทั้งหมด โดยเฉพาะเซิร์ฟเวอร์ SymasLDAP, ZooKeeper, Cassandra และ Postgres นอกจากนี้ คุณควรสำรองข้อมูลคอมโพเนนต์ทั้งหมดและการกำหนดค่าของคอมโพเนนต์เหล่านั้นด้วย
ก่อนจะเริ่ม
- เซิร์ฟเวอร์การจัดการ: ขั้นตอนการเลิกใช้งานทั้งหมดขึ้นอยู่กับเซิร์ฟเวอร์การจัดการเป็นอย่างมาก หากมีเซิร์ฟเวอร์การจัดการเพียงเซิร์ฟเวอร์เดียว เราขอแนะนำให้คุณติดตั้งคอมโพเนนต์เซิร์ฟเวอร์การจัดการใหม่ในศูนย์ข้อมูลอื่นที่ไม่ใช่ dc-1 ก่อนที่จะเลิกใช้งานเซิร์ฟเวอร์การจัดการใน dc-1 และตรวจสอบว่าเซิร์ฟเวอร์การจัดการอย่างน้อย 1 เซิร์ฟเวอร์พร้อมใช้งานอยู่เสมอ
- เราเตอร์: ก่อนที่จะเลิกใช้งานเราเตอร์ ให้ปิดใช้การเข้าถึงเราเตอร์ โดยการบล็อกพอร์ต 15999 ตรวจสอบว่าไม่มีการนำการรับส่งข้อมูลรันไทม์ ไปยังเราเตอร์ที่เลิกใช้งาน
- Cassandra และ ZooKeeper:
ส่วนด้านล่างจะอธิบายวิธีเลิกใช้งาน dc-1 ในการตั้งค่าศูนย์ข้อมูล 2 แห่ง
หากคุณมีศูนย์ข้อมูลมากกว่า 2 แห่ง โปรดตรวจสอบว่าได้นำการอ้างอิงทั้งหมดไปยังโหนดที่จะเลิกใช้งาน (ในกรณีนี้คือ dc-1) ออกจากไฟล์การกำหนดค่าแบบเงียบทั้งหมดในศูนย์ข้อมูลที่เหลือทั้งหมด สำหรับโหนด Cassandra ที่จะเลิกใช้งาน ให้ยกเลิกการเชื่อมต่อโฮสต์เหล่านั้นจาก
CASS_HOSTS
โหนด Cassandra ที่เหลือควรยังคงอยู่ในลำดับเดิมของCASS_HOSTS
- Postgres: หากเลิกใช้งานมาสเตอร์ Postgres โปรดตรวจสอบว่าได้เลื่อนระดับโหนดสแตนด์บายที่พร้อมใช้งาน เป็นมาสเตอร์ Postgres ใหม่ แม้ว่าเซิร์ฟเวอร์ QPID จะเก็บบัฟเฟอร์ไว้ในคิว แต่หากมาสเตอร์ Postgres ไม่พร้อมใช้งานเป็นเวลานาน คุณอาจเสี่ยงต่อการสูญเสียข้อมูลวิเคราะห์
ข้อกำหนดเบื้องต้น
ก่อนที่จะเลิกใช้งานคอมโพเนนต์ใดๆ เราขอแนะนำให้คุณสำรองข้อมูลโหนดทั้งหมดอย่างสมบูรณ์ ใช้ขั้นตอนสำหรับ Edge เวอร์ชันปัจจุบันเพื่อทำการสำรองข้อมูล ดูข้อมูลเพิ่มเติมเกี่ยวกับการสำรองข้อมูลได้ที่ การสำรองและกู้คืนข้อมูล
- ตรวจสอบว่า Edge ทำงานอยู่ก่อนที่จะเลิกใช้งานโดยใช้คำสั่งต่อไปนี้
/opt/apigee/apigee-service/bin/apigee-all status
- ตรวจสอบว่าไม่มีการรับส่งข้อมูลรันไทม์มายังศูนย์ข้อมูลที่คุณกำลัง เลิกใช้งาน
ลำดับการเลิกใช้งานคอมโพเนนต์
หากติดตั้ง Edge สำหรับ Private Cloud ในหลายโหนด คุณควรเลิกใช้งานคอมโพเนนต์ Edge ในโหนดเหล่านั้นตามลำดับต่อไปนี้
- Edge UI (edge-ui)
- เซิร์ฟเวอร์การจัดการ (edge-management-server)
- Symas LDAP (apigee-openldap)
- เราเตอร์ (เราเตอร์ขอบ)
- Message Processor (edge-message-processor)
- เซิร์ฟเวอร์ Qpid และ Qpidd (edge-qpid-server และ apigee-qpidd)
- ฐานข้อมูล Postgres และ PostgreSQL (edge-postgres-server และ apigee-postgresql)
- ZooKeeper (apigee-zookeeper)
- Cassandra (apigee-cassandra)
ส่วนต่อไปนี้จะอธิบายวิธีเลิกใช้งานคอมโพเนนต์แต่ละรายการ
UI ของ Edge
หากต้องการหยุดและถอนการติดตั้งคอมโพเนนต์ UI ของ Edge ของ dc-1 ให้ป้อนคำสั่งต่อไปนี้
/opt/apigee/apigee-service/bin/apigee-service edge-ui stop
/opt/apigee/apigee-service/bin/apigee-service edge-ui uninstall
เซิร์ฟเวอร์การจัดการ
หากต้องการเลิกใช้งานเซิร์ฟเวอร์การจัดการใน dc-1 ให้ทำตามขั้นตอนต่อไปนี้
- หยุดเซิร์ฟเวอร์การจัดการใน dc-1 โดยทำดังนี้
apigee-service edge-management-server stop
- ค้นหา UUID ของเซิร์ฟเวอร์การจัดการที่ลงทะเบียนใน dc-1
curl -u <AdminEmailID>:'<AdminPassword>' -X GET “http://{MS_IP}:8080/v1/servers?pod=central®ion=dc-1&type=management-server”
- วิธียกเลิกการลงทะเบียนประเภทเซิร์ฟเวอร์
curl -u <AdminEmailID>:'<AdminPassword>' -X POST http://{MS_IP}:8080/v1/servers -d "type=management-server®ion=dc-1&pod=central&uuid=UUID&action=remove"
- ลบเซิร์ฟเวอร์ หมายเหตุ: หากมีการติดตั้งคอมโพเนนต์อื่นๆ ในเซิร์ฟเวอร์นี้ด้วย
ให้ยกเลิกการลงทะเบียนคอมโพเนนต์ทั้งหมดก่อนที่จะลบ UUID
curl -u <AdminEmailID>:'<AdminPassword>' -X DELETE http://{MS_IP}:8080/v1/servers/{UUID}
- ถอนการติดตั้งคอมโพเนนต์เซิร์ฟเวอร์การจัดการใน dc-1
/opt/apigee/apigee-service/bin/apigee-service edge-management-server uninstall
Symas LDAP
ส่วนนี้จะอธิบายวิธีเลิกใช้งาน SymasLDAP ใน dc-1
หมายเหตุ: หากมีศูนย์ข้อมูลมากกว่า 2 แห่ง โปรดดูการตั้งค่าที่มีศูนย์ข้อมูลมากกว่า 2 แห่งด้านล่าง
หากต้องการเลิกใช้งาน SymasLDAP ใน dc-1 ให้ทำตามขั้นตอนต่อไปนี้
- สำรองข้อมูลโหนด dc-1 SymasLDAP โดยทำตามขั้นตอนใน วิธีสำรองข้อมูล
หยุดการจำลองข้อมูลระหว่างศูนย์ข้อมูล 2 แห่ง ได้แก่ dc-1 และ dc-2 โดย ทำตามขั้นตอนต่อไปนี้ในศูนย์ข้อมูลทั้ง 2 แห่ง
- ตรวจสอบสถานะปัจจุบัน
/opt/symas/bin/ldapsearch -H ldap://{HOST}:{PORT} -LLL -x -b "cn=config" -D "cn=admin,cn=config" -w {credentials} -o ldif-wrap=no 'olcSyncRepl' | grep olcSyncrepl
เอาต์พุตควรมีลักษณะคล้ายกับตัวอย่างต่อไปนี้
olcSyncrepl: {0}rid=001 provider=ldap://{HOST}:{PORT}/ binddn="cn=manager,dc=apigee,dc=com" bindmethod=simple credentials={credentials} searchbase="dc=apigee,dc=com" attrs="*,+" type=refreshAndPersist retry="60 1 300 12 7200 +" timeout=1
- สร้างไฟล์
break_repl.ldif
ที่มีคำสั่งต่อไปนี้dn: olcDatabase={2}mdb,cn=config changetype: modify delete: olcSyncRepl dn: olcDatabase={2}mdb,cn=config changetype: modify delete: olcMirrorMode
- เรียกใช้คำสั่ง
ldapmodify
/opt/symas/bin/ldapmodify -x -w {credentials} -D "cn=admin,cn=config" -H "ldap://{HOST}:{PORT}/" -f path/to/file/break_repl.ldif
เอาต์พุตควรมีลักษณะคล้ายกับตัวอย่างต่อไปนี้
modifying entry "olcDatabase={2}mdb,cn=config" modifying entry "olcDatabase={2}mdb,cn=config"
- ตรวจสอบสถานะปัจจุบัน
คุณสามารถยืนยันว่า dc-2 ไม่ได้จำลองแบบไปยัง dc-1 อีกต่อไปได้โดยการสร้างรายการใน LDAP ของ dc-2 และตรวจสอบว่ารายการดังกล่าวไม่ปรากฏใน LDAP ของ dc-1
คุณจะทำตามขั้นตอนด้านล่างเพื่อสร้างผู้ใช้ที่มีสิทธิ์อ่านอย่างเดียวในโหนด dc-2 SymasLDAP แล้วตรวจสอบว่ามีการจำลองผู้ใช้หรือไม่ก็ได้ จากนั้นระบบจะลบผู้ใช้
- สร้างไฟล์
readonly-user.ldif
ใน dc-2 ที่มีเนื้อหาต่อไปนี้dn: uid=readonly-user,ou=users,ou=global,dc=apigee,dc=com objectClass: organizationalPerson objectClass: person objectClass: inetOrgPerson objectClass: top cn: readonly-user sn: readonly-user userPassword: {testPassword}
- เพิ่มผู้ใช้ด้วยคำสั่ง `ldapadd` ใน dc-2
/opt/symas/bin/ldapadd -H ldap://{HOST}:{PORT} -w {credentials} -D "cn=manager,dc=apigee,dc=com" -f path/to/file/readonly-user.ldif
เอาต์พุตจะมีลักษณะคล้ายกับตัวอย่างต่อไปนี้
adding new entry "uid=readonly-user,ou=users,ou=global,dc=apigee,dc=com"
- ค้นหาผู้ใช้ใน dc-1 เพื่อให้แน่ใจว่าไม่ได้ทำซ้ำผู้ใช้ หากไม่มีผู้ใช้
ใน dc-1 คุณจะมั่นใจได้ว่า LDAPs ทั้ง 2 รายการจะไม่จำลองแบบอีกต่อไป
/opt/symas/bin/ldapsearch -H ldap://{HOST}:{PORT} -x -w {credentials} -D "cn=manager,dc=apigee,dc=com" -b uid=readonly-user,ou=users,ou=global,dc=apigee,dc=com -LLL
เอาต์พุตควรมีลักษณะคล้ายกับตัวอย่างต่อไปนี้
No such object (32) Matched DN: ou=users,ou=global,dc=apigee,dc=com
- นำผู้ใช้แบบอ่านอย่างเดียวที่คุณเพิ่มไว้ก่อนหน้านี้ออกโดยทำดังนี้
/opt/symas/bin/ldapdelete -v -H ldap://{HOST}:{PORT} -w {credentials} -D "cn=manager,dc=apigee,dc=com" "uid=readonly-user,ou=users,ou=global,dc=apigee,dc=com"
- สร้างไฟล์
- หยุด SymasLDAP ใน dc-1
/opt/apigee/apigee-service/bin/apigee-service apigee-openldap stop
- ถอนการติดตั้งคอมโพเนนต์ SymasLDAP ใน dc-1
/opt/apigee/apigee-service/bin/apigee-service apigee-openldap uninstall
เราเตอร์
ส่วนนี้จะอธิบายวิธียกเลิกการใช้งานเราเตอร์ ดูรายละเอียดเพิ่มเติมเกี่ยวกับการนำเราเตอร์ออกได้ที่หัวข้อ นำเซิร์ฟเวอร์ออก
ขั้นตอนต่อไปนี้จะเลิกใช้งานเราเตอร์จาก dc-1 หากมีการกำหนดค่าโหนดเราเตอร์หลายรายการใน dc-1 ให้ทำตามขั้นตอนในโหนดเราเตอร์ทั้งหมด ทีละรายการ
หมายเหตุ: ในที่นี้ถือว่ามีการกำหนดค่าพอร์ตตรวจสอบสถานะ 15999 ของเราเตอร์ในตัวจัดสรรภาระงาน และการบล็อกพอร์ต 15999 จะทำให้เราเตอร์เข้าถึงไม่ได้ คุณอาจต้องมีสิทธิ์เข้าถึงระดับรูท เพื่อบล็อกพอร์ต
หากต้องการเลิกใช้งานเราเตอร์ ให้ทำตามขั้นตอนต่อไปนี้
ปิดใช้ความสามารถในการเข้าถึงของเราเตอร์โดยการบล็อกพอร์ต 15999 ซึ่งเป็นพอร์ตตรวจสอบประสิทธิภาพการทำงาน ตรวจสอบว่ามีการบล็อกการรับส่งข้อมูลรันไทม์ในศูนย์ข้อมูลนี้
iptables -A INPUT -i eth0 -p tcp --dport 15999 -j REJECT
ตรวจสอบว่าเราเตอร์เข้าถึงได้โดยทำดังนี้
curl -vvv -X GET http://{ROUTER_IP}:15999/v1/servers/self/reachable
เอาต์พุตควรมีลักษณะคล้ายกับตัวอย่างต่อไปนี้
About to connect() to 10.126.0.160 port 15999 (#0) Trying 10.126.0.160... Connection refused Failed connect to 10.126.0.160:15999; Connection refused Closing connection 0 curl: (7) Failed connect to 10.126.0.160:15999; Connection refused
- รับ UUID ของเราเตอร์ตามที่อธิบายไว้ใน รับ UUID
- หยุดเราเตอร์
/opt/apigee/apigee-service/bin/apigee-service edge-router stop
- แสดงรายการพ็อดเกตเวย์ที่มีในองค์กรโดยใช้คำสั่งต่อไปนี้
curl -u <AdminEmailID>:'<AdminPassword>' -X GET "http://{MS_IP}:8080/v1/organizations/{ORG}/pods"
- ยกเลิกการลงทะเบียนประเภทของเซิร์ฟเวอร์
curl -u <AdminEmailID>:'<AdminPassword>' -X POST http://{MS_IP}:8080/v1/servers -d "type=router®ion=dc-1&pod=gateway-1&uuid=UUID&action=remove"
- ยกเลิกการลงทะเบียนเซิร์ฟเวอร์
curl -u <AdminEmailID>:'<AdminPassword>’ -X DELETE http://{MS_IP}:8080/v1/servers/UUID
- ถอนการติดตั้ง
edge-router
ดู นำเซิร์ฟเวอร์ออก/opt/apigee/apigee-service/bin/apigee-service edge-router uninstall
- ล้างกฎ
iptables
เพื่อเปิดใช้พอร์ต 15999 ที่ถูกบล็อกiptables -F
Message Processor
ส่วนนี้จะอธิบายวิธียกเลิกการใช้งาน Message Processor จาก dc-1 ดูรายละเอียดเพิ่มเติมเกี่ยวกับการนำ Message Processor ออกได้ที่ นำเซิร์ฟเวอร์ออก
เนื่องจากเราสมมติว่า dc-1 มีการติดตั้งคลัสเตอร์แบบ 12 โหนด จึงมีการกำหนดค่าโหนด Message Processor 2 โหนดใน dc-1 เรียกใช้คำสั่งต่อไปนี้ในทั้ง 2 โหนด
- รับ UUID ของเครื่องมือประมวลผลข้อความตามที่อธิบายไว้ใน รับ UUID
- หยุด Message Processor โดยทำดังนี้
apigee-service edge-message-processor stop
- ยกเลิกการลงทะเบียนประเภทของเซิร์ฟเวอร์
curl -u <AdminEmailID>:'<AdminPassword>' -X POST http://{MS_IP}:8080/v1/servers -d "type=message-processor®ion=dc-1&pod=gateway-1&uuid=UUID&action=remove"
- ยกเลิกการเชื่อมโยงสภาพแวดล้อมกับ Message Processor
curl -H "Content-Type:application/x-www-form-urlencoded" <AdminEmailID>:'<AdminPassword>’ \ -X POST http://{MS_IP}:8080/v1/organizations/{ORG}/environments/{ENV}/servers \ -d "action=remove&uuid=UUID"
- ยกเลิกการลงทะเบียนประเภทของเซิร์ฟเวอร์
curl -u <AdminEmailID>:'<AdminPassword>' -X POST http://{MS_IP}:8080/v1/servers -d "type=message-processor®ion=dc-1&pod=gateway-1&uuid=UUID&action=remove"
- ถอนการติดตั้งตัวประมวลผลข้อความ
/opt/apigee/apigee-service/bin/apigee-service edge-message-processor uninstall
- ยกเลิกการลงทะเบียนเซิร์ฟเวอร์
curl -u <AdminEmailID>:'<AdminPassword>' -X DELETE http://{MS_IP}:8080/v1/servers/UUID
เซิร์ฟเวอร์ Qpid และ Qpidd
ส่วนนี้จะอธิบายวิธีเลิกใช้งาน Qpid Server (edge-qpid-server
) และ Qpidd
(apigee-qpidd
)
มีโหนด Qpid 2 รายการที่กำหนดค่าไว้ใน dc-1 ดังนั้นคุณต้องทำตามขั้นตอนต่อไปนี้สำหรับทั้ง 2 โหนด
- รับ UUID สำหรับ Qpidd ตามที่อธิบายไว้ในรับ UUID
- หยุด
edge-qpid-server
และapigee-qpidd
/opt/apigee/apigee-service/bin/apigee-service edge-qpid-server stop
/opt/apigee/apigee-service/bin/apigee-service apigee-qpidd stop
- รับรายชื่อกลุ่มนักวิเคราะห์และกลุ่มผู้บริโภค
curl -u <AdminEmailID>:'<AdminPassword>' -X GET http://{MS_IP}:8080/v1/analytics/groups/ax
- นำ Qpid ออกจากกลุ่มผู้ใช้
curl -u <AdminEmailID>:'<AdminPassword>' -H "Content-Type: application/json" -X DELETE \ "http://{MS_IP}:8080/v1/analytics/groups/ax/{ax_group}/consumer-groups/{consumer_group}/consumers/{QPID_UUID}"
- นำ Qpid ออกจากกลุ่มการวิเคราะห์
curl -v -u <AdminEmailID>:'<AdminPassword>' \ -X DELETE "http://{MS_IP}:8080/v1/analytics/groups/ax/{ax_group}/servers?uuid={QPID_UUID}&type=qpid-server"
- ยกเลิกการลงทะเบียนเซิร์ฟเวอร์ Qpid จากการติดตั้ง Edge โดยทำดังนี้
curl -u <AdminEmailID>:'<AdminPassword>' -X POST http://{MS_IP}:8080/v1/servers \ -d "type=qpid-server®ion=dc-1&pod=central&uuid={QPID_UUID}&action=remove"
- นำเซิร์ฟเวอร์ Qpid ออกจากการติดตั้ง Edge
curl -u <AdminEmailID>:'<AdminPassword>' -X DELETE http://{MS_IP}:8080/v1/servers/UUID
- รีสตาร์ทคอมโพเนนต์ edge-qpid-server ทั้งหมดในทุกโหนดเพื่อให้แน่ใจว่าคอมโพเนนต์เหล่านั้นจะรับการเปลี่ยนแปลง
$ /opt/apigee/apigee-service/bin/apigee-service edge-qpid-server restart $ /opt/apigee/apigee-service/bin/apigee-service edge-qpid-server wait_for_ready
- ถอนการติดตั้ง edge-qpid-server และ apigee-qpidd
$ /opt/apigee/apigee-service/bin/apigee-service edge-qpid-server uninstall $ /opt/apigee/apigee-service/bin/apigee-service apigee-qpidd uninstall
Postgres และ Postgresql
ศูนย์ข้อมูลที่คุณกำลังเลิกใช้งานอาจมีมาสเตอร์ Postgres หรือสแตนด์บาย Postgres ส่วนต่อไปนี้จะอธิบายวิธีเลิกใช้งาน
การเลิกใช้งานมาสเตอร์ Postgres
หมายเหตุ: หากเลิกใช้งานมาสเตอร์ Postgres โปรดตรวจสอบว่าได้เลื่อนระดับโหนดสแตนด์บายที่พร้อมใช้งานเป็นมาสเตอร์ Postgres ใหม่ แม้ว่าคิว QPID จะบัฟเฟอร์ข้อมูล แต่หากมาสเตอร์ Postgres ไม่พร้อมใช้งานเป็นเวลานาน คุณก็อาจเสี่ยงต่อการสูญเสียข้อมูลวิเคราะห์
วิธีเลิกใช้งานมาสเตอร์ Postgres
- สำรองข้อมูลโหนดหลัก Postgres ของ dc-1 โดยทำตามวิธีการในลิงก์ต่อไปนี้
- รับ UUID ของเซิร์ฟเวอร์ Postgres ตามที่อธิบายไว้ใน รับ UUID
- ใน dc-1 ให้หยุด
edge-postgres-server
และapigee-postgresql
ในมาสเตอร์ปัจจุบัน/opt/apigee/apigee-service/bin/apigee-service edge-postgres-server stop
/opt/apigee/apigee-service/bin/apigee-service apigee-postgresql stop
- ในโหนดสแตนด์บายบน dc-2 ให้ป้อนคำสั่งต่อไปนี้เพื่อทำให้เป็นโหนดหลัก
/opt/apigee/apigee-service/bin/apigee-service apigee-postgresql promote-standby-to-master <IP of OLD Progress master>
หมายเหตุ: หากมีโหนด Postgres สแตนด์บายมากกว่า 1 รายการ คุณต้องเพิ่มรายการโฮสต์ใน มาสเตอร์ใหม่และอัปเดตการตั้งค่าการจำลองแบบสำหรับโหนด Postgres สแตนด์บายที่มีอยู่ทั้งหมด
หากต้องการเพิ่มรายการโฮสต์ไปยังมาสเตอร์ Postgres ใหม่ ให้ทำตามขั้นตอนในส่วนที่เกี่ยวข้อง ด้านล่าง
หากเหลือโหนดสแตนด์บายเพียงโหนดเดียว
ตัวอย่างเช่น สมมติว่าก่อนที่จะเลิกใช้งาน มีการกำหนดค่าโหนด Postgres 3 รายการ คุณเลิกใช้งานมาสเตอร์ที่มีอยู่และเลื่อนระดับโหนดสแตนด์บาย Postgres ที่เหลืออยู่ รายการใดรายการหนึ่งให้เป็นมาสเตอร์ กำหนดค่าโหนดสแตนด์บายที่เหลือโดยทำตามขั้นตอนต่อไปนี้
- ในมาสเตอร์ใหม่ ให้แก้ไขไฟล์การกำหนดค่า
เพื่อตั้งค่าต่อไปนี้
PG_MASTER=IP_or_DNS_of_new_PG_MASTER PG_STANDBY=IP_or_DNS_of_PG_STANDBY
- เปิดใช้การจำลองในมาสเตอร์ใหม่
/opt/apigee/apigee-service/bin/apigee-service apigee-postgresql setup-replication-on-master -f configFIle
หากมีโหนดสแตนด์บายเหลือมากกว่า 1 รายการ
- เพิ่มการกำหนดค่าต่อไปนี้ใน
/opt/apigee/customer/application/postgresql.properties
conf_pg_hba_replication.connection=host replication apigee standby_1_ip/32 trust \n host replication apigee standby_2_ip/32 trust
- ตรวจสอบว่าไฟล์ /opt/apigee/customer/application/postgresql.properties เป็นของ
ผู้ใช้ apigee:
chown apigee:apigee /opt/apigee/customer/application/postgresql.properties
- รีสตาร์ท
apigee-postgresql
apigee-service apigee-postgresql restart
- แก้ไขไฟล์การกำหนดค่า
/opt/silent.conf
และอัปเดต ฟิลด์PG_MASTER
ด้วยที่อยู่ IP ของมาสเตอร์ Postgres ใหม่ - นำข้อมูล Postgres เก่าออกด้วยคำสั่งต่อไปนี้
rm -rf /opt/apigee/data/apigee-postgresql/
- ตั้งค่าการจำลองแบบในโหนดสแตนด์บาย
/opt/apigee/apigee-service/bin/apigee-service apigee-postgresql setup-replication-on-standby -f configFile
- ตรวจสอบว่าได้ตั้งค่ามาสเตอร์ Postgres อย่างถูกต้องแล้วโดยป้อนคำสั่งต่อไปนี้ใน dc-2
/opt/apigee/apigee-service/bin/apigee-service apigee-postgresql postgres-check-master
- นำเซิร์ฟเวอร์ Postgresql ออกจากกลุ่มการวิเคราะห์และกลุ่มผู้ใช้ แล้วเพิ่มเซิร์ฟเวอร์
- นําเซิร์ฟเวอร์ Postgres เก่าออกจากกลุ่มการวิเคราะห์โดยทําตามวิธีการใน นําเซิร์ฟเวอร์ Postgres ออกจากกลุ่มการวิเคราะห์
- เพิ่มเซิร์ฟเวอร์ Postgres ใหม่ลงในกลุ่มการวิเคราะห์โดยทำตามวิธีการใน เพิ่มเซิร์ฟเวอร์ Postgres ที่มีอยู่ลงในกลุ่มการวิเคราะห์
- ยกเลิกการลงทะเบียนเซิร์ฟเวอร์ Postgres เก่าจาก dc-1 โดยทำดังนี้
curl -u <AdminEmailID>:<AdminPassword> -X POST http://{MS_IP}:8080/v1/servers \ -d "type=postgres-server®ion=dc-1&pod=analytics&uuid=UUID&action=remove"
- ลบเซิร์ฟเวอร์ postgres เก่าออกจาก dc-1
curl -u <AdminEmailID>:'<AdminPassword>' -X DELETE http://{MS_IP}:8080/v1/servers/UUID
- ตอนนี้คุณสามารถเลิกใช้งานมาสเตอร์ Postgres เก่าได้อย่างปลอดภัยแล้ว ถอนการติดตั้ง
edge-postgres-server
และapigee-postgresql
โดยทำดังนี้/opt/apigee/apigee-service/bin/apigee-service edge-postgres-server uninstall /opt/apigee/apigee-service/bin/apigee-service apigee-postgresql uninstall
วิธีอัปเดตการตั้งค่าการจำลองแบบในโหนดสแตนด์บาย
การเลิกใช้งานสแตนด์บายของ Postgres
หมายเหตุ: เอกสารประกอบสำหรับการ ติดตั้งคลัสเตอร์แบบ 12 โหนดแสดงโหนด postgresql dc-1 เป็นโหนดหลัก แต่เพื่อความสะดวก ในส่วนนี้จะถือว่าโหนด postgresql dc-1 เป็นโหนดสำรอง และโหนด postgresql dc-2 เป็นโหนดหลัก
หากต้องการเลิกใช้งานสแตนด์บาย Postgres ให้ทำตามขั้นตอนต่อไปนี้
- รับ UUID ของเซิร์ฟเวอร์ Postgres โดยทำตามวิธีการใน รับ UUID
- หยุด
apigee-postgresql
ในโหนดสแตนด์บายปัจจุบันใน dc-1 โดยทำดังนี้/opt/apigee/apigee-service/bin/apigee-service edge-postgres-server stop
/opt/apigee/apigee-service/bin/apigee-service apigee-postgresql stop
- นำเซิร์ฟเวอร์ Postgresql ออกจากกลุ่มการวิเคราะห์และกลุ่มผู้ใช้ แล้วเพิ่มเซิร์ฟเวอร์
- นําเซิร์ฟเวอร์ Postgres เก่าออกจากกลุ่มการวิเคราะห์โดยทําตามวิธีการใน นําเซิร์ฟเวอร์ Postgres ออกจากกลุ่มการวิเคราะห์
- เพิ่มเซิร์ฟเวอร์ Postgres ใหม่ลงในกลุ่มการวิเคราะห์โดยทำตามวิธีการใน เพิ่มเซิร์ฟเวอร์ Postgres ที่มีอยู่ลงในกลุ่มการวิเคราะห์
- ยกเลิกการลงทะเบียนเซิร์ฟเวอร์ Postgres เก่าจาก dc-1 โดยทำดังนี้
curl -u <AdminEmailID>:'<AdminPassword>' -X POST http://{MS_IP}:8080/v1/servers \ -d "type=postgres-server®ion=dc-1&pod=analytics&uuid=UUID&action=remove"
- ลบเซิร์ฟเวอร์ postgres เก่าออกจาก dc-1
curl -u <AdminEmailID>:'<AdminPassword>' -X DELETE http://{MS_IP}:8080/v1/servers/UUID
- ตอนนี้คุณสามารถเลิกใช้งานมาสเตอร์ Postgres เก่าได้อย่างปลอดภัยแล้ว ถอนการติดตั้ง
edge-postgres-server
และapigee-postgresql
โดยทำดังนี้/opt/apigee/apigee-service/bin/apigee-service edge-postgres-server uninstall
/opt/apigee/apigee-service/bin/apigee-service apigee-postgresql uninstall
ZooKeeper และ Cassandra
ส่วนนี้จะอธิบายวิธีเลิกใช้งานเซิร์ฟเวอร์ ZooKeeper และ Cassandra ในการตั้งค่าศูนย์ข้อมูล 2 แห่ง
หากคุณมีศูนย์ข้อมูลมากกว่า 2 แห่ง โปรดตรวจสอบว่าได้นำการอ้างอิงทั้งหมดไปยังโหนดที่จะเลิกใช้งาน (ในกรณีนี้คือ dc-1) ออกจากไฟล์การกำหนดค่าแบบเงียบทั้งหมดในศูนย์ข้อมูลที่เหลือทั้งหมด สำหรับโหนด Cassandra ที่จะเลิกใช้งาน ให้ยกเลิกการเชื่อมต่อโฮสต์เหล่านั้นจาก
CASS_HOSTS
โหนด Cassandra ที่เหลือควรยังคงอยู่ในลำดับเดิมของCASS_HOSTS
หมายเหตุเกี่ยวกับ ZooKeeper: คุณต้องรักษาจำนวนโหนดผู้ลงคะแนนขั้นต่ำขณะแก้ไขพร็อพเพอร์ตี้
ZK_HOST
ในไฟล์การกำหนดค่าเพื่อให้มั่นใจว่ากลุ่ม ZooKeeper จะยังคงทำงานได้ คุณต้องมีจำนวนโหนดผู้ลงคะแนนเป็นจำนวนคี่ ในการกำหนดค่า ดูข้อมูลเพิ่มเติมได้ที่หัวข้องานการบำรุงรักษา Apache ZooKeeperวิธีเลิกใช้งานเซิร์ฟเวอร์ ZooKeeper และ Cassandra
- สำรองข้อมูลโหนด Cassandra และ ZooKeeper ของ dc-1 โดยทำตามวิธีการในลิงก์ต่อไปนี้
แสดงรายการ UUID ของเซิร์ฟเวอร์ ZooKeeper และ Cassandra ในศูนย์ข้อมูลที่จะเลิกใช้งานโหนด Cassandra
apigee-adminapi.sh servers list -r dc-1 -p central -t application-datastore --admin <AdminEmailID> --pwd '<AdminPassword>' --host localhost
- ยกเลิกการลงทะเบียนประเภทของเซิร์ฟเวอร์
curl -u <AdminEmailID>:'<AdminPassword>' -X POST http://MS_IP:8080/v1/servers -d "type=cache-datastore&type=user-settings-datastore&type=scheduler-datastore&type=audit-datastore&type=apimodel-datastore&type=application-datastore&type=edgenotification-datastore&type=identityzone-datastore&type=user-settings-datastore&type=auth-datastore®ion=dc-1&pod=central&uuid=UUID&action=remove"
- ยกเลิกการลงทะเบียนเซิร์ฟเวอร์
curl -u <AdminEmailID>:'<AdminPassword>' -X DELETE http://MS_IP:8080/v1/servers/UUID
- อัปเดตไฟล์การกำหนดค่าโดยนำ IP ของโหนดที่เลิกใช้งานแล้วออกจาก
ZK_HOSTS
และCASS_HOSTS
ตัวอย่าง: สมมติว่าคุณมี IP
$IP1 $IP2 $IP3
ใน dc-1 และ$IP4 $IP5 $IP6
ใน dc-2 และคุณ กำลังเลิกใช้งาน dc-1 จากนั้นคุณควรนำ IP$IP1 $IP2 $IP3
ออกจาก ไฟล์การกำหนดค่า- รายการไฟล์การกำหนดค่าที่มีอยู่
ZK_HOSTS="$IP1 $IP2 $IP3 $IP4 $IP5 $IP6" CASS_HOSTS="$IP1:1,1 $IP2:1,1 $IP3:1,1, $IP4:2,1 $IP5:2,1 $IP6:2,1”
- รายการไฟล์การกำหนดค่าใหม่
ZK_HOSTS="$IP4 $IP5 $IP6" CASS_HOSTS="$IP4:2,1 $IP5:2,1 $IP6:2,1"
- รายการไฟล์การกำหนดค่าที่มีอยู่
- อัปเดตไฟล์การกำหนดค่าแบบเงียบ (แก้ไขในขั้นตอนที่ จ.) ด้วย IP ของโหนดที่นำออก
และเลิกใช้งานแล้ว และเรียกใช้โปรไฟล์เซิร์ฟเวอร์การจัดการ
ในโหนดทั้งหมดที่โฮสต์เซิร์ฟเวอร์การจัดการ
/opt/apigee/apigee-setup/bin/setup.sh -p ms -f updated_config_file
- อัปเดตไฟล์การกำหนดค่าด้วย IP ของโหนดที่นำออกและเลิกใช้งานแล้ว และเรียกใช้โปรไฟล์ MP/RMP
ในโหนดเราเตอร์และ Message Processor ทั้งหมด
- หากกำหนดค่า Edge Router และ Message Processor ในโหนดเดียวกัน ให้ป้อน
/opt/apigee/apigee-setup/bin/setup.sh -p rmp -f updated_config_file
หากกำหนดค่า Edge Router และ Message Processor ในโหนดแยกกัน ให้ป้อนข้อมูลต่อไปนี้
สำหรับเราเตอร์
/opt/apigee/apigee-setup/bin/setup.sh -p r -f updated_config_file
สำหรับ Message Processor
/opt/apigee/apigee-setup/bin/setup.sh -p mp -f updated_config_file
- หากกำหนดค่า Edge Router และ Message Processor ในโหนดเดียวกัน ให้ป้อน
- กำหนดค่าโหนด Qpid ทั้งหมดใหม่ โดยนำ IP ของโหนดที่เลิกใช้งานแล้วออกจากไฟล์การตอบกลับ
/opt/apigee/apigee-setup/bin/setup.sh -p qs -f updated_config_file
- กำหนดค่าโหนด Postgres ทั้งหมดใหม่โดยนำ IP ของโหนดที่เลิกใช้งานแล้วออกจากไฟล์การตอบกลับ
/opt/apigee/apigee-setup/bin/setup.sh -p ps -f updated_config_file
- แก้ไขคีย์สเปซ
system_auth
หากเปิดใช้การตรวจสอบสิทธิ์ Cassandra ในโหนด Cassandra ที่มีอยู่ ให้อัปเดตปัจจัยการจำลองของคีย์สเปซsystem_auth
โดยเรียกใช้คำสั่งต่อไปนี้ALTER KEYSPACE system_auth WITH replication = {'class': 'NetworkTopologyStrategy', 'dc-2': '3'};
คำสั่งนี้จะตั้งค่าปัจจัยการจำลองเป็น
'3'
ซึ่งระบุโหนด Cassandra 3 โหนด ในคลัสเตอร์ แก้ไขค่านี้ตามที่จำเป็นหลังจากทำตามขั้นตอนนี้แล้ว โทโพโลยี Cassandra ไม่ควรมี
dc-1
ในคีย์สเปซใดๆ - เลิกใช้งานโหนด Cassandra ใน dc-1 ทีละรายการ
หากต้องการเลิกใช้งานโหนด Cassandra ให้ป้อนคำสั่งต่อไปนี้
/opt/apigee/apigee-cassandra/bin/nodetool -h cassIP -u cassandra -pw '<AdminPassword>' decommission
- ตรวจสอบการเชื่อมต่อของโหนด Cassandra จาก dc-1 โดยใช้คำสั่งใดคำสั่งหนึ่งต่อไปนี้
/opt/apigee/apigee-cassandra/bin/cqlsh cassIP 9042 -u cassandra -p '<AdminPassword>'
หรือคำสั่งการยืนยันรองที่จะเรียกใช้ในโหนดที่เลิกใช้งานแล้ว
/opt/apigee/apigee-cassandra/bin/nodetool netstats
คำสั่งด้านบนควรแสดงผลดังนี้
Mode: DECOMMISSIONED
- เรียกใช้โปรไฟล์ DS สำหรับโหนด Cassandra และ ZooKeeper ทั้งหมดใน dc-2
/opt/apigee/apigee-setup/bin/setup.sh -p ds -f updated_config_file
- หยุด
apigee-cassandra
และapigee-zookeeper
ใน dc-1apigee-service apigee-cassandra stop
apigee-service apigee-zookeeper stop
- ถอนการติดตั้ง
apigee-cassandra
และapigee-zookeeper
ใน dc-1 โดยทำดังนี้apigee-service apigee-cassandra uninstall
apigee-service apigee-zookeeper uninstall
ลบการเชื่อมโยงออกจาก dc-1
หากต้องการลบการเชื่อมโยงออกจาก dc-1 ให้ทำตามขั้นตอนต่อไปนี้
- ลบการเชื่อมโยงออกจาก dc-1
- แสดงรายการพ็อดทั้งหมดที่พร้อมใช้งานภายใต้องค์กร
curl -v -u <AdminEmailID>:'<AdminPassword>' -X GET "http://MS_IP:8080/v1/o/ORG/pods"
- หากต้องการตรวจสอบว่าได้นำการเชื่อมโยงทั้งหมดออกแล้ว ให้รับ UUID ของเซิร์ฟเวอร์ที่เชื่อมโยงกับพ็อด
curl -v -u <AdminEmailID>:'<AdminPassword>' \ -X GET "http://MS_IP:8080/v1/regions/dc-1/pods/gateway-1/servers"
หากคำสั่งนี้ไม่แสดง UUID ใดๆ แสดงว่าขั้นตอนก่อนหน้าได้นำการเชื่อมโยงทั้งหมดออกแล้ว และคุณสามารถข้ามขั้นตอนถัดไปได้ ไม่เช่นนั้น ให้ทำตามขั้นตอนถัดไป
- นำการเชื่อมโยงเซิร์ฟเวอร์ทั้งหมดสำหรับ UUID ที่ได้รับในขั้นตอนก่อนหน้าออก
curl -u <AdminEmailID>:'<AdminPassword>' -X DELETE http://MS_IP:8080/v1/servers/UUID
- ยกเลิกการเชื่อมโยงองค์กรกับพ็อด
curl -v -u <AdminEmailID>:'<AdminPassword>' "http://MS_IP:8080/v1/o/ORG/pods" -d "action=remove®ion=dc-1&pod=gateway-1" -H "Content-Type: application/x-www-form-urlencoded" -X POST
- แสดงรายการพ็อดทั้งหมดที่พร้อมใช้งานภายใต้องค์กร
- ลบพ็อด
curl -v -u <AdminEmailID>:'<AdminPassword>' "http://MS_IP:8080/v1/regions/dc-1/pods/gateway-1" -X DELETE
- ลบภูมิภาค
curl -v -u <AdminEmailID>:'<AdminPassword>' "http://MS_IP:8080/v1/regions/dc-1" -X DELETE
ตอนนี้คุณได้เลิกใช้งาน dc-1 เรียบร้อยแล้ว
ภาคผนวก
การแก้ปัญหา
หากหลังจากทำตามขั้นตอนก่อนหน้าแล้ว ยังมีเซิร์ฟเวอร์ในพ็อดบางรายการ ให้ทำตามขั้นตอนต่อไปนี้ เพื่อยกเลิกการลงทะเบียนและลบเซิร์ฟเวอร์ หมายเหตุ: เปลี่ยนประเภทและพ็อดตามที่จำเป็น
- รับ UUID โดยใช้คำสั่งต่อไปนี้
apigee-adminapi.sh servers list -r dc-1 -p POD -t --admin <AdminEmailID> --pwd '<AdminPassword>’ --host localhost
- วิธียกเลิกการลงทะเบียนประเภทเซิร์ฟเวอร์
curl -u <AdminEmailID>:'<AdminPassword>' -X POST http://MP_IP:8080/v1/servers -d "type=TYPE=REGION=dc-1&pod=POD&uuid=UUID&action=remove"
- ลบเซิร์ฟเวอร์ทีละรายการโดยทำดังนี้
curl -u <AdminEmailID>:'<AdminPassword>' -X DELETE http://MP_IP:8080/v1/servers/UUID
การตรวจสอบความถูกต้อง
คุณตรวจสอบความถูกต้องของการเลิกใช้งานได้โดยใช้คำสั่งต่อไปนี้
เซิร์ฟเวอร์การจัดการ
- เรียกใช้คำสั่งต่อไปนี้จากเซิร์ฟเวอร์การจัดการในทุกภูมิภาค
curl -v -u <AdminEmailID>:'<AdminPassword>' http://MS_IP:8080/v1/servers?pod=central®ion=dc-1
curl -v -u <AdminEmailID>:'<AdminPassword>' http://MS_IP:8080/v1/servers?pod=gateway®ion=dc-1
curl -v -u <AdminEmailID>:'<AdminPassword>' http://MS_IP:8080/v1/servers?pod=analytics®ion=dc-1
- เรียกใช้คำสั่งต่อไปนี้ในคอมโพเนนต์ทั้งหมดเพื่อตรวจสอบข้อกำหนดของพอร์ตสำหรับการจัดการทั้งหมด
curl -v http://MS_IP:8080/v1/servers/self
- ตรวจสอบกลุ่มข้อมูลวิเคราะห์
curl -v -u <AdminEmailID>:'<AdminPassword>' http://MS_IP:8080/v1/o/ORG/e/ENV/provisioning/axstatus
curl -v -u <AdminEmailID>:'<AdminPassword>' http://MS_IP:8080/v1/analytics/groups/ax
-
ในโหนด Cassandra ทั้งหมด ให้ป้อนข้อมูลต่อไปนี้
/opt/apigee/apigee-cassandra/bin/nodetool -h <host> statusthrift
ซึ่งจะแสดงสถานะ
running
หรือnot running
สำหรับโหนดนั้นๆ -
ในโหนดหนึ่ง ให้ป้อน
/opt/apigee/apigee-cassandra/bin/nodetool -h <host> ring
/opt/apigee/apigee-cassandra/bin/nodetool -h <host> status
คำสั่งข้างต้นจะแสดงข้อมูลศูนย์ข้อมูลที่ใช้งานอยู่
-
ในโหนด ZooKeeper ให้ป้อนคำสั่งต่อไปนี้ก่อน
echo ruok | nc <host> 2181
คำสั่งนี้จะแสดงผล
imok
จากนั้นป้อนข้อมูลต่อไปนี้
echo stat | nc <host> 2181 | grep Mode
ค่าของ
Mode
ที่คำสั่งด้านบนแสดงผลจะเป็นค่าใดค่าหนึ่งต่อไปนี้observer
,leader
หรือfollower
-
ในโหนด ZooKeeper ให้เรียกใช้คำสั่งต่อไปนี้
/opt/apigee/apigee-zookeeper/contrib/zk-tree.sh >> /tmp/zk-tree.out.txt
-
ในโหนดหลักของ Postgres ให้เรียกใช้คำสั่งต่อไปนี้
/opt/apigee/apigee-service/bin/apigee-service apigee-postgresql postgres-check-master
ตรวจสอบว่าการตอบกลับระบุว่าโหนดเป็นโหนดหลัก
-
ในโหนดสแตนด์บาย ให้เรียกใช้คำสั่งต่อไปนี้
/opt/apigee/apigee-service/bin/apigee-service apigee-postgresql postgres-check-standby
ตรวจสอบว่าการตอบกลับยืนยันว่าโหนดเป็นโหนดสแตนด์บาย
-
เข้าสู่ระบบฐานข้อมูล PostgreSQL โดยใช้คำสั่งต่อไปนี้
psql -h localhost -d apigee -U postgres
เมื่อได้รับข้อความแจ้ง ให้ป้อนรหัสผ่านสำหรับผู้ใช้
postgres
(ค่าเริ่มต้น:postgres
)จากนั้นเรียกใช้การค้นหาต่อไปนี้เพื่อตรวจสอบ
client_received_start_timestamp
สูงสุดSELECT max(client_received_start_timestamp) FROM "analytics"."$org.$env.fact" LIMIT 1;
โหนด Cassandra/ZooKeeper
บันทึก
ตรวจสอบบันทึกในคอมโพเนนต์เพื่อให้แน่ใจว่าไม่มีข้อผิดพลาด
- ในมาสเตอร์ใหม่ ให้แก้ไขไฟล์การกำหนดค่า
เพื่อตั้งค่าต่อไปนี้