अपाचे प्रेस्टो - स्थापना

यह अध्याय बताएगा कि अपनी मशीन पर प्रेस्टो कैसे स्थापित करें। प्रेस्टो की बुनियादी आवश्यकताओं के माध्यम से चलते हैं,

  • लिनक्स या मैक ओएस
  • जावा संस्करण 8

अब, अपनी मशीन पर प्रेस्टो को स्थापित करने के लिए निम्नलिखित चरणों को जारी रखें।

जावा स्थापना का सत्यापन

उम्मीद है, आपने अभी जावा संस्करण 8 को अपनी मशीन पर पहले ही स्थापित कर लिया है, इसलिए आप केवल निम्नलिखित कमांड का उपयोग करके इसे सत्यापित करते हैं।

$ java -version

यदि जावा आपकी मशीन पर सफलतापूर्वक स्थापित है, तो आप स्थापित जावा का संस्करण देख सकते हैं। यदि जावा स्थापित नहीं है, तो अपनी मशीन पर जावा 8 को स्थापित करने के लिए बाद के चरणों का पालन करें।

JDK डाउनलोड करें। निम्नलिखित लिंक पर जाकर JDK का नवीनतम संस्करण डाउनलोड करें।

http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html

नवीनतम संस्करण JDK 8u 92 है और फ़ाइल "jdk-8u92-linux-x64.tar.gz" है। कृपया अपनी मशीन पर फ़ाइल डाउनलोड करें।

उसके बाद, फ़ाइलों को निकालें और विशिष्ट निर्देशिका में स्थानांतरित करें।

फिर जावा विकल्प सेट करें। अंत में जावा आपकी मशीन पर स्थापित हो जाएगा।

अपाचे प्रेस्टो इंस्टॉलेशन

निम्नलिखित लिंक पर जाकर प्रेस्टो का नवीनतम संस्करण डाउनलोड करें,

https://repo1.maven.org/maven2/com/facebook/presto/presto-server/0.149/

अब आपके मशीन पर "presto-server-0.149.tar.gz" का नवीनतम संस्करण डाउनलोड किया जाएगा।

टार फ़ाइलें निकालें

निकाले tar निम्न कमांड का उपयोग करके फ़ाइल -

$ tar  -zxf  presto-server-0.149.tar.gz 
$ cd presto-server-0.149

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

"डेटा" निर्देशिका बनाएँ

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

$ cd  
$ mkdir data

उस पथ को देखने के लिए जहां यह स्थित है, कमांड "pwd" का उपयोग करें। यह स्थान अगले नोड.प्रोफाइल फ़ाइल में असाइन किया जाएगा।

"आदि" निर्देशिका बनाएँ

निम्नलिखित कोड का उपयोग करके प्रेस्टो इंस्टॉलेशन निर्देशिका के अंदर एक निर्देशिका निर्देशिका बनाएं -

$ cd presto-server-0.149 
$ mkdir etc

यह निर्देशिका कॉन्फ़िगरेशन फ़ाइलों को रखेगी। आइए एक-एक करके हर फाइल बनाते हैं।

नोड गुण

प्रेस्टो नोड गुण फ़ाइल में प्रत्येक नोड के लिए विशिष्ट पर्यावरण कॉन्फ़िगरेशन शामिल है। यह निम्नलिखित कोड का उपयोग करके निर्देशिका (आदि / नोड /properties) के अंदर बनाया गया है -

$ cd etc 
$ vi node.properties  

node.environment = production 
node.id = ffffffff-ffff-ffff-ffff-ffffffffffff 
node.data-dir = /Users/../workspace/Presto

सभी परिवर्तन करने के बाद, फ़ाइल को सहेजें, और टर्मिनल से बाहर निकलें। यहाँnode.data ऊपर बनाई गई डेटा निर्देशिका का स्थान पथ है। node.id प्रत्येक नोड के लिए विशिष्ट पहचानकर्ता का प्रतिनिधित्व करता है।

