PostgreSQL
 sql >> डेटाबेस >  >> RDS >> PostgreSQL

पोस्टग्रेएसक्यूएल डिजास्टर रिकवरी के लिए बर्मन का उपयोग करना

सामान्य रूप से PostgreSQL के लिए बैकअप और पुनर्स्थापना विकल्प के रूप में कई शक्तिशाली उपकरण उपलब्ध होने चाहिए; इस संदर्भ में बर्मन, पीजीबैकरेस्ट, बार्ट कुछ नाम रखने वाले हैं। जिस बात ने हमारा ध्यान खींचा, वह यह थी कि बर्मन एक ऐसा उपकरण है जो उत्पादन परिनियोजन और बाजार के रुझानों के साथ तेजी से आगे बढ़ रहा है।

चाहे वह डॉकटर आधारित परिनियोजन हो, बैकअप को किसी भिन्न क्लाउड स्टोरेज में संग्रहीत करने की आवश्यकता हो या अत्यधिक अनुकूलन योग्य आपदा पुनर्प्राप्ति वास्तुकला की आवश्यकता हो - ऐसे सभी मामलों में बर्मन एक बहुत मजबूत दावेदार है।

यह ब्लॉग बर्मन को परिनियोजन के बारे में कुछ मान्यताओं के साथ खोजता है, हालांकि किसी भी स्थिति में इसे केवल संभावित सुविधा-सेट नहीं माना जाना चाहिए। बर्मन इस ब्लॉग में जो हम कैप्चर कर सकते हैं उससे कहीं आगे है और अगर 'पोस्टग्रेएसक्यूएल इंस्टेंस का बैकअप और पुनर्स्थापना' पर विचार किया जाता है तो इसे और खोजा जाना चाहिए।

DR तैयार परिनियोजन अनुमान 

RPO=0 आम तौर पर एक लागत पर आता है - सिंक्रोनस स्टैंडबाय सर्वर परिनियोजन अक्सर इसे पूरा करेगा, लेकिन फिर यह प्राथमिक सर्वर के TPS को अक्सर प्रभावित करता है।

PostgreSQL की तरह, जब RPO बनाम प्रदर्शन की बात आती है, तो बर्मन आपकी आवश्यकताओं को पूरा करने के लिए कई परिनियोजन विकल्प देता है। परिनियोजन सरलता, RPO=0 या लगभग शून्य प्रदर्शन प्रभाव के बारे में सोचें; बर्मन सभी में फिट बैठता है।

हमने अपने बैकअप और रीस्टोर आर्किटेक्चर के लिए डिजास्टर रिकवरी सॉल्यूशन स्थापित करने के लिए निम्नलिखित परिनियोजन पर विचार किया।

चित्र 1:बर्मन के साथ PostgreSQL परिनियोजन

दो साइटें हैं (सामान्य रूप से की तरह) आपदा-वसूली साइटों के लिए) - साइट-एक्स और साइट-वाई।

साइट-X में है:

  • एक सर्वर 'pgServer' एक PostgreSQL सर्वर इंस्टेंस pgServer को होस्ट करता है, और एक OS उपयोगकर्ता 'पोस्टग्रेज' करता है 
    • PostgreSQL इंस्टेंस भी एक सुपरयूज़र भूमिका 'bmuser' को होस्ट करने के लिए
  • एक सर्वर 'bServer' जो बर्मन बायनेरिज़ को होस्ट करता है और एक OS उपयोगकर्ता 'bmuser'

साइट-Y में है:

  • एक सर्वर 'geobServer' जो बर्मन बायनेरिज़ को होस्ट करता है और एक OS उपयोगकर्ता 'bmuser'

इस सेटअप में कई प्रकार के कनेक्शन शामिल हैं।

  • 'bServer' और 'pgServer' के बीच:
    • मैनेजमेंट-प्लेन कनेक्टिविटी बर्मन से पोस्टग्रेएसक्यूएल इंस्टेंस तक
    • बर्मन से PostgreSQL इंस्टेंस तक वास्तविक आधार बैकअप करने के लिए rsync कनेक्टिविटी
    • WAL पोस्टग्रेएसक्यूएल इंस्टेंस से बर्मन तक बर्मन-वाल-आर्काइव का उपयोग करके संग्रह करना
    • बर्मन में pg_receivexlog का उपयोग करके वाल स्ट्रीमिंग
  • 'बीसर्वर' और 'जियोसर्वर' के बीच:
    • भू-प्रतिकृति प्रदान करने के लिए बर्मन सर्वरों के बीच सिंक्रनाइज़ेशन

कनेक्टिविटी पहले 

