रेडिस - त्वरित गाइड

रेडिस एक खुला स्रोत, उन्नत की-वैल्यू स्टोर और हाईपरफॉर्मेंस, स्केलेबल वेब अनुप्रयोगों के निर्माण के लिए उपयुक्त समाधान है।

रेडिस की तीन मुख्य ख़ासियतें हैं जो इसे अलग करती हैं।

  • Redis अपने डेटाबेस को पूरी तरह से मेमोरी में रखता है, केवल दृढ़ता के लिए डिस्क का उपयोग करता है।

  • कई मुख्य-मूल्य डेटा स्टोरों की तुलना में रेडिस के पास डेटा प्रकारों का एक अपेक्षाकृत समृद्ध सेट है।

  • रेडिस किसी भी संख्या में दासों को डेटा दोहरा सकते हैं।

रेडिस के फायदे

रेडिस के कुछ फायदे निम्नलिखित हैं।

  • Exceptionally fast - रेडिस बहुत तेज है और प्रति सेकंड लगभग 110000 सेट्स कर सकता है, लगभग 81000 GET प्रति सेकंड।

  • Supports rich data types- रेडिस मूल रूप से अधिकांश डेटाटिप्स का समर्थन करता है जो डेवलपर्स पहले से ही जानते हैं जैसे कि सूची, सेट, सॉर्ट किए गए सेट और हैश। इससे विभिन्न प्रकार की समस्याओं को हल करना आसान हो जाता है क्योंकि हम जानते हैं कि कौन सी समस्या को किस डेटा प्रकार से बेहतर तरीके से नियंत्रित किया जा सकता है।

  • Operations are atomic - सभी रेडिस ऑपरेशन परमाणु हैं, जो यह सुनिश्चित करता है कि यदि दो ग्राहक समवर्ती रूप से एक्सेस करते हैं, तो रेडिस सर्वर को अद्यतन मूल्य प्राप्त होगा।

  • Multi-utility tool - रेडिस एक बहुउपयोगी उपकरण है और इसका उपयोग कई मामलों में किया जा सकता है जैसे कि कैशिंग, मैसेजिंग-क्वीज (Redis मूल रूप से पब्लिश / सब्सक्राइब का समर्थन करता है), आपके एप्लिकेशन में कोई भी अल्पकालिक डेटा, जैसे वेब एप्लिकेशन सेशन, वेब पेज हिट मायने रखता है, आदि।

Redis बनाम अन्य कुंजी मूल्य स्टोर

  • रेडिस कुंजी-वैल्यू डीबी में एक अलग विकास पथ है, जहां मूल्यों में अधिक जटिल डेटा प्रकार हो सकते हैं, इन डेटा प्रकारों पर परिभाषित परमाणु संचालन।

  • Redis एक इन-मेमोरी डेटाबेस है, लेकिन डिस्क डेटाबेस पर लगातार बना रहता है, इसलिए यह एक अलग ट्रेड का प्रतिनिधित्व करता है, जहां डेटा सेट्स की सीमा के साथ बहुत अधिक लिखने और पढ़ने की गति हासिल की जाती है जो मेमोरी से बड़ा नहीं हो सकता है।

  • इन-मेमोरी डेटाबेस का एक और लाभ यह है कि जटिल डेटा संरचनाओं का मेमोरी प्रतिनिधित्व डिस्क पर समान डेटा संरचना की तुलना में हेरफेर करने के लिए बहुत सरल है। इस प्रकार, रेडिस थोड़ा आंतरिक जटिलता के साथ बहुत कुछ कर सकता है।

इस अध्याय में, आप Redis के पर्यावरण सेटअप के बारे में जानेंगे।

Ubuntu पर Redis स्थापित करें

उबंटू में रेडिस को स्थापित करने के लिए, टर्मिनल पर जाएं और निम्नलिखित कमांड टाइप करें -

$sudo apt-get update $sudo apt-get install redis-server

यह आपकी मशीन पर Redis स्थापित करेगा।

रेडिस शुरू करें

$redis-server

चेक करें कि क्या Redis काम कर रहा है

$redis-cli

इससे रेडिस प्रॉम्प्ट खुल जाएगा।

redis 127.0.0.1:6379>

उपरोक्त संकेत में, 127.0.0.1 आपकी मशीन का IP पता है और 6379पोर्ट है जिस पर Redis सर्वर चल रहा है। अब निम्नलिखित टाइप करेंPING आदेश।

redis 127.0.0.1:6379> ping 
PONG

इससे पता चलता है कि Redis आपकी मशीन पर सफलतापूर्वक स्थापित है।

Ubuntu पर Redis Desktop Manager इंस्टॉल करें

उबंटू पर रेडिस डेस्कटॉप मैनेजर स्थापित करने के लिए, बस से पैकेज डाउनलोड करें https://redisdesktop.com/download

डाउनलोड किए गए पैकेज को खोलें और इसे इंस्टॉल करें।

Redis डेस्कटॉप मैनेजर आपको अपने Redis कीज़ और डेटा को प्रबंधित करने के लिए UI देगा।

Redis में, Redis की रूट डायरेक्टरी में एक कॉन्फ़िगरेशन फ़ाइल (redis.conf) उपलब्ध है। हालाँकि आप Redis द्वारा सभी Redis विन्यास पा सकते हैं और सेट कर सकते हैंCONFIG आदेश।

वाक्य - विन्यास

निम्नलिखित रेडिस का मूल सिंटैक्स है CONFIG आदेश।

redis 127.0.0.1:6379> CONFIG GET CONFIG_SETTING_NAME

उदाहरण

redis 127.0.0.1:6379> CONFIG GET loglevel  
1) "loglevel" 
2) "notice"

सभी कॉन्फ़िगरेशन सेटिंग्स प्राप्त करने के लिए, CONFIG_SETTING_NAME के ​​स्थान पर * का उपयोग करें

उदाहरण

redis 127.0.0.1:6379> CONFIG GET *  
  1) "dbfilename" 
  2) "dump.rdb" 
  3) "requirepass" 
  4) "" 
  5) "masterauth" 
  6) "" 
  7) "unixsocket" 
  8) "" 
  9) "logfile" 
 10) "" 
 11) "pidfile" 
 12) "/var/run/redis.pid" 
 13) "maxmemory" 
 14) "0"
 15) "maxmemory-samples" 
 16) "3" 
 17) "timeout" 
 18) "0" 
 19) "tcp-keepalive" 
 20) "0" 
 21) "auto-aof-rewrite-percentage" 
 22) "100" 
 23) "auto-aof-rewrite-min-size" 
 24) "67108864" 
 25) "hash-max-ziplist-entries" 
 26) "512" 
 27) "hash-max-ziplist-value" 
 28) "64" 
 29) "list-max-ziplist-entries" 
 30) "512" 
 31) "list-max-ziplist-value" 
 32) "64" 
 33) "set-max-intset-entries" 
 34) "512" 
 35) "zset-max-ziplist-entries" 
 36) "128" 
 37) "zset-max-ziplist-value" 
 38) "64" 
 39) "hll-sparse-max-bytes" 
 40) "3000" 
 41) "lua-time-limit" 
 42) "5000" 
 43) "slowlog-log-slower-than" 
 44) "10000" 
 45) "latency-monitor-threshold" 
 46) "0" 
 47) "slowlog-max-len" 
 48) "128" 
 49) "port" 
 50) "6379" 
 51) "tcp-backlog" 
 52) "511" 
 53) "databases" 
 54) "16" 
 55) "repl-ping-slave-period" 
 56) "10" 
 57) "repl-timeout" 
 58) "60" 
 59) "repl-backlog-size" 
 60) "1048576" 
 61) "repl-backlog-ttl" 
 62) "3600" 
 63) "maxclients" 
 64) "4064" 
 65) "watchdog-period" 
 66) "0" 
 67) "slave-priority" 
 68) "100" 
 69) "min-slaves-to-write" 
 70) "0" 
 71) "min-slaves-max-lag" 
 72) "10" 
 73) "hz" 
 74) "10" 
 75) "no-appendfsync-on-rewrite" 
 76) "no" 
 77) "slave-serve-stale-data" 
 78) "yes" 
 79) "slave-read-only" 
 80) "yes" 
 81) "stop-writes-on-bgsave-error" 
 82) "yes" 
 83) "daemonize" 
 84) "no" 
 85) "rdbcompression" 
 86) "yes"
 87) "rdbchecksum" 
 88) "yes" 
 89) "activerehashing" 
 90) "yes" 
 91) "repl-disable-tcp-nodelay" 
 92) "no" 
 93) "aof-rewrite-incremental-fsync" 
 94) "yes" 
 95) "appendonly" 
 96) "no" 
 97) "dir" 
 98) "/home/deepak/Downloads/redis-2.8.13/src" 
 99) "maxmemory-policy" 
100) "volatile-lru" 
101) "appendfsync" 
102) "everysec" 
103) "save" 
104) "3600 1 300 100 60 10000" 
105) "loglevel" 
106) "notice" 
107) "client-output-buffer-limit" 
108) "normal 0 0 0 slave 268435456 67108864 60 pubsub 33554432 8388608 60" 
109) "unixsocketperm" 
110) "0" 
111) "slaveof" 
112) "" 
113) "notify-keyspace-events" 
114) "" 
115) "bind" 
116) ""

कॉन्फ़िगरेशन संपादित करें

कॉन्फ़िगरेशन अपडेट करने के लिए, आप संपादित कर सकते हैं redis.conf सीधे फ़ाइल या आप के माध्यम से विन्यास अद्यतन कर सकते हैं CONFIG set आदेश।

वाक्य - विन्यास

निम्नलिखित का मूल सिंटैक्स है CONFIG SET आदेश।

redis 127.0.0.1:6379> CONFIG SET CONFIG_SETTING_NAME NEW_CONFIG_VALUE

उदाहरण

redis 127.0.0.1:6379> CONFIG SET loglevel "notice" 
OK 
redis 127.0.0.1:6379> CONFIG GET loglevel  
1) "loglevel" 
2) "notice"

