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

Maxscale से ProxySQL लोड बैलेंसर में माइग्रेट करना

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

कमर्शियल से लेकर ओपन सोर्स विकल्पों जैसे HAProxy, Nginx, ProxySQL, Maxscale, आदि तक कई डेटाबेस प्रॉक्सी हैं। इस ब्लॉग में, हम चर्चा करेंगे कि डेटाबेस प्रॉक्सी को Maxscale से ProxySQL में कैसे माइग्रेट किया जाए। ClusterControl की मदद से।

मैक्सस्केल के साथ वर्तमान आर्किटेक्चर

एक अत्यधिक उपलब्ध डेटाबेस आर्किटेक्चर पर विचार करें जिसमें गैलेरा क्लस्टर में 3 नोड होते हैं, और इसके ऊपर, डेटाबेस प्रॉक्सी की उच्च उपलब्धता के लिए 2 मैक्सस्केल और कीपलाइव्ड सेवाएं। गैलेरा क्लस्टर "वस्तुतः" तुल्यकालिक प्रतिकृति है, यह प्रतिकृति के लिए एक प्रमाणीकरण का उपयोग करता है यह सुनिश्चित करता है कि आपका डेटा सभी नोड्स पर उपलब्ध होगा। वर्तमान वास्तुकला नीचे दिखाया गया है:

Maxscale, MariaDB Corporation का एक डेटाबेस प्रॉक्सी है, जो अनुप्रयोगों के बीच मिडलवेयर के रूप में कार्य करता है। और डेटाबेस।

यहां क्लस्टरकंट्रोल में गैलेरा क्लस्टर और मैक्सस्केल लोड बैलेंसर्स के लिए टोपोलॉजी आर्किटेक्चर है। आप यह सब सीधे ClusterControl से परिनियोजित करने में सक्षम हैं, या मौजूदा डेटाबेस और प्रॉक्सी नोड्स को ClusterControl में आयात कर सकते हैं। आप अपने डेटाबेस टोपोलॉजी को टोपोलॉजी टैब में देख सकते हैं।

ProxySQL और Keepalived तैनात करें

ProxySQL, ProxySQL का एक अन्य डेटाबेस प्रॉक्सी है, जो क्वेरी पैटर्न के आधार पर क्वेरी कैशिंग, क्वेरी रीराइट, क्वेरीज़ को लिखने और पढ़ने के लिए विभाजित करने जैसी कुछ सुविधाएँ प्रदान करता है। क्लस्टरकंट्रोल में प्रॉक्सीएसक्यूएल को तैनात करने के लिए, आपको अपने क्लस्टर में मैनेज -> लोड बैलेंसर्स पर जाना होगा। ClusterControl कुछ भिन्न डेटाबेस प्रॉक्सी का समर्थन करता है; HAProxy, ProxySQL, MaxScale.

ProxySQL चुनें, और यह नीचे दिया गया पेज दिखाएगा:

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

यदि हम सेटअप के दौरान ProxySQL में डेटाबेस उपयोगकर्ता जोड़ना भूल जाते हैं, तो हम इसे ProxySQL उपयोगकर्ता टैब में कॉन्फ़िगर कर सकते हैं जैसा कि नीचे दिखाया गया है:

ProxySQL के लिए डेटाबेस उपयोगकर्ताओं को ProxySQL में भी कॉन्फ़िगर करने की आवश्यकता है।

ProxySQL के परिनियोजित होने के बाद, हम प्रत्येक ProxySQL होस्ट पर Keepalived को कॉन्फ़िगर करना जारी रखते हैं। ProxySQL इंस्टेंस में Keepalived सेवाएँ मास्टर/बैकअप भूमिकाओं के रूप में कार्य करेंगी। Keepalived सेवा VIP (वर्चुअल आईपी एड्रेस) का उपयोग करती है, इसलिए एप्लिकेशन मास्टर रोल पर वर्चुअल आईपी एड्रेस से कनेक्ट होगा, और स्थानीय प्रॉक्सीएसक्यूएल से कनेक्शन को अग्रेषित करेगा। यदि सेवाएं विफल हो जाती हैं, तो वीआईपी स्वचालित रूप से दूसरे नोड में चला जाएगा।

ClusterControl में रख-रखाव की तैनाती उसी पृष्ठ पर की जाती है जिस पर डेटाबेस प्रॉक्सी होता है, आपको केवल Keepalived टैब चुनने की आवश्यकता होती है। लोड बैलेंसर प्रकार चुनें, जो कि ProxySQL है, और फिर Keepalived1 और Keepalived2 के लिए वर्तमान ProxySQL जोड़ें। वर्चुअल आईपी एड्रेस और नेटवर्क इंटरफेस भरें। और अंत में, डिप्लॉय कीपलाइव्ड बटन पर क्लिक करें।

दो ProxySQL को Keepalived सेवाओं के साथ चलाने से हमें एक उच्च उपलब्धता प्रॉक्सी परत मिलती है। ClusterControl में, यह नीचे टोपोलॉजी दृश्य में दिखाया गया है:

स्विचओवर

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

 


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. MySQL में अनुक्रमणिका को समझना:भाग एक

  2. My DBA बीमार है - SysAdmins के लिए डेटाबेस फ़ेलओवर युक्तियाँ

  3. मारियाडीबी में UTC_DATE () कैसे काम करता है

  4. मारियाडीबी JSON_CONTAINS () समझाया गया

  5. SysBench का उपयोग करके MySQL और MariaDB के प्रदर्शन को बेंचमार्क कैसे करें