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

बर्मन 2.11:बरमन-बादल-पुनर्स्थापना और बरमान-बादल-वाल-पुनर्स्थापना

नई उपयोगिताओं के लिए धन्यवाद barman-cloud-restore और barman-cloud-wal-restore Barman 2.11 . में पेश किया गया , अब barman-cloud-wal-archive का उपयोग करके पहले से निष्पादित पूर्ण बैकअप का उपयोग करके PostgreSQL इंस्टेंस की पुनर्प्राप्ति को निष्पादित करना संभव है और barman-cloud-backup आदेश। आइए एक साथ देखें कि निम्नलिखित लेख में इसे कैसे लागू किया जाए।


यह ध्यान देने योग्य है कि बर्मन 2.11 में, बर्मन के लिए सभी क्लाउड यूटिलिटीज अब barman-cli-cloud नामक एक अलग पैकेज में हैं। ।

आवश्यकताएं

1. barman-cli-cloud पैकेज
2. एक PostgreSQL उदाहरण
3. AWS S3 बकेट
4. एक दूसरी वर्चुअल मशीन जहां पुनर्स्थापना निष्पादित करना है

इस लेख में, हम barman-cli-cloud का परीक्षण करेंगे डेबियन बस्टर और पोस्टग्रेएसक्यूएल 12 के साथ वर्चुअल मशीन में कार्यात्मकता। इस आलेख में निहित निर्देशों का ठीक से पालन करने के लिए, हम यह भी मानते हैं कि आपके पास है:

  • WAL फ़ाइलों को barman-cloud-wal-archive का उपयोग करके मौजूदा S3 बकेट में संग्रहीत करने के लिए पोस्टग्रेज़ को कॉन्फ़िगर किया गया
  • एक बैकअप निष्पादित किया और उसे barman-cloud-backup के माध्यम से उसी S3 बकेट में भेज दिया

आप इन पिछले ब्लॉग लेखों में निहित निर्देशों का पालन करके इसे आसानी से प्राप्त कर सकते हैं:

  • बर्मन क्लाउड - भाग 1:वाल आर्काइव
  • बर्मन क्लाउड - भाग 2:क्लाउड बैकअप

पुनर्प्राप्ति सर्वर सेट अप करें

परिणामस्वरूप, हमारे पास AWS पर एक S3 बकेट है जिसका नाम barman-s3-test . है जिसमें पहले से ही WAL फ़ाइलें और बैकअप barman-cloud-wal-archive के माध्यम से संग्रहीत हैं और barman-cloud-backup टूल्स, अब हमें एक सर्वर को ठीक से कॉन्फ़िगर करने की आवश्यकता है जो पोस्टग्रेएसक्यूएल इंस्टेंस की पुनर्प्राप्ति के लिए होस्ट होगा।

1. आधिकारिक PGDG रिपॉजिटरी से PostgreSQL 12 स्थापित करें

2. द्वितीय चतुर्थांश सार्वजनिक भंडार स्थापित करें

3. barman-cli-cloud इंस्टॉल करें पैकेज:

[email protected]:~# apt [email protected]:~# apt install barman-cli-cloud

4. स्थापित करें awscli पैकेज:

[email protected]:~# apt install awscli

5. उपयोगकर्ता को पोस्टग्रेज करने के लिए awscli टूल के साथ AWS क्रेडेंशियल कॉन्फ़िगर करें:

[email protected]:~$ aws config --profile barman-cloudAWS एक्सेस की आईडी [कोई नहीं]:AKI*****************AWS सीक्रेट एक्सेस की [कोई नहीं ]:************************** डिफ़ॉल्ट क्षेत्र का नाम [कोई नहीं]:यूरोपीय संघ -पश्चिम-1डिफ़ॉल्ट आउटपुट स्वरूप [कोई नहीं]:json

पुनर्स्थापन प्रक्रिया निष्पादित करें

अब जबकि पुनर्प्राप्ति सर्वर सही ढंग से कॉन्फ़िगर किया गया है, हम पुनर्स्थापना प्रक्रिया शुरू करने के लिए तैयार हैं।

बर्मन 2.11 ने barman-cloud-backup-list का परिचय दिया कमांड जो आपको barman-cloud-backup . के साथ किए गए बैकअप के बारे में जानकारी प्राप्त करने की अनुमति देता है :

[email protected]:~$ barman-cloud-backup-list \ --profile barman-cloud \ s3://barman-s3-test pg12बैकअप आईडी समाप्ति समय प्रारंभ Wal20200713T120856 2020-07-13 12:09:05 00000001000000000000000C

अब हम barman-cloud-restore . का उपयोग करके पुनर्स्थापना निष्पादित करने के लिए तैयार हैं आदेश:

[email protected]:~$ barman-cloud-restore \ --profile barman-cloud \ s3://barman-s3-test \ pg12 20200713T120856 \ /var/lib/postgresql/12/main/

एक बार जब पुनर्स्थापना सफलतापूर्वक समाप्त हो जाती है तो हम PGDATA निर्देशिका सामग्री की जांच कर सकते हैं:

[email protected]:~$ ls /var/lib/postgresql/12/main/PG_VERSION वैश्विक pg_hba.conf pg_multixact pg_serial pg_stat_tmp pg_twophase postgresql.auto.confbackup_label pg_commit_ts pg_identify_g_fg_swald pg_replslot pg_stat pg_tblspc pg_xact

अब, यह सुनिश्चित करने के लिए कि पुनर्स्थापना प्रक्रिया ठीक से काम कर रही है, हमें पुनर्प्राप्त PostgreSQL इंस्टेंस को शुरू करने और यह सत्यापित करने की आवश्यकता है कि सब कुछ अपेक्षित रूप से काम करता है। इस प्रक्रिया के लिए कुछ अतिरिक्त चरणों की आवश्यकता है।

सबसे पहले, चूंकि हम डेबियन सिस्टम पर हैं, इसलिए हमें /etc/postgresql/12/main/ के तहत PostgreSQL कॉन्फ़िगरेशन वाली फाइलों को कॉपी करना होगा। निर्देशिका:

[email protected]:~$ cp /var/lib/postgresql/12/main/postgresql.conf /etc/postgresql/12/main/[email protected]:~$ cp /var/lib/postgresql /12/main/pg_hba.conf /etc/postgresql/12/main/[email protected]:~$ cp /var/lib/postgresql/12/main/pg_ident.conf /etc/postgresql/12/main/

दूसरा, recovery.signal बनाएं फ़ाइल:

[email protected]:~$ टच /var/lib/postgresql/12/main/recovery.signal

फिर, archive_command . को अक्षम करें पुनर्प्राप्त उदाहरण को मूल उदाहरण के समान बाल्टी में लिखने से रोकने के लिए:

[email protected]:~$ इको \"archive_command ='cd .'\">> /etc/postgresql/12/main/postgresql.conf

उसके बाद, आपको barman-cloud-wal-restore का उपयोग करके S3 बकेट से नवीनतम उपलब्ध टाइमलाइन की WAL फ़ाइलों को पुनः प्राप्त करने के लिए PostgreSQL को कॉन्फ़िगर करने की आवश्यकता है। restore_command . में :

[email protected]:~$ echo \"restore_command ='barman-cloud-wal-restore --profile barman-cloud s3://barman-s3-test pg12%f %p'\">> / etc/postgresql/12/main/[email protected]:~$ echo \"recovery_target_timeline ='latest'\">> /etc/postgresql/12/main/postgresql.conf

महत्वपूर्ण :आगे बढ़ने से पहले कृपया सुनिश्चित करें कि PostgreSQL इंस्टेंस नहीं चल रहा है, और गंतव्य निर्देशिका (डिफ़ॉल्ट PostgreSQL डेटादिर) खाली है।

अंत में, हम नया पुनर्प्राप्त उदाहरण शुरू करने के लिए तैयार हैं:

[email protected]:~# systemctl पुनरारंभ [email protected]

महान! जैसा कि हम PostgreSQL लॉग से देख सकते हैं, WAL फ़ाइलें S3 बकेट से पुनर्प्राप्त की जाती हैं और उदाहरण सही ढंग से प्रारंभ किया गया था:

[email protected]:~$ कम /var/log/postgresql/postgresql-12-main.log...2020-07-13 12:43:25.093 UTC [9458] लॉग:PostgreSQL 12.3 (डेबियन) शुरू करना 12.3-1.pgdg100+1) x86_64-पीसी-लिनक्स-ग्नू पर, जीसीसी (डेबियन 8.3.0-6) 8.3.0, 64-बिट2020-07-13 12:43:25.093 यूटीसी [9458] लॉग द्वारा संकलित:IPv4 एड्रेस "127.0.0.1", पोर्ट 54322020-07-13 12:43:25.095 UTC [9458] लॉग पर सुनना:यूनिक्स सॉकेट पर सुनना "/var/run/postgresql/.s.PGSQL.5432"2020-07- 13 12:43:25.111 यूटीसी [9459] लॉग:डेटाबेस सिस्टम बाधित हो गया था; अंतिम बार 2020-07-13 12:08:56 यूटीसी2020-07-13 12:43:25.508 यूटीसी [9459] लॉग:आर्काइव रिकवरी शुरू करना2020-07-13 12:43:26.010 यूटीसी [9459] लॉग:रिस्टोर लॉग फ़ाइल "000000000000000000000C" संग्रह से 2020-07-13 12:43:26.052 UTC [9459] लॉग:0/C0000282020-07-13 12:43:26.054 UTC [9459] पर फिर से शुरू होता है लॉग:लगातार पुनर्प्राप्ति स्थिति 0/C0001382020 पर पहुंच गई -07-13 12:43:26.054 यूटीसी [9458] लॉग:डेटाबेस सिस्टम केवल पढ़ने के लिए कनेक्शन स्वीकार करने के लिए तैयार है2020-07-13 12:43:26.469 यूटीसी [9459] लॉग:आर्काइव2020-07 से पुनर्स्थापित लॉग फ़ाइल "000001000000000000000D"- 13 12:43:26.823 यूटीसी [9459] लॉग:0/डी0001बी02020-07-07-13 पर फिर से करें 12:43:27.242 यूटीसी [9459] लॉग:आर्काइव2020-07-13 12:43:27.592 से लॉग फ़ाइल "000001000000000000000 डी" बहाल UTC [9459] लॉग:चयनित नई टाइमलाइन आईडी:22020-07-13 12:43:27.644 यूटीसी [9459] लॉग:संग्रह पुनर्प्राप्ति पूर्ण2020-07-13 12:43:27.979 यूटीसी [9458] लॉग:डेटाबेस सिस्टम तैयार है कनेक्शन स्वीकार करें

निष्कर्ष

हमेशा की तरह बर्मन की किसी भी नई रिलीज़ के साथ, हम अनुशंसा करते हैं कि हर कोई अपने सिस्टम को नवीनतम संस्करण में अपडेट करे। परिवर्तनों और बग फिक्स की पूरी सूची यहां उपलब्ध है।

कृपया ध्यान दें कि यदि आप पहले से ही barman-cloud-wal-archive . का उपयोग कर रहे हैं या barman-cloud-backup RPM/Apt पैकेज के माध्यम से इंस्टॉल किया गया है और आप अपने सिस्टम को अपग्रेड कर रहे हैं, आपको barman-cli-cloud इंस्टॉल करना होगा पैकेट। यह इस तथ्य के कारण है कि, बर्मन 2.11 रिलीज के साथ, क्लाउड से संबंधित सभी उपकरण barman-cli-cloud का हिस्सा हैं। पैकेज जैसा कि लेख की शुरुआत में बताया गया है।

बर्मन के अगले संस्करण पुनर्प्राप्ति कमांड की उपयोगिता और स्वचालन क्षमताओं में सुधार कर सकते हैं, उदाहरण के लिए recovery.conf तैयार करके या recovery.signal वास्तविक बर्मन की तरह फ़ाइल।


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. PostgreSQL में दो स्कीमा की तुलना कैसे करें

  2. मैं कॉलम को दो टेबल से एक आउटपुट में कैसे मर्ज कर सकता हूं?

  3. मावेन-असेंबली-प्लगइन के साथ आवश्यक ड्राइवरों को शामिल करते समय कोई उपयुक्त ड्राइवर नहीं मिला

  4. PostgreSQL मेल्टडाउन बेंचमार्क

  5. PostgreSQL - दोहराए गए मानों को कैसे समाप्त करें