अमेज़ॅन आरडीएस - इंटरफेस

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

ऐसे तीन मुख्य इंटरफेस हैं।

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

इसे CLI एक्सेस भी कहा जाता है जहाँ आप AWS कमांड प्रॉम्प्ट स्क्रीन के माध्यम से DB कमांड निष्पादित कर सकते हैं जिसे आपके द्वारा उपयोग किए जा रहे क्लाइंट कंप्यूटर में स्थापित होना चाहिए। नीचे अपने स्थानीय सिस्टम में सीएलआई स्थापित करने के चरण दिए गए हैं, जिनके उपयोग से आप AWS सेवाओं तक पहुँच प्राप्त करेंगे।

AWS CLI स्थापित करने के चरण नीचे दिए गए हैं।

चरण 1

अपने वातावरण में अजगर के संस्करण की जाँच करें।

ubuntu@ubuntu:~$ python -V
ubuntu@ubuntu:~$ python3 -V

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

Python 2.7.12 
Python 3.5.2

यदि संस्करण 2.6 या 3.3 से कम है, तो आपको अपने सिस्टम में अजगर के संस्करण को अपग्रेड करने की आवश्यकता है।

चरण 2

पाइप नाम के अजगर पैकेज की उपलब्धता की जांच करें। इसे एडब्ल्यूएस सीएलआई स्थापित करने की आवश्यकता होगी।

Pip -V

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

pip 10.0.1 from /home/ubuntu/.local/lib/python3.5/site-packages/pip (python 3.5)

चरण 3

AWS CLI को स्थापित करने के लिए निम्नलिखित कमांड जारी करें।

pip install awscli –upgrade –user
aws --version

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

Aws-cli/1.11.84 Python/3.6.2 Linux/4.4.0

चरण 4

इसके बाद हम ari CLI को क्रेडेंशियल्स के साथ कॉन्फ़िगर करते हैं। हम इस आदेश को जारी करते हैं और फिर आवश्यक मानों को एक-एक करके इनपुट करते हैं।

aws configure

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

AWS Access Key ID [None]: ****PLE
AWS Secret Access Key [None]: ********8
Default region name [None]: us-west-2
Default output format [None]: json

जगह में उपरोक्त विन्यास के साथ अब आप अमेजन आरडीएस की स्थापना और उपयोग करने के लिए AWS वातावरण के साथ संचार के लिए CLI का उपयोग करने के लिए तैयार हैं। अगले अध्यायों में हम देखेंगे कि हम ऐसा कैसे कर सकते हैं।

Amazon Relational Database Service (Amazon RDS) एक एप्लीकेशन प्रोग्रामिंग इंटरफ़ेस (API) भी प्रदान करता है। API का उपयोग तब किया जाता है जब सूचनाओं का आदान-प्रदान सिस्टम के बीच मानव द्वारा आदेश जारी करने और परिणाम प्राप्त करने के बजाय किया जाता है। उदाहरण के लिए, यदि आप एक आरडीएस सेवा में डेटाबेस इंस्टेंस के जोड़ को स्वचालित करना चाहते हैं, जब लेनदेन की संख्या कुछ सीमा तक पहुंच जाती है, तो आप एक प्रोग्राम लिखने के लिए एडब्ल्यूएस एसडीके का उपयोग करते हैं जो डेटाबेस लेनदेन की संख्या और आरडीएस को स्पिन-ऑफ करेगा। उदाहरण के लिए जब आवश्यक शर्त पूरी की जाती है।

नीचे एपीआई कोड का एक उदाहरण है जो एक डीबी स्नैपशॉट की एक प्रति बनाता है। यह एक पायथन प्रोग्राम है, जो BWS3 नामक AWS sdk का उपयोग करता है। Boto3 में क्लाइंट लाइब्रेरी में copy_db_snapshot नाम की एक विधि है जिसे python प्रोग्राम द्वारा डीबी स्नैपशॉट की एक प्रतिलिपि बनाने के लिए कहा जाता है, जैसा कि दिखाया गया है।

import boto3

client = boto3.client('rds')

response = client.copy_db_snapshot(
    SourceDBSnapshotIdentifier='mydbsnapshot',
    TargetDBSnapshotIdentifier='mydbsnapshot-copy',
)

print(response)

जब उपरोक्त कार्यक्रम चलाया जाता है तो हमें प्रतिसाद मिलता है जो कॉपी ईवेंट के विभिन्न गुणों का वर्णन करता है। यहां शब्द स्ट्रिंग मापदंडों के विभिन्न नामों का प्रतिनिधित्व करता है जो उपयोगकर्ता द्वारा उनके पर्यावरण के लिए परिभाषित किया गया है। उदाहरण के लिए VpcID vpc की आईडी का प्रतिनिधित्व करता है जिसमें प्रतिलिपि कार्रवाई हो रही है।

{
    'DBSnapshot': {
        'DBSnapshotIdentifier': 'string',
        'DBInstanceIdentifier': 'string',
        'SnapshotCreateTime': datetime(2015, 1, 1),
        'Engine': 'string',
        'AllocatedStorage': 123,
        'Status': 'string',
        'Port': 123,
        'AvailabilityZone': 'string',
        'VpcId': 'string',
        'InstanceCreateTime': datetime(2015, 1, 1),
        'MasterUsername': 'string',
        'EngineVersion': 'string',
        'LicenseModel': 'string',
        'SnapshotType': 'string',
        'Iops': 123,
        'OptionGroupName': 'string',
        'PercentProgress': 123,
        'SourceRegion': 'string',
        'SourceDBSnapshotIdentifier': 'string',
        'StorageType': 'string',
        'TdeCredentialArn': 'string',
        'Encrypted': True|False,
        'KmsKeyId': 'string',
        'DBSnapshotArn': 'string',
        'Timezone': 'string',
        'IAMDatabaseAuthenticationEnabled': True|False,
        'ProcessorFeatures': [
            {
                'Name': 'string',
                'Value': 'string'
            },
        ]
    }
}