अमेज़ॅन आरडीएस - पोस्टग्रेक्यूएल सुविधाएँ

PostgreSQL एक शक्तिशाली, ओपन सोर्स ऑब्जेक्ट-रिलेशनल डेटाबेस सिस्टम है जिसने विश्वसनीयता, सुविधा मजबूती और प्रदर्शन के लिए एक मजबूत प्रतिष्ठा अर्जित की है। AWS RDS, PostgreSQL के विभिन्न संस्करणों को चलाता है। यह पॉइंट-इन-टाइम रिस्टोर और बैकअप का समर्थन करता है, डीबी स्नैपशॉट्स का निर्माण करता है और इसे मल्टी-एज़ेड वातावरण पर चलाता है।

संस्करण 10.4 के माध्यम से 9.3 RDS प्लेटफ़ॉर्म में समर्थित प्रमुख संस्करण हैं। यदि DB निर्माण के दौरान किसी भी संस्करण का उल्लेख नहीं किया गया है, तो यह उस समय के सबसे हाल के संस्करण में चूक करता है। नीचे एक उदाहरण है कि अजगर एसडीके कार्यक्रम में एडब्ल्यूएस एपीआई का उपयोग करके सभी समर्थित डीबी इंजन संस्करण कैसे प्राप्त करें।

import boto3
client = boto3.client('rds')
response = client.describe_db_engine_versions(
    DBParameterGroupFamily='',
    DefaultOnly=True,
    Engine='postgres',
    EngineVersion='',
    ListSupportedCharacterSets=False, #True,
)

print(response)

जब हम उपरोक्त कार्यक्रम चलाते हैं, तो हमें निम्नलिखित आउटपुट मिलते हैं -

{
   "ResponseMetadata": {
      "RetryAttempts": 0,
      "HTTPStatusCode": 200,
      "RequestId": "c85cd49f-2c16-44b4-9890-cb233651f962",
      "HTTPHeaders": {
         "x-amzn-requestid": "c85cd49f-2c16-44b4-9890-cb233651f962",
         "date": "Fri, 14 Sep 2018 07:31:34 GMT",
         "content-length": "995",
         "content-type": "text/xml"
      }
   },
   "u'DBEngineVersions'": [
      {
         "u'Engine'": "postgres",
         "u'DBParameterGroupFamily'": "postgres10",
         "u'SupportsLogExportsToCloudwatchLogs'": false,
         "u'SupportsReadReplica'": true,
         "u'DBEngineDescription'": "PostgreSQL",
         "u'EngineVersion'": "10.4",
         "u'DBEngineVersionDescription'": "PostgreSQL 10.4-R1",
         "u'ValidUpgradeTarget'": []
      }
   ]
}

PostgreSQL समुदाय नए संस्करण और नए एक्सटेंशन लगातार जारी करता है। Aws RDS द्वारा पूरी तरह से समर्थित होने से पहले आप नए PostgreSQL संस्करण और एक्सटेंशन आज़मा सकते हैं। ऐसा करने के लिए, आप डेटाबेस पूर्वावलोकन परिवेश में एक नया DB उदाहरण बना सकते हैं।

डेटाबेस पूर्वावलोकन परिवेश में DB आवृत्तियाँ उत्पादन परिवेश में DB आवृत्तियों के समान होती हैं। हालांकि, कई महत्वपूर्ण कारकों को ध्यान में रखें:

  • किसी भी बैकअप और स्नैपशॉट के साथ, आपको बनाने के 60 दिनों के बाद सभी DB इंस्टेंसेस हटा दिए जाते हैं।

  • आप केवल अमेज़ॅन VPC सेवा के आधार पर वर्चुअल प्राइवेट क्लाउड (VPC) में DB उदाहरण बना सकते हैं।

  • आप केवल M4, T2 और R4 उदाहरण प्रकार बना सकते हैं। आरडीएस उदाहरण कक्षाओं के बारे में अधिक जानकारी के लिए,

  • आप DB उदाहरणों के साथ AWS सहायता से सहायता प्राप्त नहीं कर सकते। आप आरडीएस डेटाबेस पूर्वावलोकन पर्यावरण फोरम में अपने प्रश्न पोस्ट कर सकते हैं।

  • आप केवल सामान्य प्रयोजन एसएसडी और प्रावधानित आईओपीएस एसएसडी भंडारण का उपयोग कर सकते हैं।

  • आप किसी DB परिवेश के स्नैपशॉट को उत्पादन परिवेश में कॉपी नहीं कर सकते।

  • कुछ अमेज़न आरडीएस विशेषताएं पूर्वावलोकन वातावरण में उपलब्ध नहीं हैं, जैसा कि निम्नलिखित वर्णित है।

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

  • एकल डेटाबेस में वृद्धिशील परिवर्तन या सबस्क्राइबर्स के लिए डेटाबेस का एक उपसमूह जैसा कि वे होते हैं।

  • कई डेटाबेसों को एक एकल (उदाहरण के लिए विश्लेषणात्मक उद्देश्यों के लिए) में समेकित करना।

  • PostgreSQL के विभिन्न प्रमुख संस्करणों के बीच की पुनरावृत्ति।

  • विभिन्न प्लेटफार्मों पर PostgreSQL उदाहरणों के बीच की नकल करना (उदाहरण के लिए लिनक्स से विंडोज)

  • उपयोगकर्ताओं के विभिन्न समूहों के लिए दोहराया डेटा तक पहुंच प्रदान करना।

  • कई डेटाबेस के बीच डेटाबेस का एक सबसेट साझा करना।

PostgreSQL DB उदाहरण के लिए Amazon RDS के लिए तार्किक प्रतिकृति को सक्षम करने के लिए

  • AWS उपयोगकर्ता खाते के लिए rds_superuser भूमिका की आवश्यकता है ताकि Amazon RDS पर PostgreSQL डेटाबेस के लिए तार्किक प्रतिकृति बना सके।

  • Rds.logical_replication पैरामीटर को 1 पर सेट करें।

  • प्रकाशक उदाहरण (उत्पादन) के लिए सुरक्षा समूह के इनबाउंड नियमों को संशोधित करें ताकि ग्राहक उदाहरण (प्रतिकृति) को कनेक्ट करने की अनुमति दे सके। यह आमतौर पर सुरक्षा समूह में ग्राहक के आईपी पते को शामिल करके किया जाता है।