Redis 5 प्रकार के डेटा प्रकारों का समर्थन करता है।

स्ट्रिंग्स

रेडिस स्ट्रिंग बाइट्स का एक क्रम है। रेडिस में स्ट्रिंग्स द्विआधारी सुरक्षित हैं, जिसका अर्थ है कि उनके पास एक ज्ञात लंबाई है जो किसी विशेष समाप्ति पात्रों द्वारा निर्धारित नहीं है। इस प्रकार, आप एक स्ट्रिंग में 512 मेगाबाइट तक कुछ भी स्टोर कर सकते हैं।

उदाहरण

redis 127.0.0.1:6379> SET name "tutorialspoint" 
OK 
redis 127.0.0.1:6379> GET name 
"tutorialspoint"

उपरोक्त उदाहरण में, SET तथा GET रेडिस कमांड हैं, name Redis और में प्रयुक्त कुंजी है tutorialspoint Redis में संग्रहित स्ट्रिंग मान है।

Note - एक स्ट्रिंग मान अधिकतम 512 मेगाबाइट लंबाई में हो सकता है।

हैश

एक रेडिस हैश प्रमुख मूल्य जोड़े का एक संग्रह है। Redis Hashes स्ट्रिंग फ़ील्ड्स और स्ट्रिंग मानों के बीच के नक्शे हैं। इसलिए, उनका उपयोग वस्तुओं का प्रतिनिधित्व करने के लिए किया जाता है।

उदाहरण

redis 127.0.0.1:6379> HMSET user:1 username tutorialspoint password 
tutorialspoint points 200 
OK 
redis 127.0.0.1:6379> HGETALL user:1  
1) "username" 
2) "tutorialspoint" 
3) "password" 
4) "tutorialspoint" 
5) "points" 
6) "200"

उपरोक्त उदाहरण में, हैश डेटा प्रकार का उपयोग उपयोगकर्ता की वस्तु को संग्रहीत करने के लिए किया जाता है जिसमें उपयोगकर्ता की बुनियादी जानकारी होती है। यहाँHMSET, HGETALL रेडिस के लिए आदेश हैं, जबकि user − 1 क्या चाबी है।

हर हैश 2 32 - 1 फ़ील्ड-वैल्यू जोड़े (4 बिलियन से अधिक) तक स्टोर कर सकता है ।

सूचियों

Redis Lists आवेषण के क्रम से छंटे हुए तारों की सूची हैं। आप तत्वों को सिर पर या पूंछ पर एक रेडिस सूची में जोड़ सकते हैं।

उदाहरण

redis 127.0.0.1:6379> lpush tutoriallist redis 
(integer) 1 
redis 127.0.0.1:6379> lpush tutoriallist mongodb 
(integer) 2 
redis 127.0.0.1:6379> lpush tutoriallist rabitmq 
(integer) 3 
redis 127.0.0.1:6379> lrange tutoriallist 0 10  

1) "rabitmq" 
2) "mongodb" 
3) "redis"

एक सूची की अधिकतम लंबाई 2 32 - 1 तत्व (4294967295, 4 बिलियन से अधिक तत्व प्रति सूची) है।

सेट

रेडिस सेट स्ट्रिंग्स का एक अनियोजित संग्रह है। रेडिस में, आप ओ (1) समय जटिलता में सदस्यों के अस्तित्व के लिए जोड़ सकते हैं, हटा सकते हैं और परीक्षण कर सकते हैं।

उदाहरण

redis 127.0.0.1:6379> sadd tutoriallist redis 
(integer) 1 
redis 127.0.0.1:6379> sadd tutoriallist mongodb 
(integer) 1 
redis 127.0.0.1:6379> sadd tutoriallist rabitmq 
(integer) 1 
redis 127.0.0.1:6379> sadd tutoriallist rabitmq 
(integer) 0 
redis 127.0.0.1:6379> smembers tutoriallist  

1) "rabitmq" 
2) "mongodb" 
3) "redis"

Note - उपरोक्त उदाहरण में, rabitmq दो बार जोड़ा जाता है, हालांकि सेट की अनूठी संपत्ति के कारण, इसे केवल एक बार जोड़ा जाता है।

एक सेट में सदस्यों की अधिकतम संख्या 2 32 - 1 (4294967295, प्रति सेट 4 बिलियन से अधिक सदस्य) है।

सॉर्ट किए गए सेट

रेडिस सॉर्ट किए गए सेट रेडिस सेट, स्ट्रिंग्स के गैर-दोहराए गए संग्रह के समान हैं। अंतर यह है कि, एक सॉर्ट किए गए सेट का प्रत्येक सदस्य एक स्कोर के साथ जुड़ा हुआ है, जिसका उपयोग क्रमबद्ध सेट को सबसे छोटे से सबसे बड़े स्कोर तक ले जाने के लिए किया जाता है। जबकि सदस्य अद्वितीय हैं, स्कोर दोहराया जा सकता है।

उदाहरण

redis 127.0.0.1:6379> zadd tutoriallist 0 redis 
(integer) 1 
redis 127.0.0.1:6379> zadd tutoriallist 0 mongodb 
(integer) 1 
redis 127.0.0.1:6379> zadd tutoriallist 0 rabitmq 
(integer) 1 
redis 127.0.0.1:6379> zadd tutoriallist 0 rabitmq 
(integer) 0 
redis 127.0.0.1:6379> ZRANGEBYSCORE tutoriallist 0 1000  

1) "redis" 
2) "mongodb" 
3) "rabitmq"

Redis कमांड का उपयोग Redis सर्वर पर कुछ ऑपरेशन करने के लिए किया जाता है।

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

वाक्य - विन्यास

निम्नलिखित Redis क्लाइंट का मूल सिंटैक्स है।

$redis-cli

उदाहरण

निम्नलिखित उदाहरण बताते हैं कि हम रेडिस क्लाइंट कैसे शुरू कर सकते हैं।

Redis क्लाइंट शुरू करने के लिए, टर्मिनल खोलें और कमांड टाइप करें redis-cli। यह आपके स्थानीय सर्वर से जुड़ जाएगा और अब आप कोई भी कमांड चला सकते हैं।

$redis-cli 
redis 127.0.0.1:6379> 
redis 127.0.0.1:6379> PING  
PONG

उपरोक्त उदाहरण में, हम स्थानीय मशीन पर चल रहे Redis सर्वर से कनेक्ट होते हैं और एक कमांड निष्पादित करते हैं PING, कि जाँच करता है कि सर्वर चल रहा है या नहीं।

दूरस्थ सर्वर पर कमांड चलाएँ

रेडिस रिमोट सर्वर पर कमांड चलाने के लिए, आपको उसी क्लाइंट द्वारा सर्वर से कनेक्ट करना होगा redis-cli

वाक्य - विन्यास

$ redis-cli -h host -p port -a password

उदाहरण

निम्नलिखित उदाहरण से पता चलता है कि होस्ट 127.0.0.1, पोर्ट 6379 पर चल रहे Redis रिमोट सर्वर से कैसे कनेक्ट किया जाए और इसमें पासवर्ड माईपास हो।

$redis-cli -h 127.0.0.1 -p 6379 -a "mypass" 
redis 127.0.0.1:6379> 
redis 127.0.0.1:6379> PING  
PONG

Redis में कमांड को मैनेज करने के लिए Redis keys कमांड का उपयोग किया जाता है। रेडिस कीज़ कमांड का उपयोग करने के लिए सिंटैक्स निम्नलिखित है।

वाक्य - विन्यास

redis 127.0.0.1:6379> COMMAND KEY_NAME

उदाहरण

redis 127.0.0.1:6379> SET tutorialspoint redis 
OK 
redis 127.0.0.1:6379> DEL tutorialspoint 
(integer) 1

उपरोक्त उदाहरण में, DEL जबकि, आज्ञा है tutorialspointक्या चाबी है। यदि कुंजी हटा दी जाती है, तो कमांड का आउटपुट 1 (पूर्णांक) होगा, अन्यथा यह (पूर्णांक) 0 होगा।

रेडिस कीज कमांड्स

निम्नलिखित तालिका में कुंजियों से संबंधित कुछ बुनियादी कमांड सूचीबद्ध हैं।

अनु क्रमांक कमांड और विवरण
1 DEL कुंजी

यह आदेश कुंजी को हटा देता है, अगर यह मौजूद है।

2 डंप कुंजी

यह आदेश निर्दिष्ट कुंजी पर संग्रहीत मान का क्रमबद्ध संस्करण लौटाता है।

3 अतिरिक्त कुंजी

यह कमांड जाँचता है कि कुंजी मौजूद है या नहीं।

4 महत्वपूर्ण सेकंड का विस्तार करें

निर्दिष्ट समय के बाद कुंजी की समाप्ति सेट करता है।

5 EXPIREAT कुंजी टाइमस्टैम्प

निर्दिष्ट समय के बाद कुंजी की समाप्ति सेट करता है। यहां समय यूनिक्स टाइमस्टैम्प प्रारूप में है।

6 PEXPIRE प्रमुख मिलीसेकंड

मिलीसेकंड में कुंजी की समाप्ति निर्धारित करें।

7 PEXPIREAT कुंजी मिलीसेकंड-टाइमस्टैम्प

मिलीसेकंड के रूप में निर्दिष्ट यूनिक्स टाइमस्टैम्प में कुंजी की समाप्ति निर्धारित करता है।

8 कुंजी पैटर्न

निर्दिष्ट पैटर्न से मेल खाती सभी कुंजियों को ढूँढता है।

9 MOVE कुंजी डीबी

किसी अन्य डेटाबेस के लिए एक कुंजी ले जाता है।

10 PERSIST कुंजी

कुंजी से समाप्ति को हटाता है।

1 1 PTTL कुंजी

मिलीसेकंड में एक्सपायरी में शेष समय हो जाता है।

12 टीटीएल कुंजी

शेष समय चाबियों में समाप्त हो जाता है।

13 RANDOMKEY