जेवीएम विन्यास

आदि निर्देशिका (आदि / jvm.config) के अंदर एक फ़ाइल "jvm.config" बनाएँ। इस फ़ाइल में जावा वर्चुअल मशीन लॉन्च करने के लिए उपयोग की जाने वाली कमांड लाइन विकल्पों की एक सूची है।

$ cd etc 
$ vi jvm.config  

-server 
-Xmx16G 
-XX:+UseG1GC 
-XX:G1HeapRegionSize = 32M 
-XX:+UseGCOverheadLimit 
-XX:+ExplicitGCInvokesConcurrent 
-XX:+HeapDumpOnOutOfMemoryError 
-XX:OnOutOfMemoryError = kill -9 %p

सभी परिवर्तन करने के बाद, फ़ाइल को सहेजें, और टर्मिनल से बाहर निकलें।

विन्यास गुण

आदि निर्देशिका (आदि / config.properties) के अंदर एक फ़ाइल "config.properties" बनाएँ। इस फ़ाइल में Presto सर्वर का विन्यास है। यदि आप परीक्षण के लिए एकल मशीन स्थापित कर रहे हैं, तो प्रेस्टो सर्वर निम्नलिखित प्रक्रिया का उपयोग करते हुए केवल समन्वय प्रक्रिया के रूप में कार्य कर सकता है -

$ cd etc 
$ vi config.properties  

coordinator = true 
node-scheduler.include-coordinator = true 
http-server.http.port = 8080 
query.max-memory = 5GB 
query.max-memory-per-node = 1GB 
discovery-server.enabled = true 
discovery.uri = http://localhost:8080

यहाँ,

  • coordinator - मास्टर नोड।

  • node-scheduler.include-coordinator - समन्वयक पर समयबद्धन कार्य की अनुमति देता है।

  • http-server.http.port - HTTP सर्वर के लिए पोर्ट निर्दिष्ट करता है।

  • query.max-memory=5GB - वितरित स्मृति की अधिकतम मात्रा।

  • query.max-memory-per-node=1GB - प्रति नोड मेमोरी की अधिकतम मात्रा।

  • discovery-server.enabled - प्रेस्टो क्लस्टर में सभी नोड्स को खोजने के लिए डिस्कवरी सेवा का उपयोग करता है।

  • discovery.uri - वह डिस्कवरी सर्वर के लिए यूआरआई।

यदि आप कई मशीन प्रेस्टो सर्वर स्थापित कर रहे हैं, तो प्रेस्टो समन्वय और कार्यकर्ता प्रक्रिया दोनों के रूप में कार्य करेगा। कई मशीनों पर प्रेस्टो सर्वर का परीक्षण करने के लिए इस कॉन्फ़िगरेशन सेटिंग का उपयोग करें।

समन्वयक के लिए विन्यास

$ cd etc 
$ vi config.properties  

coordinator = true 
node-scheduler.include-coordinator = false 
http-server.http.port = 8080 
query.max-memory = 50GB 
query.max-memory-per-node = 1GB 
discovery-server.enabled = true 
discovery.uri = http://localhost:8080

वर्कर के लिए कॉन्फ़िगरेशन

$ cd etc 
$ vi config.properties  

coordinator = false 
http-server.http.port = 8080 
query.max-memory = 50GB 
query.max-memory-per-node = 1GB 
discovery.uri = http://localhost:8080

लॉग गुण

आदि निर्देशिका (आदि / log.properties) के अंदर एक फ़ाइल "log.properties" बनाएँ। इस फ़ाइल में नामांकित पदानुक्रम के लिए न्यूनतम लॉग स्तर है। इसे निम्नलिखित कोड का उपयोग करके परिभाषित किया गया है -

$ cd etc 
$ vi log.properties  
com.facebook.presto = INFO

फ़ाइल सहेजें और टर्मिनल से बाहर निकलें। यहां, चार लॉग स्तरों का उपयोग किया जाता है, जैसे डेबग, इन्फो, वॉर्न और एरोर। डिफ़ॉल्ट लॉग स्तर INFO है।

कैटलॉग गुण

निर्देशिका (आदि / कैटलॉग) के अंदर एक निर्देशिका "कैटलॉग" बनाएँ। यह बढ़ते डेटा के लिए उपयोग किया जाएगा। उदाहरण के लिए, बनाएँetc/catalog/jmx.properties निम्नलिखित सामग्री के साथ माउंट करने के लिए jmx connector जेएमएक्स सूची के रूप में -

$ cd etc 
$ mkdir catalog 
$ cd catalog 
$ vi jmx.properties  
connector.name = jmx

प्रेस्टो शुरू करो

प्रेस्टो को निम्नलिखित कमांड का उपयोग करके शुरू किया जा सकता है,

$ bin/launcher start

फिर आप इस के समान प्रतिक्रिया देखेंगे,

Started as 840

प्रेस्टो चलाएं

प्रेस्टो सर्वर लॉन्च करने के लिए, निम्नलिखित कमांड का उपयोग करें -

$ bin/launcher run

प्रेस्टो सर्वर को सफलतापूर्वक लॉन्च करने के बाद, आप "var / log" डायरेक्टरी में लॉग फाइल पा सकते हैं।

  • launcher.log - यह लॉग लॉन्चर द्वारा बनाया गया है और सर्वर के stdout और stderr स्ट्रीम से जुड़ा है।

  • server.log - यह Presto द्वारा उपयोग की जाने वाली मुख्य लॉग फ़ाइल है।

  • http-request.log - सर्वर द्वारा प्राप्त HTTP अनुरोध।

अब तक, आपने अपनी मशीन पर प्रेस्टो कॉन्फ़िगरेशन सेटिंग्स सफलतापूर्वक स्थापित कर ली हैं। आइए प्रेस्टो सीएलआई स्थापित करने के चरणों को जारी रखें।

प्रेस्टो सीएलआई स्थापित करें

प्रेस्टो सीएलआई प्रश्नों को चलाने के लिए एक टर्मिनल-आधारित इंटरैक्टिव शेल प्रदान करता है।

निम्नलिखित लिंक पर जाकर प्रेस्टो सीएलआई डाउनलोड करें,

https://repo1.maven.org/maven2/com/facebook/presto/presto-cli/0.149/

अब "presto-cli-0.149-execable.jar" आपकी मशीन पर स्थापित किया जाएगा।

सीएलआई चलाएं

प्रेस्टो-क्ली डाउनलोड करने के बाद, इसे उस स्थान पर कॉपी करें जिसे आप इसे चलाना चाहते हैं। यह स्थान किसी भी नोड हो सकता है जिसमें समन्वयक के लिए नेटवर्क पहुंच है। सबसे पहले जार फाइल का नाम प्रेस्टो में बदलें। फिर इसके साथ निष्पादन योग्य बनाएंchmod + x निम्नलिखित कोड का उपयोग कर कमांड -

$ mv presto-cli-0.149-executable.jar presto  
$ chmod +x presto

अब निम्नलिखित आदेश का उपयोग करके CLI निष्पादित करें,

./presto --server localhost:8080 --catalog jmx --schema default  
Here jmx(Java Management Extension) refers to catalog and default referes to schema.

आप निम्न प्रतिक्रिया देखेंगे,

presto:default>

अब अपने टर्मिनल पर "jps" कमांड टाइप करें और आप चल रहे डेमोंस को देखेंगे।

प्रेस्टो बंद करो

सभी निष्पादन किए जाने के बाद, आप निम्नलिखित कमांड का उपयोग करके प्रेस्टो सर्वर को रोक सकते हैं -

$ bin/launcher stop