CouchDB - त्वरित गाइड
डेटाबेस प्रबंधन प्रणाली डेटा के भंडारण और पुनर्प्राप्ति के लिए तंत्र प्रदान करती है। आरडीबीएमएस (रिलेशनल डेटाबेस मैनेजमेंट सिस्टम), ओएलएपी (ऑनलाइन एनालिटिकल प्रोसेसिंग सिस्टम) और नोएसक्यूएल जैसे तीन मुख्य प्रकार के डेटाबेस मैनेजमेंट सिस्टम हैं।
आरडीबीएमएस
RDBMS का संबंध रिलेशनल डेटाबेस मैनेजमेंट सिस्टम से है। RDBMS SQL का आधार है, और सभी आधुनिक डेटाबेस सिस्टम जैसे MS SQL Server, IBM DB2, Oracle, MySQL और Microsoft Access के लिए।
एक रिलेशनल डेटाबेस मैनेजमेंट सिस्टम (RDBMS) एक डेटाबेस मैनेजमेंट सिस्टम (DBMS) है जो कि EF Codd द्वारा शुरू किए गए रिलेशनल मॉडल पर आधारित है।
RDBMS में डेटा को डेटाबेस ऑब्जेक्ट्स में संग्रहीत किया जाता है जिसे कहा जाता है tables। तालिका संबंधित डेटा प्रविष्टियों का एक संग्रह है और इसमें कॉलम और पंक्तियाँ हैं। यह केवल संरचित डेटा संग्रहीत करता है।
OLAP
ऑनलाइन एनालिटिकल प्रोसेसिंग सर्वर (OLAP) बहुआयामी डेटा मॉडल पर आधारित है। यह प्रबंधकों और विश्लेषकों को सूचनाओं की तेज, सुसंगत, और सूचना के लिए इंटरैक्टिव पहुंच के माध्यम से जानकारी प्राप्त करने की अनुमति देता है।
NoSQL डेटाबेस
एक NoSQL डेटाबेस (कभी-कभी केवल एसक्यूएल के रूप में कहा जाता है) एक डेटाबेस है जो संबंधपरक डेटाबेस में उपयोग किए गए सारणीबद्ध संबंधों के अलावा डेटा को संग्रहीत और पुनर्प्राप्त करने के लिए एक तंत्र प्रदान करता है। ये डेटाबेस स्कीमा-रहित हैं, आसान प्रतिकृति का समर्थन करते हैं, सरल एपीआई हैं, अंततः सुसंगत हैं, और बड़ी मात्रा में डेटा (बड़ा डेटा) संभाल सकते हैं।
NoSQL डेटाबेस का प्राथमिक उद्देश्य निम्नलिखित है -
- डिजाइन की सादगी,
- क्षैतिज स्केलिंग, और
- उपलब्धता पर महीन नियंत्रण।
NoSQL डेटाबेस रिलेशनल डेटाबेस की तुलना में विभिन्न डेटा संरचनाओं का उपयोग करते हैं। यह NoSQL में कुछ ऑपरेशन तेज करता है। किसी दिए गए NoSQL डेटाबेस की उपयुक्तता उस समस्या पर निर्भर करती है जो इसे हल करना चाहिए। ये डेटाबेस संरचित डेटा और अनस्ट्रक्चर्ड डेटा जैसे ऑडियो फ़ाइलों, वीडियो फ़ाइलों, दस्तावेज़ों आदि को संग्रहीत करते हैं। इन NoSQL डेटाबेस को तीन प्रकारों में वर्गीकृत किया गया है और इन्हें नीचे समझाया गया है।
Key-value Store- ये डेटाबेस कुंजी-मूल्य जोड़े में डेटा संग्रहीत करने के लिए डिज़ाइन किए गए हैं और इन डेटाबेस में कोई स्कीमा नहीं होगा। इन डेटाबेस में, प्रत्येक डेटा मान में एक अनुक्रमित कुंजी और उस कुंजी के लिए एक मान होता है।
उदाहरण - बर्कलेबीडीबी, कैसेंड्रा, डायनमोडीबी, रीक।
Column Store- इन डेटाबेस में, डेटा के स्तंभों में वर्गीकृत कोशिकाओं में डेटा संग्रहीत किया जाता है, और इन स्तंभों को आगे कॉलम परिवारों में वर्गीकृत किया जाता है। इन कॉलम परिवारों में किसी भी संख्या में कॉलम हो सकते हैं।
उदाहरण - BigTable, HBase, और HyperTable।
Document Store- ये कुंजी-मूल्य स्टोर के मूल विचार पर विकसित डेटाबेस हैं जहां "दस्तावेजों" में अधिक जटिल डेटा होते हैं। यहां, प्रत्येक दस्तावेज़ को एक अद्वितीय कुंजी दी गई है, जिसका उपयोग दस्तावेज़ को पुनः प्राप्त करने के लिए किया जाता है। इन्हें दस्तावेज़-उन्मुख जानकारी संग्रहीत करने, पुनर्प्राप्त करने और प्रबंधित करने के लिए डिज़ाइन किया गया है, जिसे अर्ध-संरचित डेटा के रूप में भी जाना जाता है।
उदाहरण - काउचडीबी और मोंगोबडी।
CouchDB क्या है?
CouchDB अपाचे सॉफ्टवेयर फाउंडेशन द्वारा विकसित एक खुला स्रोत डेटाबेस है। फोकस वेब का उपयोग करते हुए, उपयोग में आसानी पर है। यह एक NoSQL दस्तावेज़ स्टोर डेटाबेस है।
यह JSON का उपयोग डेटा (दस्तावेज़), जावा स्क्रिप्ट को अपनी क्वेरी भाषा के रूप में दस्तावेज़ों को बदलने के लिए करता है, दस्तावेज़ों तक पहुंचने के लिए एपीआई के लिए http प्रोटोकॉल, वेब ब्राउज़र के साथ सूचकांकों को क्वेरी करता है। यह 2005 में जारी एक मल्टी मास्टर एप्लीकेशन है और यह 2008 में एक अपाचे प्रोजेक्ट बन गया।
CouchDB क्यों?
CouchDB में HTTP- आधारित REST API है, जो डेटाबेस से आसानी से संवाद करने में मदद करता है। और HTTP संसाधनों और विधियों (GET, PUT, DELETE) की सरल संरचना को समझना और उपयोग करना आसान है।
जैसा कि हम लचीले दस्तावेज़-आधारित संरचना में डेटा संग्रहीत करते हैं, डेटा की संरचना के बारे में चिंता करने की कोई आवश्यकता नहीं है।
उपयोगकर्ताओं को शक्तिशाली डेटा मैपिंग प्रदान की जाती है, जो सूचना को क्वेरी, संयोजन और फ़िल्टर करने की अनुमति देता है।
CouchDB आसान उपयोग प्रतिकृति प्रदान करता है, जिसके उपयोग से आप डेटाबेस और मशीनों के बीच डेटा को कॉपी, शेयर और सिंक्रनाइज़ कर सकते हैं।
डेटा मॉडल
CouchDB में डेटाबेस सबसे बाहरी डेटा संरचना / कंटेनर है।
प्रत्येक डेटाबेस स्वतंत्र दस्तावेजों का एक संग्रह है।
प्रत्येक दस्तावेज़ अपने स्वयं के डेटा और स्व-निहित स्कीमा को बनाए रखता है।
दस्तावेज़ मेटाडेटा में संशोधन की जानकारी शामिल है, जो डेटाबेस के डिस्कनेक्ट होने के दौरान अंतर को मर्ज करने के लिए संभव बनाता है।
CouchDB लेखन के दौरान डेटाबेस फ़ील्ड को लॉक करने की आवश्यकता से बचने के लिए बहु संस्करण संगामिति नियंत्रण लागू करता है।
CouchDB की विशेषताएं: सामग्री को कम करें
दस्तावेज़ संग्रहण
CouchDB एक दस्तावेज़ संग्रहण NoSQL डेटाबेस है। यह अद्वितीय नामों के साथ दस्तावेज़ों को संग्रहीत करने की सुविधा प्रदान करता है, और यह डेटाबेस दस्तावेज़ों को पढ़ने और अद्यतन करने (जोड़ने, संपादित करने, हटाने) के लिए RESTful HTTP API नामक एक एपीआई भी प्रदान करता है।
CouchDB में, दस्तावेज़ डेटा की प्राथमिक इकाई हैं और इनमें मेटाडेटा भी शामिल है। दस्तावेज़ फ़ील्ड को विशिष्ट रूप से नाम दिया गया है और इसमें भिन्न प्रकार (पाठ, संख्या, बूलियन, सूचियाँ, आदि) के मान हैं, और पाठ आकार या तत्व गणना की कोई निर्धारित सीमा नहीं है।
दस्तावेज़ अपडेट (जोड़ें, संपादित करें, हटाएं) एटोमिसिटी का पालन करें, अर्थात, वे पूरी तरह से सहेजे जाएंगे या बिल्कुल नहीं सहेजे जाएंगे। डेटाबेस में आंशिक रूप से सहेजे गए या संपादित दस्तावेज़ नहीं होंगे।
Json दस्तावेज़ संरचना
{
"field" : "value",
"field" : "value",
"field" : "value",
}
ACID गुण
CouchDB में इसकी एक विशेषता के रूप में ACID गुण हैं।
संगति - जब CouchDB में डेटा एक बार प्रतिबद्ध था, तो यह डेटा संशोधित या अधिलेखित नहीं किया जाएगा। इस प्रकार, CouchDB यह सुनिश्चित करता है कि डेटाबेस फ़ाइल हमेशा एक सुसंगत स्थिति में होगी।
CouchDB रीड्स द्वारा एक मल्टी-वर्ज़न कॉन्सिरेन्सी कंट्रोल (MVCC) मॉडल का उपयोग किया जाता है, जिसके कारण क्लाइंट को रीड ऑपरेशन के आरंभ से अंत तक डेटाबेस का एक सुसंगत स्नैपशॉट दिखाई देगा।
जब भी कोई दस्तावेज़ अपडेट किया जाता है, CouchDB डेटा को डिस्क में फ्लश कर देता है, और फ़ाइल के पहले 4k को बनाने के लिए अद्यतन डेटाबेस हेडर को लगातार दो और समान चंक्स में लिखा जाता है, और फिर सिंक्रोनाइज़ डिस्क में फ्लश किया जाता है। फ्लश के दौरान आंशिक अपडेट को छोड़ दिया जाएगा।
यदि शीर्षलेख करते समय विफलता हुई है, तो पिछले समान हेडर की एक जीवित प्रतिलिपि बनी रहेगी, जो पहले से किए गए सभी डेटा की सुसंगतता सुनिश्चित करती है। हेडर क्षेत्र को छोड़कर, क्रैश या बिजली की विफलता के बाद स्थिरता चेक या फिक्स-अप कभी भी आवश्यक नहीं होते हैं।
संघनन
जब भी डेटाबेस फ़ाइल में स्थान निश्चित सीमा से ऊपर बर्बाद हो गया, सभी सक्रिय डेटा को एक नई फ़ाइल में कॉपी (क्लोन) किया जाएगा। जब नकल की प्रक्रिया पूरी तरह से हो जाएगी, तो पुरानी फाइल को छोड़ दिया जाएगा। यह सब संघनन प्रक्रिया द्वारा किया जाता है। कंपटीशन के दौरान डेटाबेस ऑनलाइन रहता है और सभी अपडेट और रीड को सफलतापूर्वक पूरा करने की अनुमति होती है।
विचारों
काउचडीबी में डेटा अर्ध-संरचित दस्तावेजों में संग्रहीत होता है जो व्यक्तिगत अंतर्निहित संरचनाओं के साथ लचीले होते हैं, लेकिन यह डेटा भंडारण और साझा करने के लिए एक सरल दस्तावेज़ मॉडल है। यदि हम अपना डेटा कई अलग-अलग तरीकों से देखना चाहते हैं, तो हमें उन डेटा को फ़िल्टर करने, व्यवस्थित करने और रिपोर्ट करने का एक तरीका चाहिए, जो तालिकाओं में विघटित नहीं हुए हैं।
इस समस्या को हल करने के लिए, CouchDB एक दृश्य मॉडल प्रदान करता है। दृश्य डेटाबेस में दस्तावेज़ों को एकत्र करने और रिपोर्ट करने की विधि है, और डेटाबेस दस्तावेज़ों को एकत्र करने, शामिल करने और रिपोर्ट करने की माँग पर बनाए गए हैं। क्योंकि विचार गतिशील रूप से निर्मित होते हैं और अंतर्निहित दस्तावेज़ को प्रभावित नहीं करते हैं, आपके पास एक ही डेटा के कई अलग-अलग दृश्य प्रतिनिधित्व हो सकते हैं जैसे आप चाहते हैं।
इतिहास
- CouchDB Erlang प्रोग्रामिंग भाषा में लिखा गया था।
- इसकी शुरुआत 2005 में डेमियन काट्ज ने की थी।
- CouchDB 2008 में एक अपाचे परियोजना बन गई।
CouchDB का वर्तमान संस्करण 1.61 है।
यह अध्याय आपको सिखाता है कि विंडोज़ में और साथ ही लिनक्स सिस्टम में CouchDB कैसे स्थापित किया जाए।
विंडोज में CouchDB स्थापित करना
CouchDB डाउनलोड करें
CouchDB के लिए आधिकारिक वेबसाइट है https://couchdb.apache.org। यदि आप दिए गए लिंक पर क्लिक करते हैं, तो आप नीचे दिखाए गए अनुसार CouchDB आधिकारिक वेबसाइट का होम पेज प्राप्त कर सकते हैं।
यदि आप डाउनलोड बटन पर क्लिक करते हैं जो एक पृष्ठ पर ले जाएगा जहां विभिन्न स्वरूपों में CouchDB के डाउनलोड लिंक दिए गए हैं। निम्नलिखित स्नैपशॉट समान दिखाता है।
विंडोज़ सिस्टम के लिए डाउनलोड लिंक चुनें और अपना डाउनलोड शुरू करने के लिए दिए गए दर्पणों में से एक का चयन करें।
CouchDB स्थापित करना
CouchDB सेटअप सिस्टम के नाम से आपके सिस्टम में डाउनलोड हो जाएगा setup-couchdb-1.6.1_R16B02.exe. सेटअप फ़ाइल चलाएँ और स्थापना के साथ आगे बढ़ें।
स्थापना के बाद, निम्न पर जाकर CouchDB का अंतर्निहित वेब इंटरफ़ेस खोलें link: http://127.0.0.1:5984/. यदि सब कुछ ठीक रहा, तो यह आपको एक वेब पेज देगा, जिसमें निम्न आउटपुट हैं।
{
"couchdb":"Welcome","uuid":"c8d48ac61bb497f4692b346e0f400d60",
"version":"1.6.1",
"vendor":{
"version":"1.6.1","name":"The Apache Software Foundation"
}
}
आप निम्नलिखित url का उपयोग करके CouchDB वेब इंटरफ़ेस के साथ बातचीत कर सकते हैं -
http://127.0.0.1:5984/_utils/
यह आपको Futon का इंडेक्स पेज दिखाता है, जो CouchDB का वेब इंटरफेस है।
लिनक्स सिस्टम में CouchDB स्थापित करना
कई लिनक्स फ्लेवर्ड सिस्टम के लिए, वे आंतरिक रूप से CouchDB प्रदान करते हैं। इस CouchDB स्थापित करने के लिए निर्देशों का पालन करें।
उबंटू और डेबियन पर आप उपयोग कर सकते हैं -
sudo aptitude install couchdb
Gentoo Linux पर CouchDB ebuild उपलब्ध है -
sudo emerge couchdb
यदि आपके लिनक्स सिस्टम में CouchDB नहीं है, तो CouchDB और उसकी निर्भरता को स्थापित करने के लिए अगले अनुभाग का पालन करें।
CouchDB निर्भरता स्थापित करना
निम्नलिखित निर्भरता की सूची है जो आपके सिस्टम में CouchDB प्राप्त करने के लिए स्थापित की जानी है
- एर्लांग ओटीपी
- ICU
- OpenSSL
- मोज़िला स्पाइडरमोनी
- GNU मेक
- GNU संकलक संग्रह
- libcurl
- help2man
- डॉक्स के लिए पायथन
- पायथन स्फिंक्स
इन निर्भरताओं को स्थापित करने के लिए, टर्मिनल में निम्न कमांड टाइप करें। यहां हम सेंटोस 6.5 का उपयोग कर रहे हैं और निम्नलिखित कमांड सेंटोस 6.5 के लिए आवश्यक सॉफ्टवेयर्स स्थापित करेंगे।
$sudo yum install autoconf
$sudo yum install autoconf-archive
$sudo yum install automake
$sudo yum install curl-devel
$sudo yum install erlang-asn1
$sudo yum install erlang-erts
$sudo yum install erlang-eunit
$sudo yum install erlang-os_mon
$sudo yum install erlang-xmerl
$sudo yum install help2man
$sudo yum install js-devel
$sudo yum install libicu-devel
$sudo yum install libtool
$sudo yum install perl-Test-Harness
Note −इन सभी आदेशों के लिए आपको sudo का उपयोग करने की आवश्यकता है। निम्न प्रक्रिया एक सामान्य उपयोगकर्ता को एक sudoer में बदल देती है।
व्यवस्थापक उपयोगकर्ता के रूप में लॉगिन करें
खुला हुआ sudo निम्न कमांड का उपयोग करके फ़ाइल -
visudo
- फिर अपने मौजूदा उपयोगकर्ता को sudoer विशेषाधिकार देने के लिए नीचे दिखाए अनुसार संपादित करें -
Hadoop All=(All) All , and press esc : x to write the changes to the file.
अपने सिस्टम में सभी निर्भरताएँ डाउनलोड करने के बाद, दिए गए निर्देशों का पालन करते हुए CouchDB डाउनलोड करें।
CouchDB डाउनलोड कर रहा है
Apache सॉफ्टवेयर फाउंडेशन CouchDB के लिए पूर्ण .tar फ़ाइल प्रदान नहीं करेगा, इसलिए आपको इसे स्रोत से इंस्टॉल करना होगा।
CouchDB स्थापित करने के लिए एक नई निर्देशिका बनाएं, ऐसी बनाई गई निर्देशिका में ब्राउज़ करें और निम्नलिखित आदेशों को निष्पादित करके CouchDB स्रोत डाउनलोड करें -
$ cd
$ mkdir CouchDB
$ cd CouchDB/
$ wget
http://www.google.com/url?q=http%3A%2F%2Fwww.apache.org%2Fdist%2Fcouchdb%2Fsource%2F1.6.1%2Fapache-couchdb-1.6.1.tar.gz
यह आपके सिस्टम में CouchDB स्रोत फ़ाइल डाउनलोड करेगा। अब अनजिप करेंapache-couchdb-1.6.1.tar.gz जैसा की नीचे दिखाया गया।
$ tar zxvf apache-couchdb-1.6.1.tar.gz
CouchDB कॉन्फ़िगर करना
CouchDB कॉन्फ़िगर करने के लिए, निम्नलिखित करें -
- CouchDB के होम फ़ोल्डर में ब्राउज़ करें।
- सुपरयुसर के रूप में लॉगिन करें।
- निम्न का उपयोग करके कॉन्फ़िगर करें ./configure प्रॉम्प्ट -
$ cd apache-couchdb-1.6.1
$ su
Password:
# ./configure --with-erlang=/usr/lib64/erlang/usr/include/
यह आपको नीचे दिए गए आउटपुट के समान देता है जो कि एक समापन पंक्ति के साथ नीचे दिखाया गया है - You have configured Apache CouchDB, time to relax।
# ./configure --with-erlang=/usr/lib64/erlang/usr/include/
checking for a BSD-compatible install... /usr/bin/install -c
checking whether build environment is sane... yes
checking for a thread-safe mkdir -p... /bin/mkdir -p
checking for gawk... gawk
checking whether make sets $(MAKE)... yes
checking how to create a ustar tar archive... gnutar
………………………………………………………..
……………………….
config.status: creating var/Makefile
config.status: creating config.h
config.status: config.h is unchanged
config.status: creating src/snappy/google-snappy/config.h
config.status: src/snappy/google-snappy/config.h is unchanged
config.status: executing depfiles commands
config.status: executing libtool commands
You have configured Apache CouchDB, time to relax.
Run `make && sudo make install' to install.
CouchDB स्थापित करना
अब अपने सिस्टम में CouchDB स्थापित करने के लिए निम्न कमांड टाइप करें।
# make && sudo make install
यह आपके सिस्टम में CouchDB एक समापन रेखा के साथ कहता है - You have installed Apache CouchDB, time to relax।
CouchDB शुरू
CouchDB शुरू करने के लिए, CouchDB होम फ़ोल्डर में ब्राउज़ करें और निम्न कमांड का उपयोग करें -
$ cd apache-couchdb-1.6.1
$ cd etc
$ couchdb start
यह निम्नलिखित आउटपुट देते हुए काउचबीडी शुरू करता है: -
Apache CouchDB 1.6.1 (LogLevel=info) is starting.
Apache CouchDB has started. Time to relax.
[info] [lt;0.31.0gt;] Apache CouchDB has started on http://127.0.0.1:5984/
[info] [lt;0.112.0gt;] 127.0.0.1 - - GET / 200
[info] [lt;0.112.0gt;] 127.0.0.1 - - GET /favicon.ico 200
सत्यापन
चूंकि CouchDB एक वेब इंटरफ़ेस है, इसलिए ब्राउज़र में निम्न होमपेज यूआरएल टाइप करने का प्रयास करें।
http://127.0.0.1:5984/
यह निम्नलिखित उत्पादन का उत्पादन करता है -
{
"couchdb":"Welcome",
"uuid":"8f0d59acd0e179f5e9f0075fa1f5e804",
"version":"1.6.1",
"vendor":{
"name":"The Apache Software Foundation",
"version":"1.6.1"
}
}
CURL उपयोगिता
CURL उपयोगिता CouchDB के साथ संवाद करने का एक तरीका है।
यह समर्थित प्रोटोकॉल (HTTP, HTTPS, FTP, FTPS, TFTP, DICT, TELNET, LDAP या FILE) में से किसी एक का उपयोग करके या सर्वर से डेटा ट्रांसफर करने का एक उपकरण है। कमांड को उपयोगकर्ता के इंटरैक्शन के बिना काम करने के लिए डिज़ाइन किया गया है। CURL प्रॉक्सी सपोर्ट, यूजर ऑथेंटिकेशन, ftp अपलोड, HTTP पोस्ट, एसएसएल (https :) कनेक्शन, कुकीज, फाइल ट्रांसफर रिज्यूम और बहुत कुछ उपयोगी ट्रिक्स का एक बस लोड प्रदान करता है।
CURL उपयोगिता ऑपरेटिंग सिस्टम जैसे UNIX, Linux, Mac OS X और Windows में उपलब्ध है। यह एक कमांड लाइन उपयोगिता है जिसका उपयोग करके उपयोगकर्ता कमांड लाइन से सीधे HTTP प्रोटोकॉल का उपयोग कर सकता है। यह अध्याय आपको सिखाता है कि CURL उपयोगिता का उपयोग कैसे करें।
CURL उपयोगिता का उपयोग करना
आप नीचे दिखाए अनुसार वेबसाइट के पते के बाद केवल CURL टाइप करके किसी भी वेबसाइट तक पहुँच सकते हैं -
curl www.tutorialspoint.com/
डिफ़ॉल्ट रूप से, CURL उपयोगिता अनुरोधित पृष्ठ का स्रोत कोड लौटाती है। यह इस कोड को टर्मिनल विंडो पर प्रदर्शित करता है।
CURL उपयोगिता विकल्प
CURL उपयोगिता के साथ काम करने के लिए विभिन्न विकल्प प्रदान करता है, और आप उन्हें cURL उपयोगिता सहायता में देख सकते हैं।
निम्नलिखित कोड cURL सहायता के कुछ हिस्से को दिखाता है।
$ curl --help
Usage: curl [options...] <url>
Options: (H) means HTTP/HTTPS only, (F) means FTP only
--anyauth Pick "any" authentication method (H)
-a/--append Append to target file when uploading (F/SFTP)
--basic Use HTTP Basic Authentication (H)
--cacert <file> CA certificate to verify peer against (SSL)
-d/--data <data> HTTP POST data (H)
--data-ascii <data> HTTP POST ASCII data (H)
--data-binary <data> HTTP POST binary data (H)
--data-urlencode <name=data/name@filename> HTTP POST data
urlencoded (H)
--delegation STRING GSS-API delegation permission
--digest Use HTTP Digest Authentication (H)
--disable-eprt Inhibit using EPRT or LPRT (F)
--disable-epsv Inhibit using EPSV (F)
-F/--form <name=content> Specify HTTP multipart POST data (H)
--form-string <name=string> Specify HTTP multipart POST data (H)
--ftp-account <data> Account data to send when requested by server
(F)
--ftp-alternative-to-user <cmd> String to replace "USER [name]" (F)
--ftp-create-dirs Create the remote dirs if not present (F)
--ftp-method [multi cwd/no cwd/single cwd] Control CWD usage (F)
--ftp-pasv Use PASV/EPSV instead of PORT (F)
-G/--get Send the -d data with a HTTP GET (H)
-H/--header <line> Custom header to pass to server (H)
-I/--head Show document info only
-h/--help This help text
--hostpubmd5 <md5> Hex encoded MD5 string of the host public key.
(SSH)
-0/--http1.0 Use HTTP 1.0 (H)
--ignore-content-length Ignore the HTTP Content-Length header
-i/--include Include protocol headers in the output (H/F)
-M/--manual Display the full manual
-o/--output <file> Write output to <file> instead of stdout
--pass <pass> Pass phrase for the private key (SSL/SSH)
--post301 Do not switch to GET after following a 301
redirect (H)
--post302 Do not switch to GET after following a 302
redirect (H)
-O/--remote-name Write output to a file named as the remote file
--remote-name-all Use the remote file name for all URLs
-R/--remote-time Set the remote file's time on the local output
-X/--request <command> Specify request command to use
--retry <num> Retry request <num> times if transient problems
occur
--retry-delay <seconds> When retrying, wait this many seconds
between each
--retry-max-time <seconds> Retry only within this period
-T/--upload-file <file> Transfer <file> to remote site
--url <URL> Set URL to work with
-B/--use-ascii Use ASCII/text transfer
CouchDB के साथ संचार करते समय, cURL उपयोगिता के कुछ विकल्पों का बड़े पैमाने पर उपयोग किया गया था। निम्नलिखित CURL उपयोगिता के कुछ महत्वपूर्ण विकल्पों का संक्षिप्त विवरण निम्नलिखित हैं, जिनमें CouchDB द्वारा उपयोग किया गया है।
-X झंडा
(HTTP) HTTP सर्वर से संचार करते समय उपयोग की जाने वाली कस्टम अनुरोध विधि निर्दिष्ट करता है। निर्दिष्ट अनुरोध का उपयोग विधि के बजाय किया जाता है अन्यथा उपयोग किया जाता है (जो कि जीईटी में चूक करता है)। विवरण और स्पष्टीकरण के लिए HTTP 1.1 विनिर्देश पढ़ें।
(FTP) FTP के साथ फ़ाइल सूचियाँ करते समय LIST के बजाय उपयोग करने के लिए एक कस्टम FTP आदेश निर्दिष्ट करता है।
एच
(HTTP) वेब पेज प्राप्त करते समय अतिरिक्त हेडर का उपयोग किया जाता है। ध्यान दें कि यदि आप एक कस्टम हेडर जोड़ते हैं जिसका नाम उसी में से एक है जिसका आंतरिक रूप से उपयोग किया जाएगा, तो आपके बाह्य सेट हेडर का उपयोग आंतरिक के बजाय किया जाएगा। यह आपको CURL से सामान्य रूप से भी पेचीदा काम करने की अनुमति देगा। आपको आंतरिक रूप से सेट हेडर को पूरी तरह से जानने के बिना प्रतिस्थापित नहीं करना चाहिए कि आप क्या कर रहे हैं। बृहदान्त्र के दाईं ओर सामग्री के बिना एक के साथ एक आंतरिक हेडर की जगह, उस हेडर को दिखने से रोक देगा।
CURL आश्वस्त करता है कि आपके द्वारा जोड़े गए प्रत्येक शीर्षलेख को पंक्ति मार्कर के उचित अंत के साथ जोड़ा / प्रतिस्थापित किया जाएगा। न तो आपको हेडर कंटेंट के एक भाग के रूप में जोड़ना चाहिए और न ही नई चीज़ों को जोड़ना चाहिए और न ही अव्यवस्थित चीज़ों में वापसी करनी चाहिए।
उपयोगकर्ता-एजेंट और -e / - संदर्भित विकल्प भी देखें।
कई हेडर जोड़ने / बदलने / हटाने के लिए इस विकल्प का कई बार उपयोग किया जा सकता है।
-d झंडा
CURL के इस झंडे का उपयोग करके, आप सर्वर पर HTTP POST अनुरोध के साथ डेटा भेज सकते हैं, जैसे कि यह उपयोगकर्ता द्वारा फॉर्म में भरा गया था और प्रस्तुत किया गया था।
Example
मान लीजिए कि एक वेबसाइट है और आप उसमें लॉगिन करना चाहते हैं या वेबसाइट पर कुछ डेटा भेजना चाहते हैं, जो कि cURL यूटिलिटी के झंडे का उपयोग कर रहा है जैसा कि नीचे दिखाया गया है।
curl -X PUT http://mywebsite.com/login.html -d userid=001 -d password=tutorialspoint
यह एक पोस्ट का हिस्सा भेजता है जो दिखता है "userid=001&password=tutorialspoint"। इसी तरह आप दस्तावेज़ों (JSON) को -d ध्वज का उपयोग करके भी भेज सकते हैं।
-उ झंडा
इस ध्वज का उपयोग करते हुए, cURL फ़ाइल में अनुरोध का आउटपुट लिखता है।
Example
निम्नलिखित उदाहरण के उपयोग को दर्शाता है -o CURL उपयोगिता का ध्वज।
$ curl -o example.html www.tutorialspoint.com/index.htm
% Total % Received % Xferd Average Speed Time Time Time Current
Dload Upload Total Spent Left Speed
100 81193 0 81193 0 0 48168 0 --:--:-- 0:00:01 --:--:--
58077
यह tutorialspoint.com के मुखपृष्ठ का स्रोत कोड प्राप्त करता है, example.com नामक फ़ाइल बनाता है और example.html नामक फ़ाइल में आउटपुट बचाता है।
निम्नलिखित का स्नैपशॉट है example.html।
-O
यह ध्वज के समान है –o, इस अंतर के साथ एकमात्र अंतर यह है कि अनुरोधित url के समान नाम वाली एक नई फ़ाइल, और अनुरोधित url का स्रोत कोड इसे कॉपी किया जाएगा।
Example
निम्नलिखित उदाहरण के उपयोग को दर्शाता है -O CURL उपयोगिता का ध्वज।
$ curl -O www.tutorialspoint.com/index.htm
% Total % Received % Xferd Average Speed Time Time Time Current
Dload Upload Total Spent Left
Speed
100 81285 0 81285 0 0 49794 0 --:--:-- 0:00:01 --:--:--
60077
यह index.htm नाम से एक नई फाइल बनाता है और इसमें tutorialspoint.com के इंडेक्स पेज के सोर्स कोड को सेव करता है।
हैलो काउचडीबी
आप CouchDB इंस्टाल किए गए GET अनुरोध को भेजकर CouchDB के होमपेज पर पहुंच सकते हैं। सबसे पहले सुनिश्चित करें कि आपने अपने लिनक्स वातावरण में CouchDB स्थापित किया है और यह सफलतापूर्वक चल रहा है, और फिर CouchDB उदाहरण के लिए एक अनुरोध भेजने के लिए निम्न सिंटैक्स का उपयोग करें।
curl http://127.0.0.1:5984/
यह आपको एक JSON दस्तावेज़ देता है जैसा कि नीचे दिखाया गया है जहां CouchDB संस्करण संख्या, विक्रेता का नाम और सॉफ़्टवेयर के संस्करण जैसे विवरण निर्दिष्ट करता है।
$ curl http://127.0.0.1:5984/
{
"couchdb" : "Welcome",
"uuid" : "8f0d59acd0e179f5e9f0075fa1f5e804",
"version" : "1.6.1",
"vendor" : {
"name":"The Apache Software Foundation",
"version":"1.6.1"
}
}
सभी डेटाबेस की सूची
आप स्ट्रिंग के साथ अनुरोध प्राप्त करके, सभी डेटाबेस की सूची प्राप्त कर सकते हैं "_all_dbs string "। CouchDB में सभी डेटाबेस की सूची प्राप्त करने के लिए सिंटैक्स निम्नलिखित है।
curl -X GET http://127.0.0.1:5984/_all_dbs
यह आपको नीचे दिखाए गए अनुसार CouchDB में सभी डेटाबेस की सूची देता है।
$ curl -X GET http://127.0.0.1:5984/_all_dbs
[ "_replicator" , "_users" ]
एक डेटाबेस बनाना
आप निम्नलिखित सिंटैक्स का उपयोग करके PUT हैडर के साथ CURL का उपयोग करके CouchDB में एक डेटाबेस बना सकते हैं -
$ curl -X PUT http://127.0.0.1:5984/database_name
उदाहरण
एक उदाहरण के रूप में, ऊपर दिए गए सिंटैक्स का उपयोग करके नाम के साथ एक डेटाबेस बनाएं my_database जैसा की नीचे दिखाया गया।
$ curl -X PUT http://127.0.0.1:5984/my_database
{"ok":true}
सत्यापन
सत्यापित करें कि क्या डेटाबेस बनाया गया है, नीचे दिखाए गए सभी डेटाबेसों को सूचीबद्ध करके। यहां आप नए बनाए गए डेटाबेस का नाम देख सकते हैं,"my_database" सूची मैं
$ curl -X GET http://127.0.0.1:5984/_all_dbs
[ "_replicator " , "_users" , "my_database" ]
डेटाबेस जानकारी प्राप्त करना
आप डेटाबेस नाम के साथ प्राप्त अनुरोध का उपयोग करके डेटाबेस के बारे में जानकारी प्राप्त कर सकते हैं। डेटाबेस की जानकारी प्राप्त करने के लिए सिंटैक्स निम्नलिखित है।
उदाहरण
एक उदाहरण के रूप में हमें डेटाबेस नाम की जानकारी मिलती है my_databaseजैसा की नीचे दिखाया गया। यहां आप प्रतिक्रिया के रूप में अपने डेटाबेस के बारे में जानकारी प्राप्त कर सकते हैं।
$ curl -X GET http://127.0.0.1:5984/my_database
{
"db_name" : "my_database",
"doc_count" : 0,
"doc_del_count" : 0,
"update_seq" : 0,
"purge_seq" : 0,
"compact_running" : false,
"disk_size" : 79,
"data_size" : 0,
"instance_start_time" : "1423628520835029",
"disk_format_version" : 6,
"committed_update_seq" : 0
}
फुटोन
Futon CouchDB का बिल्ट-इन, वेब आधारित, प्रशासन इंटरफ़ेस है। यह एक सरल चित्रमय इंटरफ़ेस प्रदान करता है, जिसके उपयोग से आप CouchDB के साथ बातचीत कर सकते हैं। यह एक भोली इंटरफ़ेस है और यह CouchDB सभी सुविधाओं के लिए पूर्ण पहुँच प्रदान करता है। निम्नलिखित उन सुविधाओं की सूची है -
Databases −- डेटाबेस बनाता है।
- डेटाबेस को नष्ट कर देता है।
- दस्तावेज बनाता है।
- दस्तावेज़ अद्यतन करता है।
- दस्तावेजों को संपादित करता है।
- दस्तावेज़ हटाता है।
Futon शुरू
सुनिश्चित करें कि CouchDB चल रहा है और फिर ब्राउज़र में निम्न यूआरएल खोलें -
http://127.0.0.1:5984/_utils/
यदि आप इस url को खोलते हैं, तो यह नीचे दिखाए गए अनुसार Futon होम पेज प्रदर्शित करता है -
इस पृष्ठ के बाईं ओर आप CouchDB के सभी वर्तमान डेटाबेसों की सूची देख सकते हैं। इस दृष्टांत में, हमारे पास एक डेटाबेस है जिसका नाम हैmy_database, सिस्टम परिभाषित डेटाबेस के साथ _replicator तथा _user।
दाहिने हाथ की ओर आप निम्नलिखित देख सकते हैं -
Tools - इस सेक्शन में आप पा सकते हैं Configuration CouchDB को कॉन्फ़िगर करने के लिए, Replicator प्रतिकृति प्रदर्शन करने के लिए, और Status CouchDB और CouchDB पर किए गए हाल के संशोधनों की स्थिति को सत्यापित करने के लिए।
Documentation - इस खंड में CouchDB के हाल के संस्करण के लिए पूर्ण प्रलेखन शामिल है।
Diagnostics - इसके तहत आप CouchDB की स्थापना को सत्यापित कर सकते हैं।
Recent Databases - इसके तहत आप हाल ही में जोड़े गए डेटाबेस के नाम पा सकते हैं।
HTTP अनुरोध हेडर का उपयोग करके, आप CouchDB के साथ संवाद कर सकते हैं। इन अनुरोधों के माध्यम से हम डेटाबेस से डेटा प्राप्त कर सकते हैं, डेटा को डेटाबेस में दस्तावेज़ों के रूप में संग्रहीत कर सकते हैं, और हम डेटाबेस में संग्रहीत दस्तावेज़ों को भी देख सकते हैं।
HTTP अनुरोध प्रारूप
डेटाबेस के साथ संचार करते समय हम विभिन्न अनुरोध प्रारूपों जैसे कि गेट, हेड, पोस्ट, पुट, डिलीट और कॉपी का उपयोग करेंगे। CouchDB में सभी कार्यों के लिए, इनपुट डेटा और आउटपुट डेटा संरचनाएं जावास्क्रिप्ट ऑब्जेक्ट नोटेशन (JSON) ऑब्जेक्ट के रूप में होंगी।
CouchDB के साथ संचार करने के लिए उपयोग किए जाने वाले HTTP प्रोटोकॉल के विभिन्न अनुरोध प्रारूप निम्नलिखित हैं।
GET- इस प्रारूप का उपयोग किसी विशिष्ट वस्तु को प्राप्त करने के लिए किया जाता है। विभिन्न मदों को प्राप्त करने के लिए, आपको विशिष्ट यूआरएल पैटर्न भेजना होगा। इस GET अनुरोध का उपयोग करके CouchDB में, हम स्थिर आइटम, डेटाबेस दस्तावेज़ और कॉन्फ़िगरेशन, और JSON दस्तावेज़ (ज्यादातर मामलों में) के रूप में सांख्यिकीय जानकारी प्राप्त कर सकते हैं।
HEAD - जवाब के शरीर के बिना एक जीईटी अनुरोध के HTTP हेडर प्राप्त करने के लिए HEAD विधि का उपयोग किया जाता है।
POST- पोस्ट अनुरोध का उपयोग डेटा अपलोड करने के लिए किया जाता है। CSTDB में POST अनुरोध का उपयोग करके, आप मान सेट कर सकते हैं, दस्तावेज़ अपलोड कर सकते हैं, दस्तावेज़ मान सेट कर सकते हैं, और कुछ प्रशासन कमांड भी शुरू कर सकते हैं।
PUT - PUT अनुरोध का उपयोग करके, आप नई ऑब्जेक्ट, डेटाबेस, दस्तावेज़, विचार और डिज़ाइन दस्तावेज़ बना सकते हैं।
DELETE - DELETE अनुरोध का उपयोग करके, आप दस्तावेज़ों, विचारों और डिज़ाइन दस्तावेज़ों को हटा सकते हैं।
COPY - COPY पद्धति का उपयोग करके, आप दस्तावेजों और वस्तुओं को कॉपी कर सकते हैं।
HTTP अनुरोध हेडर
HTTP हेडर को सही प्रारूप और एन्कोडिंग प्राप्त करने के लिए आपूर्ति की जानी चाहिए। CouchDB सर्वर को अनुरोध भेजते समय, आप अनुरोध के साथ Http अनुरोध हेडर भेज सकते हैं। निम्नलिखित Http अनुरोध हेडर अलग हैं।
Content-type- यह हैडर उस डेटा प्रकार की सामग्री को निर्दिष्ट करने के लिए उपयोग किया जाता है जिसे हम अनुरोध के साथ सर्वर को आपूर्ति करते हैं। अधिकतर जिस प्रकार की सामग्री हम अनुरोध के साथ भेजते हैं वह MIME प्रकार या JSON (एप्लिकेशन / json) होगी। अनुरोध पर सामग्री-प्रकार का उपयोग करना अत्यधिक अनुशंसित है।
Accept- इस हेडर का उपयोग सर्वर को निर्दिष्ट करने के लिए किया जाता है, क्लाइंट द्वारा समझे जाने वाले डेटा प्रकारों की सूची, ताकि सर्वर उन डेटा प्रकारों का उपयोग करके अपनी प्रतिक्रिया भेज सके। आम तौर पर यहां, आप क्लाइंट द्वारा स्वीकार किए जाने वाले MIME डेटा प्रकारों की सूची कॉलन द्वारा अलग-अलग भेज सकते हैं।
हालांकि, CouchDB के प्रश्नों में स्वीकार का उपयोग करने की आवश्यकता नहीं है, यह सुनिश्चित करने के लिए अत्यधिक अनुशंसा की जाती है कि लौटाए गए डेटा को क्लाइंट द्वारा संसाधित किया जा सकता है।
रिस्पांस हेडर
ये सर्वर द्वारा भेजे गए प्रतिक्रिया के हेडर हैं। ये हेडर प्रतिक्रिया के रूप में सर्वर द्वारा भेजे गए कंटेंट की जानकारी देते हैं।
Content-type- यह हेडर सर्वर द्वारा लौटाए गए डेटा के MIME प्रकार को निर्दिष्ट करता है। अधिकांश अनुरोध के लिए, दिया गया MIME प्रकार पाठ / सादा है।
Cache-control- यह हेडर क्लाइंट को सर्वर द्वारा भेजी गई जानकारी के इलाज के बारे में सुझाव देता है। CouchDB ज्यादातर प्रति-पुनर्वित्त लौटाता है, जो इंगित करता है कि यदि संभव हो तो जानकारी को अमान्य कर दिया जाना चाहिए।
Content-length - यह हेडर सर्वर द्वारा भेजी गई सामग्री की लंबाई को बाइट्स में लौटाता है।
Etag - इस हेडर का उपयोग किसी डॉक्यूमेंट, या किसी व्यू के लिए रिविजन को दिखाने के लिए किया जाता है।
स्थिति कोड
Http हेडर और उसके विवरण के द्वारा भेजे गए स्टेटस कोड का सारणीबद्ध रूप निम्नलिखित है।
अनु क्रमांक। | स्थिति कोड और विवरण |
---|---|
1 | 200 − OK यह स्थिति तब जारी की जाएगी जब अनुरोध सफलतापूर्वक पूरा हो जाएगा। |
2 | 201 − Created यह स्थिति दस्तावेज़ जारी किए जाने पर जारी की जाएगी। |
3 | 202 − Accepted अनुरोध स्वीकार किए जाने पर यह स्थिति जारी की जाएगी। |
4 | 404 − Not Found यह स्थिति तब जारी की जाएगी जब सर्वर अनुरोधित सामग्री को खोजने में असमर्थ हो। |
5 | 405 − Resource Not Allowed यह स्थिति तब जारी की जाती है जब HTTP अनुरोध प्रकार का उपयोग अमान्य है। |
6 | 409 − Conflict जब भी कोई अपडेट संघर्ष होता है, तो यह स्थिति जारी की जाती है। |
7 | 415 − Bad Content Type इस स्थिति ने संकेत दिया कि अनुरोधित सामग्री प्रकार सर्वर द्वारा समर्थित नहीं है। |
8 | 500 − Internal Server Error जब भी अनुरोध में भेजा गया डेटा अमान्य है, तब यह स्थिति जारी की जाती है। |
HTTP URL पथ
कुछ url पथ हैं जिनके उपयोग से, आप डेटाबेस से सीधे संपर्क कर सकते हैं। निम्नलिखित इस तरह के यूआरएल पथ का सारणीबद्ध प्रारूप है।
अनु क्रमांक। | URL और ऑपरेशन |
---|---|
1 | PUT /db इस यूआरएल का उपयोग एक नया डेटाबेस बनाने के लिए किया जाता है। |
2 | GET /db इस यूआरएल का उपयोग मौजूदा डेटाबेस के बारे में जानकारी प्राप्त करने के लिए किया जाता है। |
3 | PUT /db/document इस url का उपयोग किसी दस्तावेज़ को बनाने / मौजूदा दस्तावेज़ को अद्यतन करने के लिए किया जाता है। |
4 | GET /db/document इस url का उपयोग डॉक्यूमेंट प्राप्त करने के लिए किया जाता है। |
5 | DELETE /db/document इस यूआरएल का उपयोग निर्दिष्ट डेटाबेस से निर्दिष्ट दस्तावेज़ को हटाने के लिए किया जाता है। |
6 | GET /db/_design/design-doc इस url का उपयोग किसी डिज़ाइन दस्तावेज़ की परिभाषा प्राप्त करने के लिए किया जाता है। |
7 | GET /db/_design/designdoc/_view/view-name इस यूआरएल का उपयोग निर्दिष्ट डेटाबेस से डिज़ाइन दस्तावेज़ से दृश्य, दृश्य-नाम तक पहुंचने के लिए किया जाता है। |
डेटाबेस CouchDB में सबसे बाहरी डेटा संरचना है जहां आपके दस्तावेज़ संग्रहीत हैं। आप इन डेटाबेस को CouchDB द्वारा प्रदान की गई CURL उपयोगिता का उपयोग करके बना सकते हैं, साथ ही CouchDB के वेब इंटरफ़ेस को Futon भी कर सकते हैं।
CURL यूटिलिटी का उपयोग करके एक डेटाबेस बनाना
आप CURL उपयोगिता के माध्यम से PUT विधि का उपयोग करके सर्वर को HTTP अनुरोध भेजकर CouchDB में एक डेटाबेस बना सकते हैं। डेटाबेस बनाने के लिए सिंटैक्स निम्नलिखित है -
$ curl -X PUT http://127.0.0.1:5984/database name
का उपयोग करते हुए −Xहम HTTP कस्टम अनुरोध विधि का उपयोग करने के लिए निर्दिष्ट कर सकते हैं। इस मामले में, हम PUT पद्धति का उपयोग कर रहे हैं। जब हम PUT ऑपरेशन / विधि का उपयोग करते हैं, तो url की सामग्री उस ऑब्जेक्ट नाम को निर्दिष्ट करती है जिसे हम HTTP अनुरोध का उपयोग करके बना रहे हैं। यहाँ हमें डेटाबेस बनाने के लिए url में put request का उपयोग करके डेटाबेस का नाम भेजना है।
उदाहरण
यदि आप नाम के साथ एक डेटाबेस बनाना चाहते हैं तो ऊपर दिए गए सिंटैक्स का उपयोग करना my_database, आप इसे निम्नानुसार बना सकते हैं
curl -X PUT http://127.0.0.1:5984/my_database
{
"ok":true
}
प्रतिक्रिया के रूप में सर्वर आपको सामग्री के साथ एक JSON दस्तावेज़ लौटाएगा “ok” - true ऑपरेशन को इंगित करना सफल रहा।
सत्यापन
सत्यापित करें कि क्या डेटाबेस बनाया गया है, नीचे दिखाए गए सभी डेटाबेसों को सूचीबद्ध करके। यहां आप एक नए बनाए गए डेटाबेस का नाम देख सकते हैं," my_database " सूची मैं।
$ curl -X GET http://127.0.0.1:5984/_all_dbs
[ "_replicator " , " _users " , " my_database " ]
Futon का उपयोग कर एक डेटाबेस बनाना
एक डेटाबेस बनाने के लिए खोलें http://127.0.0.1:5984/_utils/। आपको नीचे दिखाए अनुसार CouchDB का अवलोकन / सूचकांक पृष्ठ मिलेगा।
इस पृष्ठ में, आप CouchDB में डेटाबेस की सूची देख सकते हैं, एक विकल्प बटन बायीं ओर डेटाबेस बनाएँ।
अब create database लिंक पर क्लिक करें। आप एक पॉपअप विंडो देख सकते हैंCreate New Databasesनए डेटाबेस के लिए डेटाबेस नाम के लिए पूछ रहा है। उल्लिखित मानदंडों का पालन करते हुए कोई भी नाम चुनें। यहां हम एक और डेटाबेस बना रहे हैं, जिसका नाम tutorial_point है। निम्न स्क्रीनशॉट में दिखाए अनुसार create बटन पर क्लिक करें।
CURL यूटिलिटी का उपयोग करके डेटाबेस को हटाना
आप CURL उपयोगिता के माध्यम से DELETE पद्धति का उपयोग करके सर्वर को अनुरोध भेजकर CouchDB में एक डेटाबेस को हटा सकते हैं। डेटाबेस बनाने के लिए सिंटैक्स निम्नलिखित है -
$ curl -X DELETE http://127.0.0.1:5984/database name
का उपयोग करते हुए −XHTTP सर्वर के साथ संचार करते समय हम HTTP का एक कस्टम अनुरोध विधि निर्दिष्ट कर सकते हैं। इस मामले में, हम DELETE पद्धति का उपयोग कर रहे हैं। इसमें डिलीट किए जाने वाले डेटाबेस को निर्दिष्ट करके सर्वर को url भेजें।
उदाहरण
मान लें कि CouchDB में my_database2 नाम का एक डेटाबेस है। ऊपर दिए गए सिंटैक्स का उपयोग करते हुए यदि आप इसे हटाना चाहते हैं, तो आप इसे निम्नानुसार कर सकते हैं -
$ curl -X DELETE http://127.0.0.1:5984/my_database2
{
"ok" : true
}
प्रतिक्रिया के रूप में, सर्वर आपको सामग्री के साथ JSON दस्तावेज़ लौटाएगा “ok” - true ऑपरेशन को इंगित करना सफल रहा।
सत्यापन
सत्यापित करें कि क्या डेटाबेस को नीचे दिखाए गए अनुसार सभी डेटाबेस को सूचीबद्ध करके हटा दिया गया है। यहां आप हटाए गए डेटाबेस का नाम देख सकते हैं,"my_database" सूची में नहीं है।
$ curl -X GET http://127.0.0.1:5984/_all_dbs
[ "_replicator " , " _users " ]
Futon का उपयोग कर एक डेटाबेस को हटाना
डेटाबेस हटाने के लिए, खोलें http://127.0.0.1:5984/_utils/ url जहाँ आपको CouchDB का एक अवलोकन / सूचकांक पृष्ठ मिलेगा, जैसा कि नीचे दिखाया गया है।
यहां आप तीन उपयोगकर्ता निर्मित डेटाबेस देख सकते हैं। आइए हम Tutorial_point2 नाम के डेटाबेस को हटाते हैं। डेटाबेस को हटाने के लिए, डेटाबेस की सूची में से एक का चयन करें, और उस पर क्लिक करें, जो चयनित डेटाबेस के अवलोकन पृष्ठ पर ले जाएगा जहां आप डेटाबेस पर विभिन्न कार्यों को देख सकते हैं। निम्न स्क्रीनशॉट समान दिखाता है -
उनमें से आप पा सकते हैं Delete Databaseविकल्प। उस पर क्लिक करके आप एक पॉपअप विंडो प्राप्त करेंगे, यह पूछेंगे कि क्या आप सुनिश्चित हैं! डिलीट पर क्लिक करें, चयनित डेटाबेस को हटाने के लिए।
दस्तावेज़ CouchDB के केंद्रीय डेटा संरचना हैं। डेटाबेस की सामग्री को तालिकाओं के बजाय दस्तावेज़ के रूप में संग्रहीत किया जाएगा। आप इन दस्तावेजों को CouchDB, साथ ही साथ Futon द्वारा प्रदान की गई CURL उपयोगिता का उपयोग करके बना सकते हैं। यह अध्याय डेटाबेस में दस्तावेज़ बनाने के तरीकों को शामिल करता है।
CouchDB में प्रत्येक दस्तावेज़ में एक अद्वितीय आईडी है। आप अपनी खुद की आईडी चुन सकते हैं जो एक स्ट्रिंग के रूप में होनी चाहिए। आम तौर पर, यूयूआईडी (विश्वविद्यालय अद्वितीय पहचानकर्ता) का उपयोग किया जाता है, जो यादृच्छिक संख्याएं होती हैं जिनके पास डुप्लिकेट बनाने की कम से कम संभावना होती है। ये टकराव से बचने के लिए पसंद किए जाते हैं।
CURL उपयोगिता का उपयोग करके एक दस्तावेज़ बनाना
आप CURL उपयोगिता के माध्यम से PUT विधि का उपयोग करके सर्वर को HTTP अनुरोध भेजकर CouchDB में एक दस्तावेज़ बना सकते हैं। दस्तावेज़ बनाने के लिए वाक्य रचना निम्नलिखित है।
$ curl -X PUT http://127.0.0.1:5984/database name/"id" -d ' { document} '
का उपयोग करते हुए −XHTTP सर्वर के साथ संचार करते समय हम HTTP का एक कस्टम अनुरोध विधि निर्दिष्ट कर सकते हैं। इस मामले में, हम PUT पद्धति का उपयोग कर रहे हैं। जब हम PUT विधि का उपयोग करते हैं, तो url की सामग्री उस ऑब्जेक्ट नाम को निर्दिष्ट करती है जिसे हम HTTP अनुरोध का उपयोग करके बना रहे हैं। यहाँ हमें निम्नलिखित भेजना है -
डेटाबेस नाम का नाम जिसमें हम दस्तावेज़ बना रहे हैं।
दस्तावेज़ आईडी।
दस्तावेज़ का डेटा। −dविकल्प HTTP अनुरोध के माध्यम से डेटा / दस्तावेज़ भेजने के लिए उपयोग किया जाता है। दस्तावेज़ लिखते समय, अपने कोष्ठक द्वारा अलग किए गए फ़ील्ड-वैल्यू जोड़े दर्ज करें, जैसा कि नीचे दिखाया गया है
{
Name : Raju
age : 23
Designation : Designer
}
उदाहरण
यदि आप आईडी के साथ एक दस्तावेज बनाना चाहते हैं, तो ऊपर दिए गए सिंटैक्स का उपयोग करना 001 नाम के साथ एक डेटाबेस में my_database, आप इसे नीचे दिखाए अनुसार बना सकते हैं।
$ curl -X PUT http://127.0.0.1:5984/my_database/"001" -d
'{ " Name " : " Raju " , " age " :" 23 " , " Designation " : " Designer " }'
{"ok":true,"id":"001","rev":"1-1c2fae390fa5475d9b809301bbf3f25e"}
इस अनुरोध के लिए CouchDB की प्रतिक्रिया में तीन फ़ील्ड शामिल हैं -
"ok", ऑपरेशन को इंगित करना सफल रहा।
"id", जो दस्तावेज़ की आईडी संग्रहीत करता है और
"rev",यह संशोधन आईडी इंगित करता है। हर बार जब आप एक दस्तावेज़ को संशोधित (अपडेट या संशोधित) करते हैं a_revCouchDB द्वारा मूल्य उत्पन्न किया जाएगा। यदि आप किसी दस्तावेज़ को अपडेट या हटाना चाहते हैं, तो CouchDB आपको इसमें शामिल करने की उम्मीद करता है_revसंशोधन का क्षेत्र जिसे आप बदलना चाहते हैं। जब CouchDB परिवर्तन स्वीकार करता है, तो यह एक नया संशोधन नंबर उत्पन्न करेगा। यह तंत्र संगामिति नियंत्रण सुनिश्चित करता है।
सत्यापन
यदि आप बनाए गए दस्तावेज़ को देखना चाहते हैं, तो आप इसे दस्तावेज़ का उपयोग करके प्राप्त कर सकते हैं जैसा कि नीचे दिखाया गया है।
$ curl -X GET http://127.0.0.1:5984/my_database/001
{
"_id": "001",
"_rev": "1-3fcc78daac7a90803f0a5e383f4f1e1e",
"Name": "Raju",
"age": 23,
"Designation": "Designer"
}
Futon का उपयोग करके एक दस्तावेज़ बनाना
एक दस्तावेज़ बनाने के लिए खोलें http://127.0.0.1:5984/_utils/ url CouchDB का अवलोकन / सूचकांक पृष्ठ प्राप्त करने के लिए जैसा कि नीचे दिखाया गया है।
उस डेटाबेस का चयन करें जिसमें आप दस्तावेज़ बनाना चाहते हैं। डेटाबेस का अवलोकन पृष्ठ खोलें और चुनेंNew Document विकल्प के रूप में नीचे दिखाया गया है।
जब आप सेलेक्ट करेंगे New Documentविकल्प, CouchDB एक नया डेटाबेस दस्तावेज़ बनाता है, इसे एक नया आईडी निर्दिष्ट करता है। आप आईडी के मूल्य को संपादित कर सकते हैं और एक स्ट्रिंग के रूप में अपना स्वयं का मान असाइन कर सकते हैं। निम्नलिखित चित्रण में, हमने एक नया दस्तावेज़ बनाया है जिसमें एक आईडी ००१ है।
इस पृष्ठ में, आप तीन विकल्प देख सकते हैं - दस्तावेज़ सहेजें, फ़ील्ड जोड़ें और अनुलग्नक अपलोड करें।
दस्तावेज़ में फ़ील्ड जोड़ें
दस्तावेज़ में फ़ील्ड जोड़ने के लिए उस पर क्लिक करें Add Fieldविकल्प। एक डेटाबेस बनाने के बाद, आप इस विकल्प का उपयोग करके इसमें एक फ़ील्ड जोड़ सकते हैं। इस पर क्लिक करने पर आपको टेक्स्ट बॉक्स की एक जोड़ी मिल जाएगी, अर्थात्Field, value.आप इन मानों को क्लिक करके संपादित कर सकते हैं। उन मानों को संपादित करें और अपनी इच्छित फ़ील्ड-वैल्यू जोड़ी टाइप करें। इन मानों को सहेजने के लिए हरे बटन पर क्लिक करें।
निम्नलिखित उदाहरण में, हमने कर्मचारी के नाम, आयु और, तीन क्षेत्र बनाए हैं।
दस्तावेज़ सहेजें
आप इस विकल्प पर क्लिक करके दस्तावेज़ में किए गए परिवर्तनों को सहेज सकते हैं। बचाने के बाद, एक नई आईडी_rev नीचे दिखाए अनुसार उत्पन्न किया जाएगा।
CURL का उपयोग करके दस्तावेजों को अद्यतन करना
आप CURL उपयोगिता के माध्यम से PUT विधि का उपयोग करके सर्वर को HTTP अनुरोध भेजकर CouchDB में एक दस्तावेज़ को अपडेट कर सकते हैं। दस्तावेज़ को अद्यतन करने के लिए सिंटैक्स निम्नलिखित है।
curl -X PUT http://127.0.0.1:5984/database_name/document_id/ -d '{ "field" : "value", "_rev" : "revision id" }'
उदाहरण
मान लीजिए कि my_database नाम के डेटाबेस में id 001 के साथ एक दस्तावेज़ है। आप इसे नीचे दिखाए अनुसार हटा सकते हैं।
सबसे पहले, उस दस्तावेज़ की संशोधन आईडी प्राप्त करें जिसे अपडेट किया जाना है। आप पा सकते हैं_rev दस्तावेज़ में स्वयं दस्तावेज़, इसलिए नीचे दिखाए गए अनुसार दस्तावेज़ प्राप्त करें।
$ curl -X GET http://127.0.0.1:5984/my_database/001
{
"_id" : "001",
"_rev" : "2-04d8eac1680d237ca25b68b36b8899d3 " ,
"age" : "23"
}
दस्तावेज़ को अद्यतन करने के लिए दस्तावेज़ से संशोधन आईडी _rev का उपयोग करें। यहां हम 23 से 24 की उम्र को अपडेट कर रहे हैं।
$ curl -X PUT http://127.0.0.1:5984/my_database/001/ -d
' { " age " : " 24 " , " _rev " : " 1-1c2fae390fa5475d9b809301bbf3f25e " } '
{ " ok " : true , " id " : " 001 " , " rev " : " 2-04d8eac1680d237ca25b68b36b8899d3 " }
सत्यापन
दस्तावेज़ को सत्यापित करने के लिए, नीचे दिखाए गए अनुसार GET अनुरोध का उपयोग करके दस्तावेज़ को फिर से प्राप्त करें।
$ curl -X GET http://127.0.0.1:5984/my_database/001
{
" _id " : " 001 ",
" _rev " : " 2-04d8eac1680d237ca25b68b36b8899d3 " ,
" age " : " 23 "
}
Note
दस्तावेज़ को अपडेट करते समय कुछ महत्वपूर्ण बिंदुओं पर ध्यान दिया जाना चाहिए।
URL हम डेटाबेस नाम और दस्तावेज़ आईडी वाले अनुरोध में भेजते हैं।
मौजूदा दस्तावेज़ को अपडेट करना पूरे दस्तावेज़ को अपडेट करने के समान है। आप किसी मौजूदा दस्तावेज़ में फ़ील्ड नहीं जोड़ सकते। आप केवल एक ही दस्तावेज़ आईडी के साथ डेटाबेस में दस्तावेज़ का एक नया संस्करण लिख सकते हैं।
हमें JSON अनुरोध के एक भाग के रूप में संशोधन संख्या की आपूर्ति करनी है।
बदले में JSON में सफलता संदेश, अद्यतन की जा रही दस्तावेज़ की आईडी और नई संशोधन जानकारी शामिल है। यदि आप दस्तावेज़ के नए संस्करण को अपडेट करना चाहते हैं, तो आपको इस नवीनतम संशोधन संख्या को उद्धृत करना होगा।
Futon का उपयोग कर दस्तावेजों को अद्यतन करना
किसी दस्तावेज़ को हटाने के लिए खोलें http://127.0.0.1:5984/_utils/ url CouchDB का अवलोकन / सूचकांक पृष्ठ प्राप्त करने के लिए जैसा कि नीचे दिखाया गया है।
उस डेटाबेस का चयन करें जिसमें अद्यतन किया जाने वाला दस्तावेज़ मौजूद है और उसे क्लिक करें। यहां हम नाम के डेटाबेस में एक दस्तावेज अपडेट कर रहे हैंtutorials_point। आपको डेटाबेस में दस्तावेजों की सूची नीचे दिखाए अनुसार मिलेगी।
एक दस्तावेज़ का चयन करें जिसे आप अपडेट करना चाहते हैं और उस पर क्लिक करें। आपको नीचे दिखाए गए अनुसार दस्तावेजों की सामग्री मिलेगी।
यहां, दिल्ली से हैदराबाद तक के स्थान को अपडेट करने के लिए, टेक्स्ट बॉक्स पर क्लिक करें, फ़ील्ड को संपादित करें, और नीचे दिखाए गए परिवर्तनों को सहेजने के लिए हरे बटन पर क्लिक करें।
CURL यूटिलिटी का उपयोग कर एक डॉक्यूमेंट को हटाना
आप CURL उपयोगिता के माध्यम से DELETE पद्धति का उपयोग करके सर्वर को HTTP अनुरोध भेजकर काउचडीबी में एक दस्तावेज़ को हटा सकते हैं। दस्तावेज़ को हटाने के लिए वाक्य रचना निम्नलिखित है।
curl -X DELETE http : // 127.0.0.1:5984 / database name/database id?_rev id
का उपयोग करते हुए −X,HTTP सर्वर के साथ संचार करते समय हम HTTP का एक कस्टम अनुरोध विधि निर्दिष्ट कर सकते हैं। इस मामले में, हम डिलीट विधि का उपयोग कर रहे हैं। एक डेटाबेस को हटाने के लिए /database_name/database_id/
पर्याप्त नहीं है। आपको url के माध्यम से हाल ही में संशोधन आईडी पास करना होगा। किसी भी डेटा संरचना की विशेषताओं का उल्लेख करने के लिए"?" प्रयोग किया जाता है।
उदाहरण
मान लीजिए कि नाम के डेटाबेस में कोई दस्तावेज है my_databaseदस्तावेज़ आईडी के साथ 001. इस दस्तावेज़ को हटाने के लिए, आपको दस्तावेज़ की Rev आईडी प्राप्त करनी होगी। नीचे दिखाए अनुसार दस्तावेज़ डेटा प्राप्त करें।
$ curl -X GET http://127.0.0.1:5984/my_database/001
{
" _id " : " 001 ",
" _rev " : " 2-04d8eac1680d237ca25b68b36b8899d3 " ,
" age " : " 23 "
}
अब हटाए गए दस्तावेज़ की संशोधन आईडी निर्दिष्ट करें, दस्तावेज़ की आईडी, और डेटाबेस का नाम दस्तावेज़ से संबंधित है, जैसा कि नीचे दिखाया गया है -
$ curl -X DELETE http://127.0.0.1:5984/my_database/001?rev=1-
3fcc78daac7a90803f0a5e383f4f1e1e
{"ok":true,"id":"001","rev":"2-3a561d56de1ce3305d693bd15630bf96"}
सत्यापन
यह सत्यापित करने के लिए कि दस्तावेज़ हटा दिया गया है या नहीं, का उपयोग करके दस्तावेज़ लाने का प्रयास करें GETतरीका। चूंकि आप हटाए गए दस्तावेज़ ला रहे हैं, यह आपको एक त्रुटि संदेश देगा जैसा कि नीचे दिखाया गया है -
$ curl -X GET http://127.0.0.1:5984/my_database/001
{"error":"not_found","reason":"deleted"}
Futon का उपयोग कर एक दस्तावेज़ हटाना
सबसे पहले, डेटाबेस में दस्तावेजों को सत्यापित करें। निम्नलिखित डेटाबेस के स्नैपशॉट का नाम दिया गया हैtutorials_point।
यहां आप निरीक्षण कर सकते हैं, डेटाबेस में तीन दस्तावेज होते हैं। किसी भी दस्तावेज़ को हटाने के लिए कहें003, निम्नलिखित करें -
दस्तावेज़ पर क्लिक करें, आपको पृष्ठ-मूल्य जोड़े के रूप में चयनित दस्तावेज़ की सामग्री दिखाने वाला एक पृष्ठ मिलेगा।
इस पृष्ठ में भी चार विकल्प हैं Save Document, Add Field, Upload Attachment, Delete Document.
पर क्लिक करें Delete Document विकल्प।
आपको एक डायलॉग बॉक्स मिलेगा "Are you sure you want to delete this document?" डॉक्यूमेंट को डिलीट करने के लिए डिलीट पर क्लिक करें।
CURL का उपयोग करके फ़ाइलें संलग्न करना
आप ईमेल की तरह ही CouchDB में फाइल अटैच कर सकते हैं। फ़ाइल में नाम जैसा मेटाडेटा है और इसमें MIME प्रकार शामिल है, और अटैचमेंट की संख्या में बाइट्स शामिल हैं। एक दस्तावेज़ में फ़ाइलों को संलग्न करने के लिए आपको सर्वर को PUT अनुरोध भेजना होगा। दस्तावेज़ में फ़ाइलें संलग्न करने के लिए सिंटैक्स निम्नलिखित है -
$ curl -vX PUT http://127.0.0.1:5984/database_name/database_id
/filename?rev=document rev_id --data-binary @filename -H "Content-Type:
type of the content"
अनुरोध में विभिन्न विकल्प हैं जिन्हें नीचे समझाया गया है।
--data-binary@ - यह विकल्प cURL को HTTP अनुरोध बॉडी में फ़ाइल की सामग्री को पढ़ने के लिए कहता है।
-H - यह विकल्प उस सामग्री प्रकार का उल्लेख करने के लिए उपयोग किया जाता है जिसे हम अपलोड करने जा रहे हैं।
उदाहरण
हमें एक फाइल अटैच करें जिसका नाम है boy.jpg, आईडी के साथ दस्तावेज़ के लिए 001, नाम के डेटाबेस में my_databaseCUTDB को PUT अनुरोध भेजकर। इससे पहले, आपको आईडी के साथ दस्तावेज़ का डेटा प्राप्त करना होगा001 अपने वर्तमान पाने के लिए rev आईडी नीचे दिखाया गया है।
$ curl -X GET http://127.0.0.1:5984/my_database/001
{
"_id": "001",
"_rev": "1-967a00dff5e02add41819138abb3284d"
}
अब का उपयोग कर _rev मूल्य, नीचे दिखाए गए अनुसार CUTDB सर्वर को PUT अनुरोध भेजें।
$ curl -vX PUT http://127.0.0.1:5984/my_database/001/boy.jpg?rev=1-
967a00dff5e02add41819138abb3284d --data-binary @boy.jpg -H "ContentType:
image/jpg"
सत्यापन
यह सत्यापित करने के लिए कि क्या अनुलग्नक अपलोड किया गया है, नीचे दिखाए अनुसार दस्तावेज़ सामग्री प्राप्त करें
$ curl -X GET http://127.0.0.1:5984/my_database/001
{
"_id": "001",
"_rev": "2-4705a219cdcca7c72aac4f623f5c46a8",
"_attachments": {
"boy.jpg": {
"content_type": "image/jpg",
"revpos": 2,
"digest": "md5-9Swz8jvmga5mfBIsmCxCtQ==",
"length": 91408,
"stub": true
}
}
}
Futon का उपयोग करके फ़ाइलें संलग्न करना
अटैचमेंट अपलोड करें
इस विकल्प का उपयोग करके, आप एक नया अनुलग्नक जैसे फ़ाइल, छवि या दस्तावेज़ को डेटाबेस पर अपलोड कर सकते हैं। ऐसा करने के लिए, पर क्लिक करेंUpload Attachmentबटन। एक संवाद बॉक्स दिखाई देगा जहां आप अपलोड की जाने वाली फ़ाइल का चयन कर सकते हैं। फ़ाइल का चयन करें और पर क्लिक करेंUpload बटन।
अपलोड की गई फ़ाइल _attachments फ़ील्ड के अंतर्गत प्रदर्शित की जाएगी। बाद में आप उस पर क्लिक करके फ़ाइल देख सकते हैं।