Redis से एक यादृच्छिक कुंजी लौटाता है।

14 RENAME प्रमुख newkey

कुंजी नाम बदलता है।

15 RENAMENX प्रमुख newkey

यदि नई कुंजी मौजूद नहीं है, तो कुंजी का नाम बदल देता है।

16 TYPE कुंजी

कुंजी में संग्रहीत मान का डेटा प्रकार लौटाता है।

रेडिस स्ट्रिंग्स कमांड को रेडिस में स्ट्रिंग मान के प्रबंधन के लिए उपयोग किया जाता है। Redis string कमांड का उपयोग करने के लिए सिंटैक्स निम्नलिखित है।

वाक्य - विन्यास

redis 127.0.0.1:6379> COMMAND KEY_NAME

उदाहरण

redis 127.0.0.1:6379> SET tutorialspoint redis 
OK 
redis 127.0.0.1:6379> GET tutorialspoint 
"redis"

उपरोक्त उदाहरण में, SET तथा GET जबकि, आज्ञाएँ हैं tutorialspoint क्या चाबी है।

रेडिस स्ट्रिंग्स कमांड्स

निम्नलिखित तालिका रेडिस में स्ट्रिंग्स का प्रबंधन करने के लिए कुछ मूल आदेशों को सूचीबद्ध करती है।

अनु क्रमांक कमांड और विवरण
1 मुख्य मूल्य सेट करें

यह कमांड निर्दिष्ट कुंजी पर मान सेट करता है।

2 चाबी देना

एक कुंजी का मूल्य हो जाता है।

3 GETRANGE कुंजी प्रारंभ अंत

एक कुंजी पर संग्रहीत स्ट्रिंग का एक विकल्प हो जाता है।

4 महत्वपूर्ण मूल्य प्राप्त करें

कुंजी का स्ट्रिंग मान सेट करता है और उसका पुराना मान लौटाता है।

5 GETBIT कुंजी ऑफसेट

कुंजी पर संग्रहीत स्ट्रिंग मान में ऑफसेट पर बिट मान लौटाता है।

6 MGET key1 [key2 ..]

सभी दी गई कुंजियों का मान प्राप्त करता है

7 सेटबाइट कुंजी ऑफसेट मान

सेट या कुंजी में संग्रहीत स्ट्रिंग मान में ऑफसेट पर बिट को साफ करता है

8 SETEX कुंजी सेकंड मान

एक कुंजी की समाप्ति के साथ मूल्य सेट करता है

9 SETNX प्रमुख मूल्य

कुंजी का मान सेट करता है, केवल अगर कुंजी मौजूद नहीं है

10 SETRANGE कुंजी ऑफसेट मान

निर्दिष्ट ऑफसेट पर शुरू होने वाली कुंजी पर एक स्ट्रिंग के हिस्से को ओवरराइट करता है

1 1 STRLEN कुंजी

एक कुंजी में संग्रहीत मूल्य की लंबाई हो जाती है

12 MSET कुंजी मूल्य [मुख्य मूल्य ...]

कई मूल्यों के लिए कई कुंजी सेट करता है

13 MSETNX मुख्य मूल्य [मुख्य मूल्य ...]

कई कुंजियों को कई मानों में सेट करता है, केवल अगर कोई भी कुंजी मौजूद नहीं है

14 PSETEX कुंजी मिलीसेकंड मान

एक कुंजी के मिलीसेकंड में मूल्य और समाप्ति सेट करता है

15 INCR कुंजी

एक से एक कुंजी के पूर्णांक मूल्य को बढ़ाता है

16 INCRBY प्रमुख वेतन वृद्धि

दी गई राशि से एक कुंजी के पूर्णांक मूल्य को बढ़ाता है

17 INCRBYFLOAT प्रमुख वेतन वृद्धि

दी गई राशि से एक कुंजी के फ्लोट मूल्य को बढ़ाता है

18 DECR कुंजी

एक के बाद एक कुंजी के पूर्णांक मूल्य को घटाता है

19 महत्वपूर्ण गिरावट

दी गई संख्या से किसी कुंजी के पूर्णांक मान को घटाता है

20 मुख्य मूल्य का मूल्यांकन करें

एक कुंजी के लिए एक मूल्य जोड़ता है

Redis Hashes स्ट्रिंग फ़ील्ड्स और स्ट्रिंग मानों के बीच के नक्शे हैं। इसलिए, वे वस्तुओं का प्रतिनिधित्व करने के लिए सही डेटा प्रकार हैं।

रेडिस में, प्रत्येक हैश 4 बिलियन से अधिक फ़ील्ड-वैल्यू जोड़े को स्टोर कर सकता है।

उदाहरण

redis 127.0.0.1:6379> HMSET tutorialspoint name "redis tutorial" 
description "redis basic commands for caching" likes 20 visitors 23000 
OK 
redis 127.0.0.1:6379> HGETALL tutorialspoint  
1) "name" 
2) "redis tutorial" 
3) "description" 
4) "redis basic commands for caching" 
5) "likes" 
6) "20" 
7) "visitors" 
8) "23000"

उपर्युक्त उदाहरण में, हमने 'Tutorialspoint' नाम के रेडिस ट्यूटोरियल डिटेल (नाम, विवरण, पसंद, आगंतुक) को हैश में सेट किया है।

रेडिस हैश कमांड्स

निम्न तालिका हैश से संबंधित कुछ बुनियादी आदेशों को सूचीबद्ध करती है।

अनु क्रमांक कमांड और विवरण
1 HDEL कुंजी फ़ील्ड 2 [field2]

एक या अधिक हैश फ़ील्ड हटाता है।

2 HEXISTS प्रमुख क्षेत्र

निर्धारित करता है कि हैश फ़ील्ड मौजूद है या नहीं।

3 HGET कुंजी क्षेत्र

निर्दिष्ट कुंजी पर संग्रहीत हैश फ़ील्ड का मान हो जाता है।

4 HGETALL कुंजी

निर्दिष्ट कुंजी पर एक हैश में संग्रहीत सभी फ़ील्ड और मान प्राप्त होते हैं

5 HINCRBY प्रमुख क्षेत्र वृद्धि

दिए गए नंबर द्वारा हैश फ़ील्ड के पूर्णांक मान को बढ़ाता है

6 HINCRBYFLOAT प्रमुख क्षेत्र वृद्धि

दी गई राशि से हैश फ़ील्ड के फ़्लोट मान को बढ़ाता है

7 HKEYS कुंजी

एक हैश में सभी क्षेत्रों हो जाता है

8 HLEN कुंजी

एक हैश में खेतों की संख्या हो जाती है

9 HMGET कुंजी फ़ील्ड 1 [field2]

सभी दिए गए हैश फ़ील्ड के मान प्राप्त करता है

10 HMSET कुंजी फ़ील्ड 1 मान 1 [फ़ील्ड 2 मान 2]

एकाधिक हैश फ़ील्ड को कई मानों पर सेट करता है

1 1 HSET प्रमुख फ़ील्ड मान

एक हैश फ़ील्ड का स्ट्रिंग मान सेट करता है

12 HSETNX प्रमुख फ़ील्ड मान

हैश फ़ील्ड का मान सेट करता है, केवल यदि फ़ील्ड मौजूद नहीं है

13 HVALS कुंजी

एक हैश में सभी मूल्यों हो जाता है

14 HSCAN प्रमुख कर्सर [MATCH पैटर्न] [COUNT गणना]

आकस्मिक रूप से हैश फ़ील्ड और संबंधित मान पुनरावृत्त होते हैं

Redis Lists आवेषण के क्रम से छंटे हुए तारों की सूची हैं। आप सिर या सूची की पूंछ में रेडिस सूचियों में तत्व जोड़ सकते हैं।

एक सूची की अधिकतम लंबाई 2 32 - 1 तत्व (4294967295, 4 बिलियन से अधिक तत्व प्रति सूची) है।

उदाहरण

redis 127.0.0.1:6379> LPUSH tutorials redis 
(integer) 1 
redis 127.0.0.1:6379> LPUSH tutorials mongodb 
(integer) 2 
redis 127.0.0.1:6379> LPUSH tutorials mysql 
(integer) 3 
redis 127.0.0.1:6379> LRANGE tutorials 0 10  
1) "mysql" 
2) "mongodb" 
3) "redis"

उपरोक्त उदाहरण में, कमांड द्वारा 'ट्यूटोरियल' नाम की रेडिस सूची में तीन मान डाले गए हैं LPUSH

रेडिस लिस्ट्स कमांड्स

निम्न तालिका सूचियों से संबंधित कुछ बुनियादी आदेशों को सूचीबद्ध करती है।

अनु क्रमांक कमांड और विवरण
1 BLPOP key1 [key2] टाइमआउट

सूची में पहला तत्व निकालता है और तब तक प्राप्त करता है जब तक कि कोई उपलब्ध न हो जाए

2 BRPOP key1 [key2] टाइमआउट

एक सूची में अंतिम तत्व को निकालता है और प्राप्त करता है, या एक उपलब्ध होने तक ब्लॉक करता है

3 BRPOPLPUSH स्रोत गंतव्य समयबाह्य

एक सूची से एक मूल्य लेता है, इसे दूसरी सूची में धकेलता है और इसे वापस करता है; या एक उपलब्ध होने तक ब्लॉक

4 LINDEX प्रमुख सूचकांक

एक सूची से एक तत्व अपने सूचकांक द्वारा हो जाता है

5 LINSERT कुंजी से पहले | पिवट मूल्य के बाद

सूची में किसी अन्य तत्व से पहले या बाद में एक तत्व सम्मिलित करता है

6 एलएलएन कुंजी

एक सूची की लंबाई हो जाती है

7 एलपीओपी कुंजी

एक सूची में पहला तत्व निकालता है और प्राप्त करता है

8 LPUSH कुंजी मान 1 [मान 2]

एक सूची में एक या एकाधिक मान प्रस्तुत करता है

9 LPUSHX प्रमुख मूल्य

किसी सूची के लिए एक मूल्य प्रस्तुत करता है, केवल अगर सूची मौजूद है

10 LRANGE कुंजी प्रारंभ रोक

सूची से तत्वों की एक सीमा हो जाती है

1 1 LREM कुंजी गणना मूल्य

तत्वों को एक सूची से निकालता है

12 एलएसईटी प्रमुख सूचकांक मूल्य

किसी सूची में एक तत्व का मूल्य इसके सूचकांक द्वारा निर्धारित करता है

13 LTRIM कुंजी प्रारंभ रोक

एक सूची को निर्दिष्ट सीमा तक ले जाता है

14 RPOP कुंजी

एक सूची में अंतिम तत्व निकालता है और प्राप्त करता है

15 RPOPLPUSH स्रोत गंतव्य

एक सूची में अंतिम तत्व को निकालता है, इसे दूसरी सूची में जोड़ता है और इसे वापस करता है

16 RPUSH कुंजी मान 1 [मान 2]

एक सूची में एक या कई मान जोड़ता है

17 RPUSHX प्रमुख मूल्य

किसी सूची के लिए एक मूल्य लागू होता है, केवल अगर सूची मौजूद है

रेडिस सेट्स अद्वितीय तारों का एक अनियंत्रित संग्रह है। विशिष्ट साधन सेट एक कुंजी में डेटा की पुनरावृत्ति की अनुमति नहीं देते हैं।

ओ (1) में सदस्यों के अस्तित्व के लिए रेडिस सेट ऐड, रिमूव और टेस्ट (सेट के अंदर निहित तत्वों की संख्या की परवाह किए बिना लगातार)। एक सूची की अधिकतम लंबाई 2 32 - 1 तत्व (4294967295, प्रति सेट 4 अरब से अधिक तत्व) है।

उदाहरण

redis 127.0.0.1:6379> SADD tutorials redis 
(integer) 1 
redis 127.0.0.1:6379> SADD tutorials mongodb 
(integer) 1 
redis 127.0.0.1:6379> SADD tutorials mysql 
(integer) 1 
redis 127.0.0.1:6379> SADD tutorials mysql 
(integer) 0 
redis 127.0.0.1:6379> SMEMBERS tutorials  
1) "mysql" 
2) "mongodb" 
3) "redis"

उपरोक्त उदाहरण में, कमांड द्वारा 'ट्यूटोरियल' नाम के रेडिस सेट में तीन मान डाले गए हैं SADD

रेडिस सेट्स कमांड्स

निम्न तालिका सेट से संबंधित कुछ बुनियादी आदेशों को सूचीबद्ध करती है।

अनु क्रमांक कमांड और विवरण
1 SADD प्रमुख सदस्य 1 [सदस्य 2]

एक या अधिक सदस्यों को एक सेट में जोड़ता है

2 SCARD कुंजी

एक सेट में सदस्यों की संख्या हो जाती है

3 SDIFF key1 [key2]

कई सेट घटाता है

4 SDIFFSTORE गंतव्य कुंजी 1 [key2]

एकाधिक सेट को घटाता है और परिणामी सेट को एक कुंजी में संग्रहीत करता है

5 SINTER key1 [key2]

कई सेट लगाता है

6 SINTERSTORE डेस्टिनेशन key1 [key2]

एकाधिक सेट और एक कुंजी में परिणामी सेट को संग्रहीत करता है

7 SISMEMBER प्रमुख सदस्य

निर्धारित करता है कि क्या दिया गया मान किसी सेट का सदस्य है

8 SMEMBERS कुंजी

एक सेट में सभी सदस्यों हो जाता है

9 SMOVE स्रोत गंतव्य सदस्य

एक सदस्य से दूसरे सेट पर ले जाता है

10 SPOP कुंजी

एक सेट से एक यादृच्छिक सदस्य को निकालता है और लौटाता है

1 1 SRANDMEMBER कुंजी [गिनती]

एक सेट से एक या एक से अधिक यादृच्छिक सदस्य हो जाते हैं

12 SREM प्रमुख सदस्य 1 [सदस्य 2]

एक सेट से एक या एक से अधिक सदस्यों को निकालता है

13 सनियन की 1 [की 2]

कई सेट जोड़ता है

14 SUNIONSTORE डेस्टिनेशन key1 [key2]

एकाधिक सेट जोड़ता है और एक कुंजी में परिणामी सेट को संग्रहीत करता है

15 SSCAN प्रमुख कर्सर [MATCH पैटर्न] [COUNT गणना]

आकस्मिक रूप से सेट तत्वों को पुनरावृत्त करता है

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

Redis में O (1) में सदस्यों के अस्तित्व के लिए सेट, ऐड, रिमूव और टेस्ट को हल किया जाता है (सेट के अंदर निहित तत्वों की संख्या की परवाह किए बिना लगातार समय)। एक सूची की अधिकतम लंबाई 2 32 - 1 तत्व (4294967295, प्रति सेट 4 अरब से अधिक तत्व) है।

उदाहरण

redis 127.0.0.1:6379> ZADD tutorials 1 redis 
(integer) 1 
redis 127.0.0.1:6379> ZADD tutorials 2 mongodb 
(integer) 1 
redis 127.0.0.1:6379> ZADD tutorials 3 mysql 
(integer) 1 
redis 127.0.0.1:6379> ZADD tutorials 3 mysql 
(integer) 0 
redis 127.0.0.1:6379> ZADD tutorials 4 mysql 
(integer) 0 
redis 127.0.0.1:6379> ZRANGE tutorials 0 10 WITHSCORES  
1) "redis" 
2) "1" 
3) "mongodb" 
4) "2" 
5) "mysql" 
6) "4"

उपरोक्त उदाहरण में, कमांड द्वारा 'ट्यूटोरियल' नाम के रेडिस सॉर्ट किए गए सेट में इसके स्कोर के साथ तीन मान डाले गए हैं ZADD

रेडिस सॉर्टेड सेट कमांड्स

निम्न तालिका क्रमबद्ध सेट से संबंधित कुछ बुनियादी आदेशों को सूचीबद्ध करती है।

अनु क्रमांक कमांड और विवरण
1 ZADD प्रमुख स्कोर 1 सदस्य 1 [स्कोर 2 सदस्य 2]

एक या अधिक सदस्यों को एक सॉर्ट किए गए सेट में जोड़ता है, या इसके स्कोर को अपडेट करता है, अगर यह पहले से मौजूद है

2 ZCARD कुंजी

एक क्रमबद्ध सेट में सदस्यों की संख्या हो जाती है

3 ZCOUNT कुंजी न्यूनतम अधिकतम

सदस्यों को दिए गए मानों के भीतर अंकों के साथ क्रमबद्ध सेट में गिना जाता है

4 ZINCRBY प्रमुख वेतन वृद्धि सदस्य

सॉर्ट किए गए सेट में सदस्य के स्कोर को बढ़ाता है

5 ZINTERSTORE गंतव्य अंक कुंजी [कुंजी ...]

एकाधिक सॉर्ट किए गए सेट को संग्रहीत करता है और एक नई कुंजी में परिणामी सॉर्ट किए गए सेट को संग्रहीत करता है

6 ZLEXCOUNT कुंजी न्यूनतम अधिकतम

किसी दिए गए लेक्सिकोग्राफ़िक श्रेणी के बीच सॉर्ट किए गए सेट में सदस्यों की संख्या की गणना करता है

7 ZRANGE कुंजी प्रारंभ रोक [WITHSCORES]

अनुक्रमणिका द्वारा सॉर्ट किए गए सेट में सदस्यों की एक श्रृंखला देता है

8 ZRANGEBYLEX प्रमुख न्यूनतम अधिकतम [सीमा ऑफसेट गणना]

एक क्रमबद्ध सेट में सदस्यों की एक श्रृंखला को लेक्सोग्राफ़िक श्रेणी द्वारा लौटाता है

9 ZRANGEBYSCORE प्रमुख न्यूनतम अधिकतम [WITHSCORES] [सीमा]

स्कोर के आधार पर, क्रमबद्ध सेट में सदस्यों की एक श्रृंखला लौटाता है

10 ZRANK प्रमुख सदस्य

एक सॉर्ट किए गए सेट में एक सदस्य के सूचकांक का निर्धारण करता है

1 1 ZREM प्रमुख सदस्य [सदस्य ...]

सॉर्ट किए गए सेट से एक या अधिक सदस्य निकालता है

12 ZREMRANGEBYLEX कुंजी न्यूनतम अधिकतम

दिए गए लेक्सिकोग्राफ़िक श्रेणी के बीच एक सॉर्ट किए गए सेट में सभी सदस्यों को निकालता है

13 ZREMRANGEBYRANK कुंजी प्रारंभ रोक

सभी सदस्यों को दिए गए अनुक्रमित के भीतर एक हल किए गए सेट में निकाल देता है

14 ZREMRANGEBYSCORE कुंजी न्यूनतम अधिकतम

सभी सदस्यों को दिए गए अंकों के भीतर हल किए गए सेट में हटा देता है

15 ZREVRANGE कुंजी स्टॉप [WITHSCORES]

इंडेक्स द्वारा सॉर्ट किए गए सेट में सदस्यों की एक श्रृंखला लौटाता है, जिसमें उच्च से निम्न तक के स्कोर का आदेश दिया जाता है

16 ZREVRANGEBYSCORE प्रमुख अधिकतम मिनट [WITHSCORES]

एक क्रमबद्ध सेट में सदस्यों की एक श्रृंखला लौटाता है, स्कोर से, उच्च से निम्न क्रम के साथ

17 ZREVRANK प्रमुख सदस्य

सॉर्ट किए गए सेट में एक सदस्य के सूचकांक को निर्धारित करता है, जिसमें उच्च से निम्न तक के अंक दिए जाते हैं

18 ZSCORE प्रमुख सदस्य

दिए गए सदस्य के साथ जुड़े स्कोर को एक क्रमबद्ध सेट में प्राप्त करता है

19 ZUNIONSTORE गंतव्य संख्या कुंजी [कुंजी ...]

एकाधिक सॉर्ट किए गए सेट को जोड़ता है और परिणामस्वरूप सॉर्ट किए गए सेट को एक नई कुंजी में संग्रहीत करता है

20 ZSCAN प्रमुख कर्सर [MATCH पैटर्न] [COUNT गणना]

आकस्मिक रूप से सॉर्ट किए गए सेट तत्व और संबंधित स्कोर

Redis HyperLogLog एक एल्गोरिथ्म है, जो एक निरंतर, और छोटी मात्रा में मेमोरी का उपयोग करके सेट में अद्वितीय तत्वों की संख्या का एक अनुमान प्रदान करने के लिए यादृच्छिककरण का उपयोग करता है।

HyperLogLog 0.81% की मानक त्रुटि के साथ प्रति कुंजी 12 kbytes के आसपास बहुत कम मात्रा में स्मृति का उपयोग करके भी एक सेट की कार्डिनैलिटी का एक बहुत अच्छा अनुमान प्रदान करता है। जब तक आप 2 64 आइटम नहीं ले सकते, तब तक आपके द्वारा गिने जाने वाले आइटमों की संख्या की कोई सीमा नहीं है ।

उदाहरण

निम्नलिखित उदाहरण बताते हैं कि Redis HyperLogLog कैसे काम करता है।

redis 127.0.0.1:6379> PFADD tutorials "redis"  
1) (integer) 1  
redis 127.0.0.1:6379> PFADD tutorials "mongodb"  
1) (integer) 1  
redis 127.0.0.1:6379> PFADD tutorials "mysql"  
1) (integer) 1  
redis 127.0.0.1:6379> PFCOUNT tutorials  
(integer) 3

रेडिस हाइपरलॉग कमांड

निम्नलिखित तालिका Redis HyperLogLog से संबंधित कुछ बुनियादी आदेशों को सूचीबद्ध करती है।

अनु क्रमांक कमांड और विवरण
1 PFADD प्रमुख तत्व [तत्व ...]

निर्दिष्ट तत्वों को निर्दिष्ट HyperLogLog में जोड़ता है।

2 PFCOUNT कुंजी [कुंजी ...]

हाइपरलॉगलॉग द्वारा कुंजी (एस) में देखे गए सेट (ओं) के अनुमानित कार्डिनैलिटी को लौटाता है।

3 PFMERGE डेस्टी सोर्सकी [sourcekey ...]

एक ही में एन अलग HyperLogLogs जोड़ता है।

Redis Pub / Sub उस मैसेजिंग सिस्टम को लागू करता है जहां प्रेषक (redis शब्दावली में जिन्हें प्रकाशक कहते हैं) संदेश भेजते हैं जबकि रिसीवर (सब्सक्राइबर) उन्हें प्राप्त करते हैं। वह लिंक जिसके द्वारा संदेशों को स्थानांतरित किया जाता है, कहा जाता हैchannel

Redis में, कोई भी ग्राहक किसी भी चैनल की सदस्यता ले सकता है।

उदाहरण

निम्नलिखित उदाहरण बताते हैं कि ग्राहक अवधारणा कैसे प्रकाशित होती है। निम्नलिखित उदाहरण में, एक ग्राहक 'redisChat' नामक एक चैनल की सदस्यता लेता है।

redis 127.0.0.1:6379> SUBSCRIBE redisChat  
Reading messages... (press Ctrl-C to quit) 
1) "subscribe" 
2) "redisChat" 
3) (integer) 1

अब, दो ग्राहक 'redisChat' नाम के एक ही चैनल पर संदेश प्रकाशित कर रहे हैं और उपरोक्त ग्राहक को संदेश प्राप्त हो रहे हैं।

redis 127.0.0.1:6379> PUBLISH redisChat "Redis is a great caching technique"  
(integer) 1  
redis 127.0.0.1:6379> PUBLISH redisChat "Learn redis by tutorials point"  
(integer) 1   
1) "message" 
2) "redisChat" 
3) "Redis is a great caching technique" 
1) "message" 
2) "redisChat" 
3) "Learn redis by tutorials point"

रेडिस पबसब कमांड्स

निम्नलिखित तालिका Redis पब / उप से संबंधित कुछ बुनियादी आदेशों को सूचीबद्ध करती है।

अनु क्रमांक कमांड और विवरण
1 PSUBSCRIBE पैटर्न [पैटर्न ...]

दिए गए पैटर्न से मेल खाने वाले चैनलों की सदस्यता।

2 PUBSUB उप-तर्क [तर्क [तर्क ...]]

पब / सब सिस्टम की स्थिति बताता है। उदाहरण के लिए, कौन से क्लाइंट सर्वर पर सक्रिय हैं।

3 सार्वजनिक चैनल संदेश

एक चैनल को एक संदेश पोस्ट करता है।

4 PUNSUBSCRIBE [पैटर्न [पैटर्न ...]]

दिए गए पैटर्न से मेल खाते चैनलों पर पोस्ट किए गए संदेशों को सुनना बंद कर देता है।

5 SUBSCRIBE चैनल [चैनल ...]

दिए गए चैनलों के लिए प्रकाशित संदेशों की सूची।

6 UNSUBSCRIBE [चैनल [चैनल ...]]

दिए गए चैनलों पर पोस्ट किए गए संदेशों को सुनना बंद कर देता है।

रेडिस लेनदेन एक ही चरण में आदेशों के एक समूह के निष्पादन की अनुमति देता है। लेन-देन के दो गुण निम्नलिखित हैं।

  • लेन-देन के सभी आदेशों को क्रमिक रूप से एक ही पृथक ऑपरेशन के रूप में निष्पादित किया जाता है। यह संभव नहीं है कि किसी अन्य क्लाइंट द्वारा जारी किया गया एक अनुरोध रेडिस लेनदेन के निष्पादन के बीच में परोसा जाए।

  • रेडिस लेनदेन भी परमाणु है। परमाणु का अर्थ है या तो सभी आदेश या कोई भी संसाधित नहीं है।

नमूना

रेडिस लेनदेन को कमांड द्वारा शुरू किया जाता है MULTI और फिर आपको उन आदेशों की एक सूची पारित करने की आवश्यकता है जिन्हें लेनदेन में निष्पादित किया जाना चाहिए, जिसके बाद पूरे लेनदेन को निष्पादित किया जाता है EXEC आदेश।

redis 127.0.0.1:6379> MULTI 
OK 
List of commands here 
redis 127.0.0.1:6379> EXEC

उदाहरण

निम्नलिखित उदाहरण बताते हैं कि रेडिस लेनदेन को कैसे शुरू और निष्पादित किया जा सकता है।

redis 127.0.0.1:6379> MULTI 
OK 
redis 127.0.0.1:6379> SET tutorial redis 
QUEUED 
redis 127.0.0.1:6379> GET tutorial 
QUEUED 
redis 127.0.0.1:6379> INCR visitors 
QUEUED 
redis 127.0.0.1:6379> EXEC  
1) OK 
2) "redis" 
3) (integer) 1

Redis Transaction Commands

निम्नलिखित तालिका में रेडिस लेनदेन से संबंधित कुछ बुनियादी आदेश दिखाए गए हैं।

अनु क्रमांक कमांड और विवरण
1 रद्द करें

बहु के बाद जारी किए गए सभी आदेशों को त्याग देता है

2 कार्यकारी

बहु के बाद जारी किए गए सभी आदेशों को निष्पादित करता है

3 मल्टी

लेन-देन ब्लॉक की शुरुआत को चिह्नित करता है

4 unwatch

सभी देखे गए कुंजियों के बारे में भूल जाता है

5 देखो कुंजी [कुंजी ...]

MULTI / EXEC ब्लॉक के निष्पादन को निर्धारित करने के लिए दी गई कुंजियाँ देखता है

Redis scripting का उपयोग Lua दुभाषिया का उपयोग करके स्क्रिप्ट का मूल्यांकन करने के लिए किया जाता है। यह 2.6.0 संस्करण से शुरू होने वाले रेडिस में बनाया गया है। स्क्रिप्टिंग के लिए प्रयुक्त कमांड हैEVAL आदेश।

वाक्य - विन्यास

निम्नलिखित का मूल सिंटैक्स है EVAL आदेश।

redis 127.0.0.1:6379> EVAL script numkeys key [key ...] arg [arg ...]

उदाहरण

निम्नलिखित उदाहरण बताते हैं कि रेडिस स्क्रिप्टिंग कैसे काम करती है।

redis 127.0.0.1:6379> EVAL "return {KEYS[1],KEYS[2],ARGV[1],ARGV[2]}" 2 key1 
key2 first second  
1) "key1" 
2) "key2" 
3) "first" 
4) "second"

रेडिस स्क्रिप्टिंग कमांड्स

निम्न तालिका में रेडिस स्क्रिप्टिंग से संबंधित कुछ बुनियादी कमांड सूचीबद्ध हैं।

अनु क्रमांक कमांड और विवरण
1 EVAL स्क्रिप्ट संख्या कुंजी [कुंजी ...] arg [arg ...]

एक लुआ लिपि निष्पादित करता है।

2 EVALSHA sha1 संख्या कुंजी [कुंजी ...] arg [arg ...]

एक लुआ लिपि निष्पादित करता है।

3 SCRIPT EXISTS स्क्रिप्ट [स्क्रिप्ट ...]

स्क्रिप्ट कैश में स्क्रिप्ट के अस्तित्व की जाँच करता है।

4 SCRIPT FLUSH

स्क्रिप्ट कैश से सभी स्क्रिप्ट हटाता है।

5 SCRIPT KILL

वर्तमान में निष्पादन में स्क्रिप्ट को मारता है।

6 SCRIPT लोड स्क्रिप्ट

निर्दिष्ट Lua स्क्रिप्ट को स्क्रिप्ट कैश में लोड करता है।

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

उदाहरण

निम्नलिखित उदाहरण बताते हैं कि कैसे एक ग्राहक खुद को रेडिस सर्वर पर प्रमाणित करता है और जांचता है कि सर्वर चल रहा है या नहीं।

redis 127.0.0.1:6379> AUTH "password" 
OK 
redis 127.0.0.1:6379> PING 
PONG

रेडिस कनेक्शन कमांड्स

निम्न तालिका में रेडिस कनेक्शन से संबंधित कुछ बुनियादी कमांड सूचीबद्ध हैं।

अनु क्रमांक कमांड और विवरण
1 AUTH का पासवर्ड

दिए गए पासवर्ड के साथ सर्वर को प्रमाणित करता है

2 ECHO संदेश

दिए गए तार को प्रिंट करता है

3 पिंग

जाँचता है कि सर्वर चल रहा है या नहीं

4 छोड़ना

वर्तमान कनेक्शन को बंद कर देता है

5 इंडेक्स का चयन करें

वर्तमान कनेक्शन के लिए चयनित डेटाबेस को बदलता है

Redis सर्वर कमांड मूल रूप से Redis सर्वर का प्रबंधन करने के लिए उपयोग किया जाता है।

उदाहरण

निम्नलिखित उदाहरण बताते हैं कि हम सर्वर के बारे में सभी आंकड़े और जानकारी कैसे प्राप्त कर सकते हैं।

redis 127.0.0.1:6379> INFO  

# Server 
redis_version:2.8.13 
redis_git_sha1:00000000 
redis_git_dirty:0 
redis_build_id:c2238b38b1edb0e2 
redis_mode:standalone 
os:Linux 3.5.0-48-generic x86_64 
arch_bits:64 
multiplexing_api:epoll 
gcc_version:4.7.2 
process_id:3856 
run_id:0e61abd297771de3fe812a3c21027732ac9f41fe 
tcp_port:6379 
uptime_in_seconds:11554 
uptime_in_days:0 hz:10 
lru_clock:16651447 
config_file:  

# Clients 
connected_clients:1
client_longest_output_list:0 
client_biggest_input_buf:0 
blocked_clients:0  

# Memory 
used_memory:589016 
used_memory_human:575.21K 
used_memory_rss:2461696 
used_memory_peak:667312 
used_memory_peak_human:651.67K 
used_memory_lua:33792 
mem_fragmentation_ratio:4.18 
mem_allocator:jemalloc-3.6.0  

# Persistence 
loading:0 
rdb_changes_since_last_save:3 
rdb_bgsave_in_progress:0 
rdb_last_save_time:1409158561 
rdb_last_bgsave_status:ok 
rdb_last_bgsave_time_sec:0 
rdb_current_bgsave_time_sec:-1 
aof_enabled:0 
aof_rewrite_in_progress:0 
aof_rewrite_scheduled:0 
aof_last_rewrite_time_sec:-1 
aof_current_rewrite_time_sec:-1 
aof_last_bgrewrite_status:ok 
aof_last_write_status:ok  

# Stats 
total_connections_received:24 
total_commands_processed:294 
instantaneous_ops_per_sec:0 
rejected_connections:0 
sync_full:0 
sync_partial_ok:0 
sync_partial_err:0 
expired_keys:0 
evicted_keys:0 
keyspace_hits:41
keyspace_misses:82 
pubsub_channels:0 
pubsub_patterns:0 
latest_fork_usec:264  

# Replication 
role:master 
connected_slaves:0 
master_repl_offset:0 
repl_backlog_active:0 
repl_backlog_size:1048576 
repl_backlog_first_byte_offset:0 
repl_backlog_histlen:0  

# CPU 
used_cpu_sys:10.49 
used_cpu_user:4.96 
used_cpu_sys_children:0.00 
used_cpu_user_children:0.01  

# Keyspace 
db0:keys = 94,expires = 1,avg_ttl = 41638810 
db1:keys = 1,expires = 0,avg_ttl = 0 
db3:keys = 1,expires = 0,avg_ttl = 0

रेडिस सर्वर कमांड्स

निम्न तालिका में रेडिस सर्वर से संबंधित कुछ बुनियादी कमांड सूचीबद्ध हैं।

अनु क्रमांक कमांड और विवरण
1 BGREWRITEAOF

एसिंक्रोनस रूप से एपेंड-ओनली फ़ाइल को फिर से लिखता है

2 BGSAVE

असिंक्रोनस रूप से डिस्क पर डाटासेट को बचाता है

3 ग्राहक किल [आईपी: पोर्ट] [आईडी क्लाइंट-आईडी]

एक ग्राहक के कनेक्शन को मारता है

4 ग्राहक सूची

सर्वर से क्लाइंट कनेक्शन की सूची प्राप्त करता है

5 ग्राहक का नाम

वर्तमान कनेक्शन का नाम हो जाता है

6 ग्राहक पीयूस टाइमआउट

निर्दिष्ट समय के लिए क्लाइंट से आदेशों को रोकता है

7 ग्राहक सेटनाम कनेक्शन-नाम

वर्तमान कनेक्शन नाम सेट करता है

8 ग्राहक SLOTS

नोड मैपिंग के लिए क्लस्टर स्लॉट की एक सरणी हो जाता है

9 COMMAND

रेडिस कमांड विवरण की एक सरणी हो जाती है

10 कॉमांड COUNT

रेडिस कमांड की कुल संख्या हो जाती है

1 1 कॉमांड GETKEYS

एक पूर्ण Redis कमांड दी गई कुंजियों को निकालता है

12 BGSAVE

असिंक्रोनस रूप से डिस्क पर डाटासेट को बचाता है

13 COMMAND जानकारी कमांड-नाम [कमांड-नाम ...]

विशिष्ट Redis कमांड विवरण की एक सरणी हो जाती है

14 CONFIG GET पैरामीटर

कॉन्फ़िगरेशन पैरामीटर का मान प्राप्त करता है

15 CONFIG समीक्षा

इन-मेमोरी कॉन्फ़िगरेशन के साथ कॉन्फ़िगरेशन फ़ाइल को फिर से लिखता है

16 CONFIG सेट पैरामीटर मान

दिए गए मान के लिए एक कॉन्फ़िगरेशन पैरामीटर सेट करता है

17 CONFIG RESETSTAT

INFO द्वारा लौटाए गए आँकड़े रीसेट करता है

18 DBSIZE

चयनित डेटाबेस में कुंजियों की संख्या लौटाता है

19 DEBUG OBJECT कुंजी

एक कुंजी के बारे में जानकारी डीबगिंग हो जाता है

20 DEBUG SEGFAULT

सर्वर क्रैश कर देता है

21 FLUSHALL

सभी डेटाबेस से सभी कुंजियों को निकालता है

22 FLUSHDB

वर्तमान डेटाबेस से सभी कुंजियों को निकालता है

23 जानकारी [अनुभाग]

सर्वर के बारे में जानकारी और आँकड़े प्राप्त करता है

24 LASTSAVE

डिस्क के लिए अंतिम सफल सहेजें के UNIX समय स्टैम्प हो जाता है

25 निगरानी

वास्तविक समय में सर्वर द्वारा प्राप्त सभी अनुरोधों की सूची

26 भूमिका

प्रतिकृति के संदर्भ में उदाहरण की भूमिका देता है

27 सहेजें

सिंक्रोनस डिस्क पर डेटासेट को सेव करता है

28 SHUTDOWN [NOSAVE] [SAVE]

सिंक्रनाइज़ किए गए डेटासेट को डिस्क पर सहेजता है और फिर सर्वर को बंद कर देता है

29 SLAVEOF होस्ट पोर्ट

सर्वर को दूसरे उदाहरण का दास बनाता है, या इसे एक मास्टर के रूप में बढ़ावा देता है

30 SLOWLOG उप-तर्क [तर्क]

Redis धीमी क्वेरी लॉग का प्रबंधन करता है

31 समन्वयन

प्रतिकृति के लिए प्रयुक्त कमांड

32 समय

वर्तमान सर्वर समय देता है

Redis SAVE वर्तमान Redis डेटाबेस का बैकअप बनाने के लिए कमांड का उपयोग किया जाता है।

वाक्य - विन्यास

निम्नलिखित लालियों का मूल सिंटैक्स है SAVE आदेश।

127.0.0.1:6379> SAVE

उदाहरण

निम्न उदाहरण वर्तमान डेटाबेस का बैकअप बनाता है।

127.0.0.1:6379> SAVE  
OK

यह कमांड एक बनाएगा dump.rdb अपने Redis निर्देशिका में फ़ाइल।

Redis Data को पुनर्स्थापित करें

Redis डेटा को पुनर्स्थापित करने के लिए, Redis बैकअप फ़ाइल (dip.rdb) को अपनी Redis निर्देशिका में ले जाएँ और सर्वर शुरू करें। अपनी Redis निर्देशिका प्राप्त करने के लिए, का उपयोग करेंCONFIG नीचे दिखाए अनुसार रेडिस की कमान।

127.0.0.1:6379> CONFIG get dir  
1) "dir" 
2) "/user/tutorialspoint/redis-2.8.13/src"

उपरोक्त कमांड के आउटपुट में /user/tutorialspoint/redis-2.8.13/src निर्देशिका है, जहां Redis सर्वर स्थापित है।

Bgsave

Redis बैकअप बनाने के लिए, एक वैकल्पिक कमांड BGSAVEभी उपलब्ध है। यह कमांड बैकअप प्रक्रिया शुरू करेगा और इसे बैकग्राउंड में रन करेगा।

उदाहरण

127.0.0.1:6379> BGSAVE  
Background saving started

रेडिस डेटाबेस को सुरक्षित किया जा सकता है, जैसे कि कनेक्शन बनाने वाले किसी भी ग्राहक को कमांड निष्पादित करने से पहले प्रमाणित करने की आवश्यकता होती है। रेडिस को सुरक्षित करने के लिए, आपको पासवर्ड को कॉन्‍फ़िगर फ़ाइल में सेट करना होगा।

उदाहरण

निम्न उदाहरण आपके Redis उदाहरण को सुरक्षित करने के लिए चरण दिखाता है।