सर्वर के बीच प्राथमिक कनेक्टिविटी की जरूरत ssh के माध्यम से है। इसे पासवर्ड रहित बनाने के लिए ssh-keys का उपयोग किया जाता है। आइए ssh कुंजियाँ स्थापित करें और उनका आदान-प्रदान करें।

पीजीसर्वर पर:

example@sqldat.com$ ssh-keygen -q -t rsa -N '' -f ~/.ssh/id_rsa <<<y 2>&1 >/dev/null

example@sqldat.com$ ssh-copy-id -i ~/.ssh/id_rsa.pub example@sqldat.com

example@sqldat.com$ ssh example@sqldat.com "chmod 600 ~/.ssh/authorized_keys"

बीसर्वर पर:

example@sqldat.com$ ssh-keygen -q -t rsa -N '' -f ~/.ssh/id_rsa <<<y 2>&1 >/dev/null

example@sqldat.com$ ssh-copy-id -i ~/.ssh/id_rsa.pub example@sqldat.com

example@sqldat.com$ ssh example@sqldat.com "chmod 600 ~/.ssh/authorized_keys"

जियोबसर्वर पर:

example@sqldat.com$ ssh-keygen -q -t rsa -N '' -f ~/.ssh/id_rsa <<<y 2>&1 >/dev/null

example@sqldat.com$ ssh-copy-id -i ~/.ssh/id_rsa.pub example@sqldat.com

example@sqldat.com$ ssh example@sqldat.com "chmod 600 ~/.ssh/authorized_keys"

PostgreSQL इंस्टेंस कॉन्फ़िगरेशन 

पोस्टग्रेज इंस्टेंस को फिर से बनाने के लिए हमें दो मुख्य चीजों की आवश्यकता होती है - आधार निर्देशिका और उसके बाद उत्पन्न वाल / लेनदेन लॉग। बर्मन सर्वर समझदारी से उन पर नज़र रखता है। हमें यह सुनिश्चित करने की आवश्यकता है कि बर्मन के लिए इन कलाकृतियों को एकत्र करने के लिए उचित फ़ीड तैयार की जाए।

postgresql.conf में निम्नलिखित पंक्तियाँ जोड़ें:

listen_addresses = '172.25.130.180'     #as per above deployment assumption

wal_level = replica                     #or higher 

archive_mode = on

archive_command = 'barman-wal-archive -U bmuser bserver pgserver %p'

आर्काइव कमांड यह सुनिश्चित कर रहा है कि जब WAL को पोस्टग्रेज इंस्टेंस द्वारा आर्काइव किया जाना है, तो बर्मन-वाल-आर्काइव यूटिलिटी इसे बर्मन सर्वर पर सबमिट कर देती है। यह ध्यान दिया जाना चाहिए कि बर्मन-क्ली पैकेज इसलिए 'पीजीसर्वर' पर उपलब्ध कराया जाना चाहिए। यदि हम बर्मन-वाल-आर्काइव उपयोगिता का उपयोग नहीं करना चाहते हैं तो rsync का उपयोग करने का एक और विकल्प है।

निम्नलिखित को pg_hba.conf में जोड़ें:

host     all                    all     172.25.130.186/32     md5

host     replication            all     172.25.130.186/32     md5

यह मूल रूप से इस पोस्टग्रेज इंस्टेंस के लिए 'bmserver' से एक प्रतिकृति और एक सामान्य कनेक्शन की अनुमति दे रहा है।

अब बस इंस्टेंस को पुनरारंभ करें और bmuser नामक एक सुपर उपयोगकर्ता भूमिका बनाएं:

example@sqldat.com$ pg_ctl restart

example@sqldat.com$ createuser -s -P bmuser 

यदि आवश्यक हो, तो हम सुपर-उपयोगकर्ता के रूप में भी bmuser का उपयोग करने से बच सकते हैं; जिसे इस उपयोगकर्ता को सौंपे गए विशेषाधिकारों की आवश्यकता होगी। उपरोक्त उदाहरण के लिए, हमने bmuser को पासवर्ड के रूप में भी इस्तेमाल किया। लेकिन जहां तक ​​PostgreSQL इंस्टेंस कॉन्फ़िगरेशन की आवश्यकता है, वह बहुत अधिक है।

बर्मन कॉन्फ़िगरेशन 

बर्मन के विन्यास में तीन बुनियादी घटक हैं:

  • वैश्विक कॉन्फ़िगरेशन 
  • सर्वर स्तर कॉन्फ़िगरेशन 
  • बरमन चलाने वाला उपयोगकर्ता 

 हमारे मामले में, चूंकि बर्मन आरपीएम का उपयोग करके स्थापित किया गया है, इसलिए हमने अपनी वैश्विक कॉन्फ़िगरेशन फ़ाइलें यहां संग्रहीत की हैं:

/etc/barman.conf

हम सर्वर स्तर कॉन्फ़िगरेशन को bmuser होम निर्देशिका में संग्रहीत करना चाहते थे, इसलिए हमारी वैश्विक कॉन्फ़िगरेशन फ़ाइल में निम्नलिखित सामग्री थी:

[barman]

barman_user = bmuser

configuration_files_directory = /home/bmuser/barman.d

barman_home = /home/bmuser

barman_lock_directory = /home/bmuser/run

log_file = /home/bmuser/barman.log

log_level = INFO

प्राथमिक बर्मन सर्वर कॉन्फ़िगरेशन 

उपरोक्त परिनियोजन में, हमने प्राथमिक बर्मन सर्वर को उसी डेटा-सेंटर / साइट में रखने का निर्णय लिया जहां पोस्टग्रेएसक्यूएल इंस्टेंस रखा गया है। इसका लाभ यह है कि आवश्यकता पड़ने पर कम अंतराल और तेजी से वसूली होती है। कहने की जरूरत नहीं है कि PostgreSQL सर्वर पर भी कम कंप्यूटिंग और/या नेटवर्क बैंडविड्थ की जरूरत है।

बर्मन को pgServer पर PostgreSQL इंस्टेंस को प्रबंधित करने देने के लिए, हमें निम्नलिखित सामग्री के साथ एक कॉन्फ़िगरेशन फ़ाइल (हमने pgserver.conf नाम दिया) जोड़ने की आवश्यकता है:

[pgserver]

description =  "Example pgserver configuration"

ssh_command = ssh example@sqldat.com

conninfo = host=pgserver user=bmuser dbname=postgres

backup_method = rsync

reuse_backup = link

backup_options = concurrent_backup

parallel_jobs = 2

archiver = on

archiver_batch_size = 50

path_prefix = "/usr/pgsql-12/bin"



streaming_conninfo = host=pgserver user=bmuser dbname=postgres

streaming_archiver=on

create_slot = auto

और एक .pgpass फ़ाइल जिसमें PostgreSQL इंस्टेंस में bmuser के क्रेडेंशियल हैं:

echo 'pgserver:5432:*:bmuser:bmuser' > ~/.pgpass 

महत्वपूर्ण कॉन्फ़िगरेशन आइटम को थोड़ा और समझने के लिए:

  • ssh_command :कनेक्शन स्थापित करने के लिए प्रयुक्त होता है जिस पर rsync किया जाएगा 
  • conninfo :बर्मन को पोस्टग्रेज सर्वर के साथ कनेक्शन स्थापित करने देने के लिए कनेक्शन स्ट्रिंग
  • reuse_backup :कम संग्रहण के साथ वृद्धिशील बैकअप की अनुमति देने के लिए 
  • बैकअप_विधि :मूल निर्देशिका का बैकअप लेने की विधि
  • path_prefix :वह स्थान जहां pg_receivexlog बायनेरिज़ संग्रहीत हैं 
  • streaming_conninfo :WAL स्ट्रीम करने के लिए उपयोग की जाने वाली कनेक्शन स्ट्रिंग 
  • create_slot :यह सुनिश्चित करने के लिए कि पोस्टग्रेज़ इंस्टेंस द्वारा स्लॉट बनाए गए हैं 

निष्क्रिय बर्मन सर्वर कॉन्फ़िगरेशन 

भू-प्रतिकृति साइट का विन्यास बहुत आसान है। इसके लिए केवल एक ssh कनेक्शन जानकारी की आवश्यकता होती है, जिस पर यह निष्क्रिय नोड साइट प्रतिकृति करेगी।

दिलचस्प बात यह है कि ऐसा निष्क्रिय नोड मिक्स-मोड में काम कर सकता है; दूसरे शब्दों में - वे PostgreSQL साइटों के लिए बैकअप करने के लिए सक्रिय बर्मन सर्वर के रूप में कार्य कर सकते हैं और समानांतर में अन्य बर्मन सर्वरों के लिए प्रतिकृति/कैस्केड साइट के रूप में कार्य कर सकते हैं।

चूंकि, हमारे मामले में बर्मन (साइट-वाई पर) के इस उदाहरण को केवल एक निष्क्रिय नोड होने की आवश्यकता है, हमें केवल /home/bmuser/barman.d/pgserver.conf फ़ाइल बनाने की आवश्यकता है निम्नलिखित विन्यास के साथ:

[pgserver]

