การย้ายคอมโพเนนต์จากเครื่องหนึ่งไปยังอีกเครื่องหนึ่งอาจทำให้เกิดการกำหนดค่าไม่ตรงกันหากคุณไม่ได้ซิงค์ที่อยู่ IP ในไฟล์การกำหนดค่าคอมโพเนนต์
ส่วนนี้จะอธิบายวิธีวินิจฉัยและแก้ไขการกำหนดค่าที่ไม่ตรงกัน
ที่อยู่ IP กับชื่อโฮสต์
คุณควรใช้ที่อยู่ IP แทนชื่อโฮสต์ในไฟล์การกำหนดค่าคอมโพเนนต์
แม้ว่าไฟล์การกำหนดค่าคอมโพเนนต์บางไฟล์จะอนุญาตให้คุณใช้ชื่อโฮสต์แทนที่อยู่ IP ได้ แต่การใช้ชื่อโฮสต์อาจทำให้การแก้ปัญหาซับซ้อนขึ้น เช่น ชื่อโฮสต์ อาจเป็นแหล่งที่มาของปัญหาที่เกี่ยวข้องกับการเชื่อมต่อเซิร์ฟเวอร์ DNS, การค้นหาที่ไม่สำเร็จ และ การซิงค์
ด้วยเหตุนี้ Apigee จึงขอแนะนำอย่างยิ่งให้ใช้ที่อยู่ IP สำหรับการกำหนดค่าคอมโพเนนต์ทั้งหมด ในบางกรณี เช่น Cassandra คุณต้องใช้ที่อยู่ IP และใช้ชื่อโฮสต์ไม่ได้ ตัวอย่างส่วนใหญ่ในเอกสารประกอบใช้ที่อยู่ IP สำหรับการกำหนดค่าคอมโพเนนต์
สำหรับชื่อโฮสต์และที่อยู่ IP โปรดพิจารณาผลกระทบของสถานการณ์ต่อไปนี้ เมื่อย้ายเซิร์ฟเวอร์ Apigee
สถานการณ์ | ผลกระทบต่อการย้ายเซิร์ฟเวอร์ |
---|---|
การเปลี่ยนแปลงที่อยู่ IP | อัปเดตไฟล์ที่เกี่ยวข้องทั้งหมดซึ่งอ้างอิงถึงที่อยู่ IP เดิม |
การเปลี่ยนชื่อโฮสต์โดยไม่มีการเปลี่ยนแปลงที่อยู่ IP | ไม่ได้ส่งผลอะไร |
การเปลี่ยนชื่อโฮสต์เมื่อมีการเปลี่ยนแปลงที่อยู่ IP | เหมือนกับการเปลี่ยนแปลงที่อยู่ IP |
การเปลี่ยนที่อยู่ IP ของโหนด Cassandra
หากต้องการเปลี่ยนที่อยู่ IP ของโหนด Cassandra ให้ทำตามขั้นตอนต่อไปนี้
สำหรับ การกำหนดค่าที่มีโหนด Cassandra เดียว
- แก้ไข
/opt/apigee/customer/application/cassandra.properties
ในระบบที่กำลังแก้ไข หากไม่มีไฟล์ ให้สร้างไฟล์ - เปลี่ยนพารามิเตอร์ต่อไปนี้
- ตั้งค่าพารามิเตอร์
conf_cassandra_seeds
และconf_cassandra_listen_address
เพื่อระบุที่อยู่ IP ใหม่ของระบบ - เปลี่ยน
conf_cassandra_rpc_address
เพื่อใช้ ที่อยู่ IP ใหม่หรือ 0.0.0.0 (ซึ่งอนุญาตให้ Cassandra Thrift รับฟังในอินเทอร์เฟซทั้งหมด)
- ตั้งค่าพารามิเตอร์
- เปิด
/opt/apigee/apigee-cassandra/conf/cassandra-topology.properties
ในเครื่องมือแก้ไข คุณควรเห็นที่อยู่ IP เดิมและการตั้งค่าเริ่มต้นในแบบฟอร์ม192.168.56.101=dc-1:ra-1 default=dc-1:ra-1
บันทึกข้อมูลดังกล่าว
- แก้ไข
/opt/apigee/customer/application/cassandra.properties
เพื่อเปลี่ยนที่อยู่ IP เก่าที่ระบุเป็นที่อยู่ IP ใหม่ ดังนี้conf_cassandra-topology_topology=192.168.56.103=dc-1:ra-1\ndefault=dc-1:ra-1\n
ตรวจสอบว่าคุณได้แทรก "\n" หลังที่อยู่ IP และระบุการตั้งค่าเริ่มต้นเดียวกันกับที่คุณพบ ด้านบนในขั้นตอนที่ 3
- รีสตาร์ท Cassandra
/opt/apigee/apigee-service/bin/apigee-service apigee-cassandra restart
- หากจำเป็น ให้ซ่อมแซม ZooKeeper ด้วย (ดูการเปลี่ยนที่อยู่ IP ของโหนด ZooKeeper) หรือรีสตาร์ทคอมโพเนนต์แพลตฟอร์ม Apigee ทุกรายการ โดยเริ่มจาก Management Server
สำหรับการกำหนดค่าที่มีโหนด Cassandra หลายรายการ (วงแหวน)
- หากโหนดที่กำลังเปลี่ยนแปลงเป็นโหนดเริ่มต้น ให้แก้ไขไฟล์
/opt/apigee/customer/application/cassandra.properties
ในแต่ละระบบในวงแหวน และเปลี่ยนพารามิเตอร์conf_cassandra_seeds
ให้มี IP ใหม่ของระบบที่แก้ไข หากไม่มีไฟล์ cassandra.properties ให้สร้างไฟล์ ดังกล่าว - แก้ไข
/opt/apigee/customer/application/cassandra.properties
ในระบบที่จะแก้ไข แล้วเปลี่ยนพารามิเตอร์ต่อไปนี้- ตั้งค่า
conf_cassandra_listen_address
ให้ใช้ที่อยู่ IP ใหม่ - ตั้งค่า
conf_cassandra_rpc_address
ให้ใช้ที่อยู่ IP ใหม่หรือ "0.0.0.0" (ซึ่งอนุญาตให้ Cassandra Thrift รับฟังในอินเทอร์เฟซทั้งหมด)
- ตั้งค่า
- เปิด
/opt/apigee/apigee-cassandra/conf/cassandra-topology.properties
ในเครื่องมือแก้ไข คุณควรเห็นที่อยู่ IP ของ Cassandra ทั้งหมดและการตั้งค่าเริ่มต้นในแบบฟอร์มต่อไปนี้192.168.56.101=dc-1:ra-1 192.168.56.102=dc-1:ra-1 192.168.56.103=dc-1:ra-1 default=dc-1:ra-1
บันทึกข้อมูลดังกล่าว
- แก้ไข
/opt/apigee/customer/application/cassandra.properties
เพื่อเปลี่ยนที่อยู่ IP เก่าที่ระบุเป็นที่อยู่ IP ใหม่ ดังนี้conf_cassandra-topology_topology=192.168.56.101=dc-1:ra-1\n192.168.56.102=dc-1:ra-1\n192.168.56.104=dc-1:ra-1\ndefault=dc-1:ra-1\n
ตรวจสอบว่าคุณได้แทรก "\n" หลังที่อยู่ IP แต่ละรายการ และใช้การตั้งค่าเริ่มต้นเดียวกันกับที่คุณ บันทึกไว้ข้างต้นในขั้นตอนที่ 3
- รีสตาร์ท Cassandra ในระบบที่แก้ไขแล้ว
/opt/apigee/apigee-service/bin/apigee-service apigee-cassandra restart
- สำหรับโหนดอื่นๆ ทั้งหมด ให้ทำซ้ำการเปลี่ยนแปลงที่ทำในขั้นตอนที่ 3 และ 4 เพื่อแจ้งให้ทราบเกี่ยวกับตำแหน่งของโหนดนี้ในวงแหวน Cassandra นอกจากนี้ ให้เปลี่ยน IP ของโหนดเริ่มต้นตามที่อธิบายไว้ในขั้นตอนที่ 1
- รีสตาร์ทโหนด Cassandra ที่เหลือทีละโหนด
/opt/apigee/apigee-service/bin/apigee-service apigee-cassandra restart
- เรียกใช้คำสั่ง
nodetool ring
ในโหนดที่แก้ไขเพื่อให้แน่ใจว่าวงแหวนเสร็จสมบูรณ์ คุณสามารถดูยูทิลิตีได้ที่/opt/apigee/apigee-cassandra/bin
nodetool [-u username -pw password] -h localhost ring
- เรียกใช้
nodetool repair
ในโหนดที่แก้ไข โปรดทราบว่ากระบวนการนี้อาจใช้เวลาสักครู่ ดังนั้นเราขอแนะนำอย่างยิ่งว่าอย่าดำเนินการในช่วงเวลาที่มีการเข้าชม API สูงสุดnodetool [-u username -pw password] -h localhost repair -pr
- หากจำเป็น ให้ซ่อมแซม ZooKeeper (ดูการเปลี่ยนที่อยู่ IP ของโหนด ZooKeeper) จากนั้นรีสตาร์ทคอมโพเนนต์แพลตฟอร์ม Apigee ทุกรายการ โดยเริ่มจากเซิร์ฟเวอร์การจัดการ
อัปเดตการลงทะเบียน ที่เก็บข้อมูล
- ค้นหา UUID ของการลงทะเบียนพื้นที่เก็บข้อมูลที่ระบุที่อยู่ IP เก่าโดยใช้คำสั่งด้านล่าง
จดพารามิเตอร์ "type" และ "UUID" ไว้
-
curl -u ADMINEMAIL:PW "http://$MSIP:$port/v1/servers?pod=central®ion=DC" | egrep -i '[type|internalip|uuid|region]'
-
curl -u ADMINEMAIL:PW "http://$MSIP:$port/v1/servers?pod=gateway®ion=DC" | egrep -i '[type|internalip|uuid|region]'
-
curl -u ADMINEMAIL:PW "http://$MSIP:$port/v1/servers?pod=analytics®ion=DC" | egrep -i '[type|internalip|uuid|region]'
โดย DC คือชื่อศูนย์ข้อมูล ในการติดตั้งศูนย์ข้อมูลเดียว ค่า มักจะเป็น "dc-1"
-
- ลงทะเบียนที่อยู่ IP ใหม่โดยใช้คำสั่งใดคำสั่งหนึ่งด้านล่าง คำสั่งที่จำเป็นจะ
ขึ้นอยู่กับประเภทของโหนดที่เปลี่ยนแปลง
- สำหรับ type="application-datastore"
curl -u ADMINEMAIL:PW "http://MSIP:port/v1/servers -d \ "Type=application-datastore&Type=audit-datastore&InternalIP=NEWIP®ion=REGION&pod=central" \ -H 'content-type: application/x-www-form-urlencoded' -X POST
- สำหรับ type="kms-datastore"
curl -u ADMINEMAIL:PW "http://MSIP:port/v1/servers -d \ "Type=kms-datastore&Type=dc-datastore&Type=keyvaluemap-datastore&Type=counter-datastore&Type=cache-datastore \ &InternalIP=NEWIP®ion=REGION&pod=GATEWAY_POD" -H 'content-type: \ application/x-www-form-urlencoded' -X POST
- สำหรับ type="reportcrud-datastore" ให้ทำดังนี้
curl -u ADMINEMAIL:PW "http://MSIP:port/v1/servers" -d \ "Type=reportcrud-datastore&InternalIP=NEW_IP®ion=REGION&pod=analytics" \ -H 'content-type: application/x-www-form-urlencoded' -X POST
- สำหรับ type="application-datastore"
- ลบการลงทะเบียนเก่าสำหรับ UUID ของระบบที่มีการเปลี่ยนแปลงที่อยู่ IP
สำหรับปัญหา UUID แต่ละรายการ ให้ทำดังนี้
curl -u ADMINEMAIL:PW "http://MSIP:port/v1/servers/OLD_UUID" -X DELETE
การเปลี่ยนที่อยู่ IP ของโหนด ZooKeeper
ทำตามขั้นตอนด้านล่างเพื่อเปลี่ยนที่อยู่ IP ของโหนด ZooKeeper
เปลี่ยนที่อยู่ IP และรีสตาร์ทกลุ่ม ZooKeeper (สำหรับการกำหนดค่ากลุ่มแบบหลายโหนดเท่านั้น)
- เปิด
/opt/apigee/apigee-zookeeper/conf/zoo.cfg
ในเครื่องมือแก้ไข คุณควรเห็น ที่อยู่ IP ของ ZooKeeper ทั้งหมดและการตั้งค่าเริ่มต้นในรูปแบบต่อไปนี้server.1=192.168.56.101:2888:3888 server.2=192.168.56.102:2888:3888 server.3=192.168.56.103:2888:3888
บันทึกข้อมูลดังกล่าว
- ในแต่ละโหนด ZooKeeper ให้แก้ไขไฟล์
/opt/apigee/customer/application/zookeeper.properties
เพื่อตั้งค่าพร็อพเพอร์ตี้conf_zoo_quorum
เป็นที่อยู่ IP ที่ถูกต้อง หากไม่มีไฟล์ ให้สร้างไฟล์conf_zoo_quorum=server.1=192.168.56.101:2888:3888\nserver.2=192.168.56.102:2888:3888\nserver.3=192.168.56.104:2888:3888\n
ตรวจสอบว่าคุณได้แทรก "\n" หลังที่อยู่ IP แต่ละรายการ และรายการต่างๆ อยู่ในลำดับเดียวกันใน ทุกโหนด
- ค้นหาหัวหน้าของกลุ่ม ZooKeeper โดยใช้คำสั่งต่อไปนี้ (แทนที่
node ด้วยที่อยู่ IP ของเครื่อง Zookeeper)
echo srvr | nc node 2181
บรรทัด Mode ในเอาต์พุตควรระบุว่า "leader"
- รีสตาร์ท ZooKeeper ทีละรายการโดยเริ่มจากลีดเดอร์และจบด้วยโหนดที่เปลี่ยนที่อยู่ IP หากโหนด Zookeeper มากกว่า 1 รายการเปลี่ยนที่อยู่ IP คุณอาจต้องรีสตาร์ทโหนดทั้งหมด
/opt/apigee/apigee-service/bin/apigee-service apigee-zookeeper restart
- ใช้คำสั่ง
echo
ที่อธิบายไว้ข้างต้นเพื่อยืนยันแต่ละโหนด ZooKeeper
แจ้งโหนด Apigee เกี่ยวกับการกำหนดค่าที่เปลี่ยนแปลง
- ในโหนดเราเตอร์แต่ละโหนด ให้แก้ไขไฟล์
/opt/apigee/customer/application/router.properties
ดังนี้ หากไม่มีไฟล์ ให้สร้างไฟล์- เปลี่ยนพารามิเตอร์
conf_zookeeper_connection.string
ให้รวมที่อยู่ IP ใหม่ - เปลี่ยนพารามิเตอร์
conf_zookeeper_zk1.host
ให้รวมที่อยู่ IP ใหม่
- เปลี่ยนพารามิเตอร์
- ในโหนด Message Processor ทุกโหนด ให้แก้ไขไฟล์
/opt/apigee/customer/application/message-processor.properties
ดังนี้ หากไม่มีไฟล์ ให้สร้างไฟล์- เปลี่ยนพารามิเตอร์
conf_zookeeper_connection.string
ให้มีที่อยู่ IP ใหม่ - เปลี่ยนพารามิเตอร์
conf_zookeeper_zk1.host
ให้รวมที่อยู่ IP ใหม่
- เปลี่ยนพารามิเตอร์
- ในโหนดเซิร์ฟเวอร์การจัดการ ให้แก้ไขไฟล์
/opt/apigee/customer/application/management-server.properties
ดังนี้ หากไม่มีไฟล์ ให้สร้างไฟล์- เปลี่ยนพารามิเตอร์
conf_zookeeper_connection.string
ให้มีที่อยู่ IP ใหม่ - เปลี่ยนพารามิเตอร์
conf_zookeeper_zk1.host
ให้รวมที่อยู่ IP ใหม่
- เปลี่ยนพารามิเตอร์
- รีสตาร์ทคอมโพเนนต์แพลตฟอร์ม Apigee ทั้งหมดโดยเรียกใช้คำสั่งต่อไปนี้ในแต่ละโหนด
/opt/apigee/apigee-service/bin/apigee-all restart
การเปลี่ยนที่อยู่ IP ของเซิร์ฟเวอร์ LDAP (SymasLDAP)
หากต้องการเปลี่ยนที่อยู่ IP ของโหนด SymasLDAP ให้ทำดังนี้
- ในโหนดเซิร์ฟเวอร์การจัดการ ให้แก้ไขไฟล์
/opt/apigee/customer/application/management-server.properties
file หากไม่มีไฟล์ ให้สร้างไฟล์ - ในไฟล์
management-server.properties
ให้ตั้งค่าพารามิเตอร์conf_security_ldap.server.host
เป็นที่อยู่ IP ใหม่ - รีสตาร์ทเซิร์ฟเวอร์การจัดการโดยทำดังนี้
/opt/apigee/apigee-service/bin/apigee-service edge-management-server restart
การเปลี่ยนที่อยู่ IP ของโหนด Apigee ประเภทอื่นๆ
หากต้องการเปลี่ยนที่อยู่ IP ของโหนดประเภทใดประเภทหนึ่ง (เราเตอร์, Message Processor, เซิร์ฟเวอร์ Postgres (ไม่ใช่ postgresql) และเซิร์ฟเวอร์ Qpid (ไม่ใช่ qpidd) ให้ทำดังนี้
- ใช้คำสั่ง
curl
ต่อไปนี้เพื่อลงทะเบียนที่อยู่ IP ภายในและภายนอกใหม่curl -u ADMINEMAIL:PW -X PUT \ http://MSIP:8080/v1/servers/uuid -d ExternalIP=ip
curl -u ADMINEMAIL:PW -X PUT \ http://$MSIP:8080/v1/servers/uuid -d InternalIP=ip
โดยที่ uuid คือ UUID ของโหนด
ดูข้อมูลเกี่ยวกับวิธีรับ UUID ของคอมโพเนนต์ได้ที่หัวข้อรับ UUID