127.0.0.1:6379> CONFIG get requirepass 
1) "requirepass" 
2) ""

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

127.0.0.1:6379> CONFIG set requirepass "tutorialspoint" 
OK 
127.0.0.1:6379> CONFIG get requirepass 
1) "requirepass" 
2) "tutorialspoint"

पासवर्ड सेट करने के बाद, यदि कोई क्लाइंट बिना प्रमाणीकरण के कमांड चलाता है, तो (error) NOAUTH Authentication required। त्रुटि वापस आ जाएगी। इसलिए, क्लाइंट को उपयोग करने की आवश्यकता हैAUTH खुद को प्रमाणित करने की आज्ञा।

वाक्य - विन्यास

निम्नलिखित का मूल सिंटैक्स है AUTH आदेश।

127.0.0.1:6379> AUTH password

उदाहरण

127.0.0.1:6379> AUTH "tutorialspoint" 
OK 
127.0.0.1:6379> SET mykey "Test value" 
OK 
127.0.0.1:6379> GET mykey 
"Test value"

Redis बेंचमार्क एक साथ n कमांड चलाकर Redis के प्रदर्शन की जांच करने की उपयोगिता है।

वाक्य - विन्यास

निम्नलिखित Redis बेंचमार्क का मूल सिंटैक्स है।

redis-benchmark [option] [option value]

उदाहरण

उदाहरण के बाद 100000 आदेशों को कॉल करके रेडिस की जाँच करता है।

redis-benchmark -n 100000  

PING_INLINE: 141043.72 requests per second 
PING_BULK: 142857.14 requests per second 
SET: 141442.72 requests per second 
GET: 145348.83 requests per second 
INCR: 137362.64 requests per second 
LPUSH: 145348.83 requests per second 
LPOP: 146198.83 requests per second 
SADD: 146198.83 requests per second 
SPOP: 149253.73 requests per second 
LPUSH (needed to benchmark LRANGE): 148588.42 requests per second 
LRANGE_100 (first 100 elements): 58411.21 requests per second 
LRANGE_300 (first 300 elements): 21195.42 requests per second 
LRANGE_500 (first 450 elements): 14539.11 requests per second 
LRANGE_600 (first 600 elements): 10504.20 requests per second 
MSET (10 keys): 93283.58 requests per second

निम्नलिखित Redis बेंचमार्क में उपलब्ध विकल्पों की एक सूची है।

अनु क्रमांक विकल्प विवरण डिफ़ॉल्ट मान
1 -h सर्वर होस्ट नाम निर्दिष्ट करता है 127.0.0.1
2 -p सर्वर पोर्ट निर्दिष्ट करता है 6379
3 -s सर्वर सॉकेट निर्दिष्ट करता है
4 -c समानांतर कनेक्शन की संख्या निर्दिष्ट करता है 50
5 -n अनुरोधों की कुल संख्या निर्दिष्ट करता है 10000
6 -d बाइट में SET / GET मान का डेटा आकार निर्दिष्ट करता है 2
7 -k 1 = जीवित रखना, 0 = फिर से जोड़ना 1
8 -r एसएटीडी के लिए एसईटी / जीईटी / आईएनसीआर, यादृच्छिक मूल्यों के लिए यादृच्छिक कुंजियों का उपयोग करें
9 -p पाइपलाइन <numreq> अनुरोध 1
10 -h सर्वर होस्ट नाम निर्दिष्ट करता है
1 1 -q फोर्सेस क्विट टू रेडिस। बस क्वेरी / सेकंड मान दिखाता है
12 --csv सीएसवी प्रारूप में आउटपुट
13 -l पाश उत्पन्न करता है, परीक्षण हमेशा के लिए चलाएं
14 -t केवल परीक्षण की अल्पविराम से अलग की गई सूची को चलाता है
15 -I निष्क्रिय अंदाज़। बस एन निष्क्रिय कनेक्शन खोलता है और प्रतीक्षा करें

उदाहरण

निम्नलिखित उदाहरण Redis बेंचमार्क उपयोगिता में कई उपयोग विकल्पों को दर्शाता है।

redis-benchmark -h 127.0.0.1 -p 6379 -t set,lpush -n 100000 -q  

SET: 146198.83 requests per second 
LPUSH: 145560.41 requests per second

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

  • क्लाइंट सॉकेट को गैर-अवरुद्ध अवस्था में रखा जाता है क्योंकि Redis मल्टीप्लेक्सिंग और गैर-अवरुद्ध I / O का उपयोग करता है।

  • TCP_NODELAY विकल्प यह सुनिश्चित करने के लिए सेट किया गया है कि हमारे कनेक्शन में देरी न हो।

  • एक पठनीय फ़ाइल ईवेंट बनाया जाता है ताकि Redis सॉकेट पर पढ़ने के लिए नया डेटा उपलब्ध होते ही क्लाइंट प्रश्नों को एकत्र कर सके।

ग्राहकों की अधिकतम संख्या

Redis config (redis.conf) में, एक संपत्ति है जिसे कहा जाता है maxclients, जो ग्राहकों की अधिकतम संख्या का वर्णन करता है जो रेडिस से जुड़ सकते हैं।

निम्नलिखित कमांड का मूल सिंटैक्स है।

config get maxclients  

1) "maxclients" 
2) "10000"

डिफ़ॉल्ट रूप से, यह गुण 10000 पर सेट है (OS की अधिकतम फ़ाइल डिस्क्रिप्टर सीमा की संख्या के आधार पर), हालाँकि आप इस गुण को बदल सकते हैं।

उदाहरण

निम्नलिखित उदाहरण में, हमने सर्वर शुरू करते समय अधिकतम ग्राहकों की संख्या 100000 निर्धारित की है।

redis-server --maxclients 100000

क्लाइंट कमांड्स

अनु क्रमांक आदेश विवरण
1 CLIENT LIST Redis सर्वर से जुड़े क्लाइंट की सूची लौटाता है
2 CLIENT SETNAME वर्तमान कनेक्शन के लिए एक नाम असाइन करता है
3 CLIENT GETNAME CLIENT SETNAME द्वारा निर्धारित वर्तमान कनेक्शन का नाम लौटाता है
4 CLIENT PAUSE यह एक कनेक्शन नियंत्रण कमांड है जो निर्दिष्ट राशि (मिलीसेकंड में) के लिए सभी रेडिस ग्राहकों को निलंबित करने में सक्षम है।
5 CLIENT KILL यह कमांड किसी दिए गए क्लाइंट कनेक्शन को बंद कर देता है।

रेडिस एक टीसीपी सर्वर है और अनुरोध / प्रतिक्रिया प्रोटोकॉल का समर्थन करता है। रेडिस में, निम्नलिखित चरणों के साथ एक अनुरोध पूरा किया जाता है -

  • क्लाइंट सर्वर को एक क्वेरी भेजता है, और सॉकेट से पढ़ता है, आमतौर पर एक अवरुद्ध तरीके से, सर्वर प्रतिक्रिया के लिए।

  • सर्वर कमांड को प्रोसेस करता है और क्लाइंट को प्रतिक्रिया भेजता है।

मीनिंग ऑफ Pipelining

पाइपलाइनिंग का मूल अर्थ है, ग्राहक सर्वर के लिए कई अनुरोधों को बिना किसी उत्तर के प्रतीक्षा कर सकता है, और अंत में एक ही चरण में उत्तरों को पढ़ता है।

उदाहरण

रेडिस पाइपलाइनिंग की जांच करने के लिए, बस रेडिस उदाहरण शुरू करें और टर्मिनल में निम्न कमांड टाइप करें।

