कभी-कभी, आपको किसी डेटा सेंटर को बंद करना पड़ सकता है. उदाहरण के लिए, अगर ऑपरेटिंग सिस्टम को अपग्रेड किया जा रहा है, तो आपको नए डेटा सेंटर में नया ऑपरेटिंग सिस्टम इंस्टॉल करना होगा. इसके बाद, पुराने डेटा सेंटर को बंद करना होगा. नीचे दिए गए सेक्शन में, किसी डेटा सेंटर को बंद करने का उदाहरण दिया गया है. इसमें 12-नोड वाले क्लस्टर किए गए इंस्टॉलेशन पर, दो डेटा सेंटर, dc-1 और dc-2 हैं:
- dc-1 वह डेटा सेंटर है जिसे बंद किया जाना है.
- dc-2 दूसरा डेटा सेंटर है, जिसका इस्तेमाल डिसकमिशन की प्रोसेस में किया जाता है.
अगर आपने ऑपरेटिंग सिस्टम को अपग्रेड किया है, तो dc-2 वह डेटा सेंटर हो सकता है जिसमें आपने ऑपरेटिंग सिस्टम (ओएस) का नया वर्शन इंस्टॉल किया है. हालांकि, डेटा सेंटर को बंद करने के लिए, नया ओएस इंस्टॉल करना ज़रूरी नहीं है.
डेटा सेंटर को बंद करने से पहले ध्यान रखने वाली बातें
डेटा सेंटर को बंद करते समय, इन बातों का ध्यान रखें:
- बंद किए जा रहे डेटा सेंटर पर रनटाइम और मैनेजमेंट ट्रैफ़िक को ब्लॉक करें और उसे दूसरे डेटा सेंटर पर रीडायरेक्ट करें.
- डेटा सेंटर बंद करने के बाद, आपके Apigee क्लस्टर में कम क्षमता होगी. इस कमी को पूरा करने के लिए, बाकी बचे डेटा सेंटर की क्षमता बढ़ाएं या बंद किए गए डेटा सेंटर के बाद, नए डेटा सेंटर जोड़ें.
- डेटा सेंटर को बंद करने की प्रोसेस के दौरान, Analytics का डेटा मिट सकता है. यह इस बात पर निर्भर करता है कि डेटा सेंटर में कौनसे Analytics कॉम्पोनेंट इंस्टॉल किए गए हैं. ज़्यादा जानकारी के लिए, Qpid नोड जोड़ना या हटाना लेख पढ़ें.
- किसी डेटा सेंटर को बंद करने से पहले, आपको यह समझना चाहिए कि सभी डेटा सेंटर में सभी कॉम्पोनेंट कैसे कॉन्फ़िगर किए गए हैं. खास तौर पर, OpenLDAP, ZooKeeper, Cassandra, और Postgres सर्वर. आपको सभी कॉम्पोनेंट और उनके कॉन्फ़िगरेशन का बैकअप भी लेना चाहिए.
शुरू करने से पहले
- मैनेजमेंट सर्वर: डिसकमिशन के सभी चरण, मैनेजमेंट सर्वर पर बहुत ज़्यादा निर्भर करते हैं. अगर आपके पास सिर्फ़ एक मैनेजमेंट सर्वर उपलब्ध है, तो हमारा सुझाव है कि dc-1 पर मौजूद मैनेजमेंट सर्वर को बंद करने से पहले, dc-1 के अलावा किसी दूसरे डेटा सेंटर पर नया मैनेजमेंट सर्वर कॉम्पोनेंट इंस्टॉल करें. साथ ही, पक्का करें कि कोई एक मैनेजमेंट सर्वर हमेशा उपलब्ध रहे.
- राऊटर: किसी राऊटर को बंद करने से पहले, पोर्ट 15999 को ब्लॉक करके, राऊटर को ऐक्सेस करने की सुविधा बंद कर दें. पक्का करें कि बंद किए जा रहे राऊटर पर कोई रनटाइम ट्रैफ़िक न भेजा जा रहा हो.
- Cassandra और ZooKeeper:
नीचे दिए गए सेक्शन में, दो डेटा सेंटर के सेटअप में dc-1 को बंद करने का तरीका बताया गया है.
अगर आपके पास दो से ज़्यादा डेटा सेंटर हैं, तो बाकी सभी डेटा सेंटर की सभी साइलेंट कॉन्फ़िगरेशन फ़ाइलों से, बंद किए जा रहे नोड (इस मामले में dc-1) के सभी रेफ़रंस हटाना न भूलें. जिन Cassandra नोड को बंद करना है उनके लिए, उन होस्ट को
CASS_HOSTS
से हटाएं. बाकी Cassandra नोड,CASS_HOSTS
के ओरिजनल क्रम में ही बने रहेंगे. - Postgres: अगर Postgres के मुख्य नोड को हटाया जाता है, तो उपलब्ध स्टैंडबाय नोड में से किसी एक को नए Postgres के मुख्य नोड के तौर पर प्रमोट करना न भूलें. QPID सर्वर, सूची में बफ़र रखता है. हालांकि, अगर Postgres मास्टर लंबे समय तक उपलब्ध नहीं है, तो आपको आंकड़ों का डेटा खोने का खतरा हो सकता है.
ज़रूरी शर्तें
हमारा सुझाव है कि किसी भी कॉम्पोनेंट को बंद करने से पहले, सभी नोड का बैक अप लें. बैकअप लेने के लिए, Edge के मौजूदा वर्शन के लिए बताए गए तरीके का इस्तेमाल करें. बैकअप लेने के बारे में ज़्यादा जानने के लिए, बैकअप लेना और रीस्टोर करना लेख पढ़ें.
- यह पक्का करें कि Edge बंद करने से पहले, वह चालू हो. इसके लिए, यह कमांड इस्तेमाल करें:
/opt/apigee/apigee-service/bin/apigee-all status
- पक्का करें कि जिस डेटा सेंटर को बंद किया जा रहा है उस पर फ़िलहाल कोई रनटाइम ट्रैफ़िक न आ रहा हो.
कॉम्पोनेंट को बंद करने का क्रम
अगर आपने कई नोड पर Edge for Private Cloud इंस्टॉल किया है, तो आपको उन नोड पर Edge कॉम्पोनेंट को इस क्रम में बंद करना चाहिए:
- Edge का यूज़र इंटरफ़ेस (edge-ui)
- मैनेजमेंट सर्वर (edge-management-server)
- OpenLDAP (apigee-openldap)
- राऊटर (एज-राऊटर)
- मैसेज प्रोसेसर (edge-message-processor)
- Qpid सर्वर और Qpidd (edge-qpid-server और apigee-qpidd)
- Postgres और PostgreSQL डेटाबेस (edge-postgres-server और apigee-postgresql)
- ZooKeeper (apigee-zookeeper)
- Cassandra (apigee-cassandra)
नीचे दिए गए सेक्शन में, हर कॉम्पोनेंट को बंद करने का तरीका बताया गया है.
Edge का यूज़र इंटरफ़ेस (यूआई)
dc-1 के Edge यूज़र इंटरफ़ेस (यूआई) कॉम्पोनेंट को रोकने और अनइंस्टॉल करने के लिए, ये कमांड डालें:
/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
- 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"
- सर्वर मिटाएं. ध्यान दें: अगर इस सर्वर पर अन्य कॉम्पोनेंट भी इंस्टॉल हैं, तो यूनीक आइडेंटिटी (यूयूआईडी) मिटाने से पहले, उन सभी को डीरजिस्टर करें.
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
Open LDAP
इस सेक्शन में, dc-1 पर OpenLDAP को बंद करने का तरीका बताया गया है.
ध्यान दें: अगर आपके पास दो से ज़्यादा डेटा सेंटर हैं, तो नीचे दो से ज़्यादा डेटा सेंटर वाले सेटअप देखें.
dc-1 पर OpenLDAP को बंद करने के लिए, यह तरीका अपनाएं:
- बैक अप कैसे लें में दिया गया तरीका अपनाकर, dc-1 OpenLDAP नोड का बैक अप लें.
दोनों डेटा सेंटर, dc-1 और dc-2 के बीच डेटा डुप्लीकेट होने की प्रोसेस को रोकने के लिए, दोनों डेटा सेंटर में यह तरीका अपनाएं.
- मौजूदा स्थिति देखें:
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}bdb,cn=config changetype: modify delete: olcSyncRepl dn: olcDatabase={2}bdb,cn=config changetype: modify delete: olcMirrorMode
ldapmodify
कमांड चलाएं:ldapmodify -x -w {credentials} -D "cn=admin,cn=config" -H "ldap://{HOST}:{PORT}/" -f path/to/file/break_repl.ldif
आउटपुट कुछ ऐसा दिखना चाहिए:
modifying entry "olcDatabase={2}bdb,cn=config" modifying entry "olcDatabase={2}bdb,cn=config"
- मौजूदा स्थिति देखें:
dc-2 एलडीपी में एंट्री बनाकर और यह पक्का करके पुष्टि की जा सकती है कि dc-2 अब dc-1 में डुप्लीकेट कॉपी नहीं बना रहा है कि वह dc-1 के एलडीपी में नहीं दिख रही है.
इसके अलावा, नीचे दिया गया तरीका भी अपनाया जा सकता है. इससे dc-2 OpenLDAP नोड में, सिर्फ़ पढ़ने का ऐक्सेस वाला उपयोगकर्ता बनाया जा सकता है. इसके बाद, यह देखा जा सकता है कि उपयोगकर्ता को डुप्लीकेट किया गया है या नहीं. इसके बाद, उपयोगकर्ता को मिटा दिया जाता है.
- dc-2 में
readonly-user.ldif
फ़ाइल बनाएं और उसमें यह कॉन्टेंट डालें: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}
- dc-2 में `ldapadd` कमांड की मदद से उपयोगकर्ता जोड़ें:
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 में मौजूद नहीं है, तो आपको यह पक्का हो जाएगा कि दोनों एलडीपी अब डुप्लीकेट नहीं हो रहे हैं:
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
- पहले जोड़े गए, सिर्फ़ पढ़ने की अनुमति वाले उपयोगकर्ता को हटाएं:
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"
- dc-2 में
- dc-1 में OpenLDAP को बंद करने के लिए:
/opt/apigee/apigee-service/bin/apigee-service apigee-openldap stop
- dc-1 पर OpenLDAP कॉम्पोनेंट को अनइंस्टॉल करें:
/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
- यूयूआईडी पाना में बताए गए तरीके से, राऊटर का यूयूआईडी पाएं.
- राऊटर को बंद करें:
/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
- ब्लॉक किए गए पोर्ट 15999 को चालू करने के लिए,
iptables
नियमों को फ़्लश करें:iptables -F
मैसेज प्रोसेसर
इस सेक्शन में, dc-1 से मैसेज प्रोसेसर को हटाने का तरीका बताया गया है. मैसेज प्रोसेसर को हटाने के बारे में ज़्यादा जानकारी के लिए, सर्वर हटाना लेख पढ़ें.
हम मान रहे हैं कि dc-1 में 12 नोड वाला क्लस्टर इंस्टॉलेशन है. इसलिए, dc-1 में दो मैसेज प्रोसेसर नोड कॉन्फ़िगर किए गए हैं. दोनों नोड में, नीचे दिए गए निर्देशों को पूरा करें.
- मैसेज प्रोसेसर के यूयूआईडी पाएं. इसके लिए, यूयूआईडी पाना लेख पढ़ें.
- मैसेज प्रोसेसर को बंद करना:
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"
- किसी एनवायरमेंट को मैसेज प्रोसेसर से अलग करना.
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
) को बंद करने का तरीका बताया गया है. dc-1 में दो Qpid नोड कॉन्फ़िगर किए गए हैं. इसलिए, आपको दोनों नोड के लिए ये चरण पूरे करने होंगे:
- यूयूआईडी पाना में बताए गए तरीके से, Qpidd के लिए यूयूआईडी पाएं.
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
- Analytics और उपभोक्ता ग्रुप की सूची पाएं:
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}"
- Analytics ग्रुप से 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"
- Edge इंस्टॉलेशन से Qpid सर्वर को अनरजिस्टर करें:
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"
- Edge इंस्टॉलेशन से Qpid सर्वर हटाएं:
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 के मुख्य नोड के तौर पर प्रमोट करना न भूलें. QPID, डेटा को बफ़र में डालता है. अगर Postgres का मास्टर लंबे समय तक उपलब्ध नहीं होता है, तो Analytics का डेटा मिटने का खतरा होता है.
Postgres मास्टर को बंद करने के लिए:
- नीचे दिए गए लिंक में दिए गए निर्देशों का पालन करके, dc-1 Postgres के मास्टर नोड का बैक अप लें:
- Postgres सर्वर के UUID पाएं. इसके लिए, 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 नोड हैं, तो आपको नए मास्टर पर होस्ट एंट्री जोड़नी होंगी और सभी उपलब्ध Postgres स्टैंडबाय नोड के लिए, डुप्लीकेट कॉपी बनाने की सेटिंग अपडेट करनी होगी.
नए Postgres मास्टर में होस्ट एंट्री जोड़ने के लिए: यहां दिए गए सही सेक्शन में दिया गया तरीका अपनाएं:
अगर सिर्फ़ एक स्टैंडबाय नोड बचा है
उदाहरण के लिए, मान लें कि डिसकमिशन से पहले, तीन Postgres नोड कॉन्फ़िगर किए गए थे. आपने मौजूदा मास्टर को बंद कर दिया है और बाकी बचे 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
अगर एक से ज़्यादा स्टैंडबाय नोड बचे हैं
/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
फ़ील्ड को नए Postgres मास्टर के आईपी पते से अपडेट करें. - इस कमांड की मदद से, Postgres का पुराना डेटा हटाएं:
rm -rf /opt/apigee/data/apigee-postgresql/
- स्टैंडबाय नोड पर डुप्लीकेट कॉपी बनाने की सुविधा सेट अप करना:
/opt/apigee/apigee-service/bin/apigee-service apigee-postgresql setup-replication-on-standby -f configFile
- dc-2 में यह कमांड डालकर पुष्टि करें कि Postgres का मास्टर सही तरीके से सेट अप किया गया है:
/opt/apigee/apigee-service/bin/apigee-service apigee-postgresql postgres-check-master
- Analytics ग्रुप और कंज्यूमर ग्रुप से Postgresql सर्वर हटाएं और जोड़ें.
- किसी Analytics ग्रुप से Postgres सर्वर हटाने के निर्देशों का पालन करके, Analytics ग्रुप से पुराने Postgres सर्वर को हटाएं.
- किसी Analytics ग्रुप में मौजूदा Postgres सर्वर जोड़ें में दिए गए निर्देशों का पालन करके, Analytics ग्रुप में नया Postgres सर्वर जोड़ें.
- dc-1 से पुराने postgres सर्वर को रजिस्टर करने की सुविधा हटाएं:
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"
- dc-1 से पुराने postgres सर्वर को मिटाएं:
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 नोड वाले क्लस्टर वाले इंस्टॉलेशन के दस्तावेज़ में, dc-1 postgresql नोड को मास्टर के तौर पर दिखाया गया है. हालांकि, इस सेक्शन में यह माना गया है कि dc-1 postgresql नोड स्टैंडबाय है और dc-2 postgresql नोड मास्टर है.
Postgres स्टैंडबाय को बंद करने के लिए, यह तरीका अपनाएं:
- यूयूआईडी पाएं में दिए गए निर्देशों का पालन करके, Postgres सर्वर के यूयूआईडी पाएं.
- dc-1 में मौजूदा स्टैंडबाय नोड पर
apigee-postgresql
को बंद करना:/opt/apigee/apigee-service/bin/apigee-service edge-postgres-server stop
/opt/apigee/apigee-service/bin/apigee-service apigee-postgresql stop
- Analytics ग्रुप और कंज्यूमर ग्रुप से Postgresql सर्वर हटाएं और जोड़ें.
- किसी Analytics ग्रुप से Postgres सर्वर हटाने के निर्देशों का पालन करके, Analytics ग्रुप से पुराने Postgres सर्वर को हटाएं.
- किसी Analytics ग्रुप में मौजूदा Postgres सर्वर जोड़ें में दिए गए निर्देशों का पालन करके, Analytics ग्रुप में नया Postgres सर्वर जोड़ें.
- dc-1 से पुराने postgres सर्वर को रजिस्टर करने की सुविधा हटाएं:
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"
- dc-1 से पुराने postgres सर्वर को मिटाएं:
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 सर्वर को बंद करने का तरीका बताया गया है.
अगर आपके पास दो से ज़्यादा डेटा सेंटर हैं, तो बाकी सभी डेटा सेंटर की सभी साइलेंट कॉन्फ़िगरेशन फ़ाइलों से, बंद किए जा रहे नोड (इस मामले में dc-1) के सभी रेफ़रंस हटाना न भूलें. जिन Cassandra नोड को बंद करना है उनके लिए, उन होस्ट को
CASS_HOSTS
से हटाएं. बाकी Cassandra नोड,CASS_HOSTS
के ओरिजनल क्रम में ही बने रहेंगे.ZooKeeper के बारे में जानकारी: कॉन्फ़िगरेशन फ़ाइल में
ZK_HOST
प्रॉपर्टी में बदलाव करते समय, आपको वोटर नोड का कोरम बनाए रखना होगा. इससे यह पक्का किया जा सकेगा कि ZooKeeper का ग्रुप काम करता रहे. आपके कॉन्फ़िगरेशन में, वोटर नोड की संख्या विषम होनी चाहिए. ज़्यादा जानकारी के लिए, Apache ZooKeeper के रखरखाव से जुड़े टास्क देखें.ZooKeeper और Cassandra सर्वर को बंद करने के लिए:
- नीचे दिए गए लिंक में दिए गए निर्देशों का पालन करके, dc-1 Cassandra और ZooKeeper नोड का बैक अप लें:
उस डेटा सेंटर में मौजूद 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
- कॉन्फ़िगरेशन फ़ाइल को अपडेट करें. इसमें,
ZK_HOSTS
औरCASS_HOSTS
से हटाए गए, बंद किए गए नोड के आईपी शामिल करें.उदाहरण: मान लें कि आपके पास dc-1 में
$IP1 $IP2 $IP3
और dc-2 में$IP4 $IP5 $IP6
आईपी हैं और आपने dc-1 को बंद कर दिया है. इसके बाद, आपको कॉन्फ़िगरेशन फ़ाइलों से$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"
- कॉन्फ़िगरेशन फ़ाइल की मौजूदा एंट्री:
- हटाए गए और बंद किए गए नोड के आईपी के साथ, साइलेंट कॉन्फ़िगरेशन फ़ाइल (e चरण में बदली गई) को अपडेट करें और मैनेजमेंट सर्वर होस्ट करने वाले सभी नोड पर मैनेजमेंट सर्वर प्रोफ़ाइल चलाएं:
/opt/apigee/apigee-setup/bin/setup.sh -p ms -f updated_config_file
- कॉन्फ़िगरेशन फ़ाइल को हटाए गए नोड के आईपी के साथ अपडेट करें और सभी राउटर और मैसेज प्रोसेसर नोड पर एमपी/आरएमपी प्रोफ़ाइल चलाएं:
- अगर एज राउटर और मैसेज प्रोसेसर को एक ही नोड पर कॉन्फ़िगर किया गया है, तो यह डालें:
/opt/apigee/apigee-setup/bin/setup.sh -p rmp -f updated_config_file
अगर एज राउटर और मैसेज प्रोसेसर को अलग-अलग नोड पर कॉन्फ़िगर किया गया है, तो यह जानकारी डालें:
राऊटर के लिए:
/opt/apigee/apigee-setup/bin/setup.sh -p r -f updated_config_file
मैसेज प्रोसेसर के लिए:
/opt/apigee/apigee-setup/bin/setup.sh -p mp -f updated_config_file
- अगर एज राउटर और मैसेज प्रोसेसर को एक ही नोड पर कॉन्फ़िगर किया गया है, तो यह डालें:
- सभी Qpid नोड को फिर से कॉन्फ़िगर करें. इसके लिए, रिस्पॉन्स फ़ाइल से हटाए गए नोड के आईपी का इस्तेमाल करें:
/opt/apigee/apigee-setup/bin/setup.sh -p qs -f updated_config_file
- सभी Postgres नोड को फिर से कॉन्फ़िगर करें. इसके लिए, रिस्पॉन्स फ़ाइल से हटाए गए नोड के आईपी का इस्तेमाल करें:
/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'};
यह कमांड, क्लस्टर में तीन Cassandra नोड के बारे में बताते हुए, रिप्लिकेशन फ़ैक्टर को
'3'
पर सेट करता है. ज़रूरत के मुताबिक इस वैल्यू में बदलाव करें.यह चरण पूरा करने के बाद, Cassandra टोपोलॉजी के किसी भी कीस्पेस में
dc-1
नहीं होना चाहिए.- dc-1 पर, Cassandra नोड को एक-एक करके बंद करें.
Cassandra नोड को बंद करने के लिए, यह कमांड डालें:
/opt/apigee/apigee-cassandra/bin/nodetool -h cassIP -u cassandra -pw '<AdminPassword>' decommission
- dc-1 से Cassandra नोड के कनेक्शन की जांच करने के लिए, इनमें से किसी एक कमांड का इस्तेमाल करें:
/opt/apigee/apigee-cassandra/bin/cqlsh cassIP 9042 -u cassandra -p '<AdminPassword>'
इसके अलावा, बंद किए गए नोड पर पुष्टि करने के लिए, यह दूसरा निर्देश भी चलाया जा सकता है:
/opt/apigee/apigee-cassandra/bin/nodetool netstats
ऊपर दिए गए कमांड से यह जानकारी मिलनी चाहिए:
Mode: DECOMMISSIONED
- dc-2 में मौजूद सभी Cassandra और ZooKeeper नोड के लिए, डीएस प्रोफ़ाइल चलाएं:
/opt/apigee/apigee-setup/bin/setup.sh -p ds -f updated_config_file
- dc-1 में
apigee-cassandra
औरapigee-zookeeper
को रोकें:apigee-service apigee-cassandra stop
apigee-service apigee-zookeeper stop
- dc-1 में
apigee-cassandra
औरapigee-zookeeper
को अनइंस्टॉल करें: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"
- यह देखने के लिए कि सभी बाइंडिंग हटाई गई हैं या नहीं, पोड से जुड़े सर्वर के
यूयूआईडी पाएं:
curl -v -u <AdminEmailID>:'<AdminPassword>' \ -X GET "http://MS_IP:8080/v1/regions/dc-1/pods/gateway-1/servers"
अगर यह कमांड कोई यूयूआईडी नहीं दिखाता है, तो इसका मतलब है कि पिछले चरणों में सभी बाइंडिंग हटा दी गई हैं. ऐसे में, अगले चरण को छोड़ा जा सकता है. अगर ऐसा नहीं होता है, तो अगला चरण पूरा करें.
- पिछले चरण में मिले यूयूआईडी के लिए, सभी सर्वर बाइंडिंग हटाएं:
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 को बंद कर दिया गया है.
अन्य जानकारी
समस्या का हल
अगर पिछले चरणों को पूरा करने के बाद भी कुछ पॉड में सर्वर मौजूद हैं, तो सर्वर को रजिस्ट्रर करने की सुविधा हटाने और मिटाने के लिए, यहां दिया गया तरीका अपनाएं. ध्यान दें: ज़रूरत के हिसाब से टाइप और पॉड बदलें.
- नीचे दिए गए निर्देश का इस्तेमाल करके, यूनीक आइडेंटिफ़ायर पाएं:
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
- Analytics ग्रुप देखें.
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 नोड
लॉग
कॉम्पोनेंट के लॉग देखकर पक्का करें कि कोई गड़बड़ी न हो.
- नए मास्टर पर, कॉन्फ़िगरेशन फ़ाइल में बदलाव करके ये सेट करें: