काउचडीबी - कर्ल और फ्यूटन

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 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 −
  • डेटाबेस बनाता है।
  • डेटाबेस को नष्ट कर देता है।
Documents −
  • दस्तावेज बनाता है।
  • दस्तावेज़ अद्यतन करता है।
  • दस्तावेजों को संपादित करता है।
  • दस्तावेज़ हटाता है।

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 - इसके तहत आप हाल ही में जोड़े गए डेटाबेस के नाम पा सकते हैं।