$(echo -en "PING\r\n SET tutorial redis\r\nGET tutorial\r\nINCR 
visitor\r\nINCR visitor\r\nINCR visitor\r\n"; sleep 10) | nc localhost 6379  
+PONG 
+OK 
redis 
:1 
:2 
:3

उपरोक्त उदाहरण में, हम उपयोग करके Redis कनेक्शन की जांच करेंगे PINGआदेश। हमने एक स्ट्रिंग सेट किया है जिसका नाम हैtutorial मूल्य के साथ redis। बाद में, हम उस कुंजी को प्राप्त करते हैं और आगंतुक संख्या को तीन गुना बढ़ाते हैं। परिणाम में, हम देख सकते हैं कि सभी कमांड एक बार रेडिस को सबमिट किए जाते हैं, और रेडिस एक ही चरण में सभी कमांड का आउटपुट प्रदान करता है।

पाइप लाइनिंग के लाभ

इस तकनीक का लाभ काफी बेहतर प्रोटोकॉल प्रदर्शन है। पाइपलाइनिंग द्वारा प्राप्त स्पीडअप पांच के एक कारक से लेकर लोकलहोस्ट तक के कनेक्शन के लिए कम से कम एक सौ से अधिक स्लिनेट इंटरनेट कनेक्शन के कारक तक होता है।

विभाजन आपके डेटा को कई Redis उदाहरणों में विभाजित करने की प्रक्रिया है, ताकि हर उदाहरण में केवल आपकी कुंजियों का सबसेट होगा।

विभाजन के लाभ

  • यह कई कंप्यूटरों की मेमोरी के योग का उपयोग करते हुए बहुत बड़े डेटाबेस के लिए अनुमति देता है। विभाजन के बिना आप एक कंप्यूटर का समर्थन करने वाली मेमोरी की मात्रा तक सीमित हो सकते हैं।

  • यह कई कोर और कई कंप्यूटरों के लिए कम्प्यूटेशनल पावर और कई कंप्यूटर और नेटवर्क एडेप्टर के लिए नेटवर्क बैंडविड्थ को स्केल करने की अनुमति देता है।

विभाजन के नुकसान

  • कई कुंजियों से जुड़े संचालन आमतौर पर समर्थित नहीं होते हैं। उदाहरण के लिए, आप दो सेटों के बीच चौराहे का प्रदर्शन नहीं कर सकते हैं यदि वे कुंजी में संग्रहीत किए जाते हैं जो अलग-अलग रेडिस उदाहरणों में मैप किए जाते हैं।

  • कई कुंजियों वाले रेडिस लेनदेन का उपयोग नहीं किया जा सकता है।

  • विभाजन ग्रैन्युलैरियरी कुंजी है, इसलिए एक बहुत बड़ी सॉर्ट किए गए सेट की तरह एक एकल कुंजी के साथ एक डेटासेट को शार्द करना संभव नहीं है।

  • जब विभाजन का उपयोग किया जाता है, तो डेटा हैंडलिंग अधिक जटिल है। उदाहरण के लिए, आपको कई RDB / AOF फ़ाइलों को संभालना होगा, और अपने डेटा का बैकअप लेने के लिए आपको कई उदाहरणों और मेजबानों से दृढ़ता फ़ाइलों को एकत्र करने की आवश्यकता होगी।

  • क्षमता को जोड़ना और निकालना जटिल हो सकता है। उदाहरण के लिए, रेडिस क्लस्टर रनटाइम में नोड्स को जोड़ने और हटाने की क्षमता के साथ डेटा के ज्यादातर पारदर्शी पुनर्संतुलन का समर्थन करता है। हालाँकि, क्लाइंट-साइड विभाजन और प्रॉक्सी जैसी अन्य प्रणालियाँ इस सुविधा का समर्थन नहीं करती हैं। नामक एक तकनीकPresharding इस संबंध में मदद करता है।

विभाजन के प्रकार

रेडिस में दो प्रकार के विभाजन उपलब्ध हैं। मान लीजिए कि हमारे पास चार Redis इंस्टेंस, R0, R1, R2, R3 और कई कुंजियाँ हैं जो उपयोगकर्ता जैसे उपयोगकर्ता का प्रतिनिधित्व करती हैं: 1, उपयोगकर्ता: 2, ... और आगे।

श्रेणी विभाजन

श्रेणी विभाजन विशिष्ट रेडिस उदाहरणों में वस्तुओं की श्रृंखलाओं को मैप करके पूरा किया जाता है। हमारे उदाहरण के अनुसार, आईडी 0 से आईडी 10000 तक के उपयोगकर्ता R0 में जाएंगे, जबकि आईडी 10001 से आईडी 20000 तक के उपयोगकर्ता उदाहरण R1 और इसके बाद के संस्करण में जाएंगे।

हैश विभाजन

इस प्रकार के विभाजन में, एक हैश फ़ंक्शन (जैसे। मापांक फ़ंक्शन) का उपयोग कुंजी को संख्या में परिवर्तित करने के लिए किया जाता है और फिर डेटा को अलग-अलग रेडिस उदाहरणों में संग्रहीत किया जाता है।

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

इंस्टालेशन

अब, देखते हैं कि Redis Java ड्राइवर कैसे सेट करें।

  • आपको जार को पथ से डाउनलोड करने की आवश्यकता है Download jedis.jar। इसके नवीनतम रिलीज को डाउनलोड करना सुनिश्चित करें।

  • आपको शामिल करने की आवश्यकता है jedis.jar अपने वर्गपथ में।

Redis Server से कनेक्ट करें

import redis.clients.jedis.Jedis; 

public class RedisJava { 
   public static void main(String[] args) { 
      //Connecting to Redis server on localhost 
      Jedis jedis = new Jedis("localhost"); 
      System.out.println("Connection to server sucessfully"); 
      //check whether server is running or not 
      System.out.println("Server is running: "+jedis.ping()); 
   } 
}

अब, रेडिस सर्वर से कनेक्शन का परीक्षण करने के लिए उपरोक्त प्रोग्राम को संकलित करें और चलाएं। आप अपनी आवश्यकता के अनुसार अपना रास्ता बदल सकते हैं। हम इसका वर्तमान संस्करण मान रहे हैंjedis.jar वर्तमान पथ में उपलब्ध है।

$javac RedisJava.java 
$java RedisJava 
Connection to server sucessfully 
Server is running: PONG

रेडिस जावा स्ट्रिंग उदाहरण

import redis.clients.jedis.Jedis; 

public class RedisStringJava { 
   public static void main(String[] args) { 
      //Connecting to Redis server on localhost 
      Jedis jedis = new Jedis("localhost"); 
      System.out.println("Connection to server sucessfully"); 
      //set the data in redis string 
      jedis.set("tutorial-name", "Redis tutorial"); 
      // Get the stored data and print it 
      System.out.println("Stored string in redis:: "+ jedis.get("tutorialname")); 
   } 
}

अब, ऊपर दिए गए प्रोग्राम को संकलित करें और चलाएं।

$javac RedisStringJava.java 
$java RedisStringJava 
Connection to server sucessfully 
Stored string in redis:: Redis tutorial

रेडिस जावा सूची उदाहरण

import redis.clients.jedis.Jedis; 

public class RedisListJava { 
   public static void main(String[] args) { 
   
      //Connecting to Redis server on localhost 
      Jedis jedis = new Jedis("localhost"); 
      System.out.println("Connection to server sucessfully"); 
      
      //store data in redis list 
      jedis.lpush("tutorial-list", "Redis"); 
      jedis.lpush("tutorial-list", "Mongodb"); 
      jedis.lpush("tutorial-list", "Mysql"); 
      // Get the stored data and print it 
      List<String> list = jedis.lrange("tutorial-list", 0 ,5); 
      
      for(int i = 0; i<list.size(); i++) { 
         System.out.println("Stored string in redis:: "+list.get(i)); 
      } 
   } 
}

अब, ऊपर दिए गए प्रोग्राम को संकलित करें और चलाएं।

$javac RedisListJava.java 
$java RedisListJava 
Connection to server sucessfully 
Stored string in redis:: Redis 
Stored string in redis:: Mongodb 
Stored string in redis:: Mysql

Redis Java Keys उदाहरण

import redis.clients.jedis.Jedis; 

public class RedisKeyJava { 
   public static void main(String[] args) { 
   
      //Connecting to Redis server on localhost 
      Jedis jedis = new Jedis("localhost"); 
      System.out.println("Connection to server sucessfully"); 
      //store data in redis list 
      // Get the stored data and print it 
      List<String> list = jedis.keys("*"); 
      
      for(int i = 0; i<list.size(); i++) { 
         System.out.println("List of stored keys:: "+list.get(i)); 
      } 
   } 
}

अब, ऊपर दिए गए प्रोग्राम को संकलित करें और चलाएं।

$javac RedisKeyJava.java 
$java RedisKeyJava 
Connection to server sucessfully 
List of stored keys:: tutorial-name 
List of stored keys:: tutorial-list

इससे पहले कि आप अपने PHP कार्यक्रमों में Redis का उपयोग करना शुरू करें, आपको यह सुनिश्चित करने की आवश्यकता है कि आपके पास Redis PHP ड्राइवर और PHP मशीन पर सेट है। आप अपने मशीन पर PHP स्थापना के लिए PHP ट्यूटोरियल की जांच कर सकते हैं।

इंस्टालेशन

अब, Redis PHP ड्राइवर सेट करने के तरीके की जाँच करते हैं।

आपको github रिपॉजिटरी से phpredis डाउनलोड करने की आवश्यकता है https://github.com/nicolasff/phpredis। एक बार जब आप इसे डाउनलोड कर लेते हैं, तो फाइल को phpredis निर्देशिका में निकालें। उबंटू पर, निम्न एक्सटेंशन स्थापित करें।

cd phpredis 
sudo phpize 
sudo ./configure 
sudo make 
sudo make install

अब, PHP विस्तार निर्देशिका में "मॉड्यूल" फ़ोल्डर की सामग्री को कॉपी और पेस्ट करें और निम्नलिखित पंक्तियों को जोड़ें php.ini

extension = redis.so

अब, आपका Redis PHP संस्थापन पूरा हो गया है

Redis Server से कनेक्ट करें

<?php 
   //Connecting to Redis server on localhost 
   $redis = new Redis(); 
   $redis->connect('127.0.0.1', 6379); echo "Connection to server sucessfully"; //check whether server is running or not echo "Server is running: ".$redis->ping(); 
?>

जब प्रोग्राम निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम देगा।

Connection to server sucessfully 
Server is running: PONG

Redis PHP स्ट्रिंग उदाहरण

<?php 
   //Connecting to Redis server on localhost 
   $redis = new Redis(); $redis->connect('127.0.0.1', 6379); 
   echo "Connection to server sucessfully"; 
   //set the data in redis string 
   $redis->set("tutorial-name", "Redis tutorial"); // Get the stored data and print it echo "Stored string in redis:: " .$redis→get("tutorial-name"); 
?>

जब उपरोक्त कार्यक्रम निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम देगा।

Connection to server sucessfully 
Stored string in redis:: Redis tutorial

रेडिस php सूची उदाहरण

<?php 
   //Connecting to Redis server on localhost 
   $redis = new Redis(); $redis->connect('127.0.0.1', 6379); 
   echo "Connection to server sucessfully"; 
   //store data in redis list 
   $redis->lpush("tutorial-list", "Redis"); $redis->lpush("tutorial-list", "Mongodb"); 
   $redis->lpush("tutorial-list", "Mysql"); // Get the stored data and print it $arList = $redis->lrange("tutorial-list", 0 ,5); echo "Stored string in redis:: "; print_r($arList); 
?>

जब उपरोक्त कार्यक्रम निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम देगा।

Connection to server sucessfully 
Stored string in redis:: 
Redis 
Mongodb 
Mysql

Redis PHP Keys उदाहरण

<?php 
   //Connecting to Redis server on localhost 
   $redis = new Redis(); $redis->connect('127.0.0.1', 6379); 
   echo "Connection to server sucessfully"; 
   // Get the stored keys and print it 
   $arList = $redis->keys("*"); 
   echo "Stored keys in redis:: " 
   print_r($arList); 
?>

जब प्रोग्राम निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम देगा।

Connection to server sucessfully 
Stored string in redis:: 
tutorial-name 
tutorial-list