description =  "Geo-replication or sync for pgserver"

primary_ssh_command = ssh example@sqldat.com

इस धारणा के साथ कि चाबियों का आदान-प्रदान किया गया है और इस नोड पर वैश्विक कॉन्फ़िगरेशन पहले बताए गए अनुसार किया जाता है - हम कॉन्फ़िगरेशन के साथ बहुत कुछ कर चुके हैं।

और यहां हमारा पहला बैकअप और पुनर्स्थापना है 

bserver पर सुनिश्चित करें कि WAL प्राप्त करने की पृष्ठभूमि प्रक्रिया शुरू हो गई है; और फिर सर्वर के कॉन्फ़िगरेशन की जाँच करें:

example@sqldat.com$ barman cron

example@sqldat.com$ barman check pgserver

चेक सभी सबस्टेप्स के लिए ठीक होना चाहिए। यदि नहीं, तो /home/bmuser/barman.log देखें।

बर्मन पर बैकअप कमांड जारी करें ताकि यह सुनिश्चित हो सके कि एक आधार डेटा है जिस पर वाल लागू किया जा सकता है:

example@sqldat.com$ barman backup pgserver

'जियोबमसर्वर' पर सुनिश्चित करें कि प्रतिकृति निम्नलिखित आदेशों को निष्पादित करके की जाती है:

example@sqldat.com$ barman cron 

example@sqldat.com$ barman list-backup pgserver

क्रोन को crontab फ़ाइल में डाला जाना चाहिए (यदि मौजूद नहीं है)। सादगी के लिए, मैंने इसे यहाँ नहीं दिखाया है। अंतिम कमांड दिखाएगा कि बैकअप फ़ोल्डर जियोबमसर्वर पर भी बनाया गया है।

अब Postgres उदाहरण पर, आइए कुछ डमी डेटा बनाएं:

example@sqldat.com$ psql -U postgres -c "CREATE TABLE dummy_data( i INTEGER);"

example@sqldat.com$ psql -U postgres -c "insert into dummy_data values ( generate_series (1, 1000000 ));"

WAL की PostgreSQL आवृत्ति से प्रतिकृति को नीचे दिए गए आदेश का उपयोग करके देखा जा सकता है:

example@sqldat.com$ psql -U postgres -c "SELECT * from pg_stat_replication ;”

साइट-Y पर एक इंस्टेंस को फिर से बनाने के लिए, पहले सुनिश्चित करें कि WAL रिकॉर्ड स्विच-ओवर हैं। या यह उदाहरण, क्लीन रिकवरी बनाने के लिए:

example@sqldat.com$ barman switch-xlog --force --archive pgserver

साइट-X पर, आइए एक स्टैंडअलोन पोस्टग्रेएसक्यूएल इंस्टेंस लाते हैं ताकि यह जांचा जा सके कि बैकअप सही है या नहीं:

example@sqldat.com$ barman cron 

barman recover --get-wal pgserver latest /tmp/data

अब, आवश्यकता के अनुसार postgresql.conf और postgresql.auto.conf फ़ाइलों को संपादित करें। निम्नलिखित इस उदाहरण के लिए किए गए परिवर्तनों की व्याख्या करें:

  • postgresql.conf :सुनने_पते ने टिप्पणी की ताकि स्थानीयहोस्ट के लिए डिफ़ॉल्ट हो
  • postgresql.auto.conf :sudo bmuser को restore_command से हटा दिया

इस डेटा को /tmp/data में लाएं और अपने रिकॉर्ड के अस्तित्व की जांच करें।

निष्कर्ष

यह तो बस एक हिमखंड का सिरा था। बर्मन इसके द्वारा प्रदान की जाने वाली कार्यक्षमता के कारण इससे कहीं अधिक गहरा है - उदा। एक सिंक्रनाइज़ स्टैंडबाय, हुक स्क्रिप्ट आदि के रूप में कार्य करना। कहने की जरूरत नहीं है कि आपके उत्पादन परिवेश की आवश्यकताओं के अनुसार इसे कॉन्फ़िगर करने के लिए दस्तावेज़ीकरण को समग्रता में खोजा जाना चाहिए।


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. dplyr left_join से कम, शर्त से बड़ा

  2. प्रति दिन 1 से अधिक रिकॉर्ड कैसे चुनें?

  3. क्या PostgreSQL में स्ट्रिंग मान (जैसे eval) के अंदर किसी क्वेरी को निष्पादित करने का कोई तरीका है?

  4. n समूहीकृत श्रेणियां प्राप्त करें और दूसरों को एक में जोड़ें

  5. 1=1 पर शामिल हों (चुनें ...)?