從零搭建一個Redis服務


前言

自己在搭建redis服務的時候碰到一些問題,好多人只告訴你怎么成功搭建,但是並沒有整理過程中遇到的問題,所有樓主就花了點時間來整理下。

  • linux環境安裝redis
  • 安裝中的碰到的問題和解決辦法
  • 怎么在代碼中使用安裝的redis
  • 設置用戶名和密碼
  • 程序應用中碰到的問題

介紹

redis是一個key-value存儲系統。和Memcached類似,它支持存儲的value類型相對更多,包括string(字符串)、list(鏈表)、set(集合)、zset(sorted set --有序集合)和hash(哈希類型)。這些數據類型都支持push/pop、add/remove及取交集並集和差集及更豐富的操作,而且這些操作都是原子性的。在此基礎上,redis支持各種不同方式的排序。與memcached一樣,為了保證效率,數據都是緩存在內存中。區別的是redis會周期性的把更新的數據寫入磁盤或者把修改操作寫入追加的記錄文件,並且在此基礎上實現了master-slave(主從)同步。

Redis 是一個高性能的key-value數據庫。 redis的出現,很大程度補償了memcached這類key/value存儲的不足,在部 分場合可以對關系數據庫起到很好的補充作用。它提供了Java,C/C++,C#,PHP,JavaScript,Perl,Object-C,Python,Ruby,Erlang等客戶端,使用很方便。

一、安裝redis

1、下載安裝包

  1. cd /www/redis/ 
  2. wget http://download.redis.io/releases/redis-4.0.8.tar.gz 
  3. tar -zxvf redis-4.0.8.tar.gz 
  4. mv redis-4.0.8 redis 

2、編譯redis

  1. cd /www/redis/redis/ 
  2. make MALLOC=libc 
  3. make PREFIX=/usr/local/redis install 

3、准備配置文件

  1. cd /usr/local/redis 
  2. mkdir conf 
  3. cd conf/ 
  4. vi redis_6379.conf 

配置文件內容如下:

  1. bind 127.0.0.1 
  2. protected-mode no 
  3. port 6379 
  4. tcp-backlog 511 
  5. timeout 0 
  6. tcp-keepalive 300 
  7. daemonize yes 
  8. supervised no 
  9. pidfile /www/redis/data/redis/6379/redis_6379.pid 
  10. loglevel notice 
  11. logfile "/www/redis/data/redis/6379/log.log" 
  12. databases 16 
  13. always-show-logo yes 
  14. save 900 1 
  15. save 300 10 
  16. save 60 10000 
  17. stop-writes-on-bgsave-error yes 
  18. rdbcompression yes 
  19. rdbchecksum yes 
  20. dbfilename dump.rdb 
  21. dir /www/redis/data/redis/6379/ 
  22. slave-serve-stale-data yes 
  23. slave-read-only yes 
  24. repl-diskless-sync no 
  25. repl-diskless-sync-delay 5 
  26. repl-disable-tcp-nodelay no 
  27. slave-priority 100 
  28. lazyfree-lazy-eviction no 
  29. lazyfree-lazy-expire no 
  30. lazyfree-lazy-server-del no 
  31. slave-lazy-flush no 
  32. appendonly yes 
  33. appendfilename "appendonly.aof" 
  34. appendfsync everysec 
  35. no-appendfsync-on-rewrite no 
  36. auto-aof-rewrite-percentage 100 
  37. auto-aof-rewrite-min-size 64mb 
  38. aof-load-truncated yes 
  39. aof-use-rdb-preamble no 
  40. lua-time-limit 5000 
  41. slowlog-log-slower-than 10000 
  42. slowlog-max-len 128 
  43. latency-monitor-threshold 0 
  44. notify-keyspace-events "" 
  45. hash-max-ziplist-entries 512 
  46. hash-max-ziplist-value 64 

4、啟動服務

  1. mkdir -p /www/redis/data/redis/6379/ 
  2. cd ../bin/ 
  3. ./redis-server ../conf/redis_6379.conf 

5、使用客戶端鏈接

  1. ./redis-cli 

判斷是否啟動成功

「建議收藏」手把手教你從零搭建一個redis服務

6、使用

查看數據

  1. keys * 

設置值

  1. set oneKey 測試 

獲取值

  1. get oneKey 
「建議收藏」手把手教你從零搭建一個redis服務

二、安裝中的碰到的問題和解決辦法

問題一:

  1. WARNING: The TCP backlog setting of 511 cannot be enforced because /proc/sys/net/core/somaxconn is set to the lower value of 128. 

臨時解決辦法:

  1. echo 511 > /proc/sys/net/core/somaxconn 

永久解決辦法

  1. vi /etc/sysctl.conf 
「建議收藏」手把手教你從零搭建一個redis服務

在里面添加net.core.somaxconn= 1024 然后執行sysctl -p 就可以永久消除這個warning

「建議收藏」手把手教你從零搭建一個redis服務

問題二:

  1. WARNING overcommit_memory is set to 0! Background save may fail under low memory condition. To fix this issue add 'vm.overcommit_memory = 1' to /etc/sysctl.conf and then reboot or run the command 'sysctl vm.overcommit_memory=1' for this to take effect. 
「建議收藏」手把手教你從零搭建一個redis服務

可以參考問題一的解決

問題三:

  1. WARNING you have Transparent Huge Pages (THP) support enabled in your kernel. This will create latency and memory usage issues with Redis. To fix this issue run the command 'echo never > /sys/kernel/mm/transparent_hugepage/enabled' as root, and add it to your /etc/rc.local in order to retain the setting after a reboot. Redis must be restarted after THP is disabled 
「建議收藏」手把手教你從零搭建一個redis服務

執行命令echo never>/sys/kernel/mm/transparent hugepage/enabled

永久解決添加配置文件即可

  1. vi /etc/rc.local 

三、怎么在代碼中使用安裝的redis呢

需要引用的jar包有

  1. commons-pool-1.6.jar 
  2. jedis-2.9.0.jar 

示例代碼

  1. public static void main(String[] args) { 
  2.  //創建redis對象 
  3.  String ip = ""; 
  4.  Jedis jedis=new Jedis(ip,6379);//鏈接redis 
  5.  //記錄操作個數 
  6.  jedis.set("name", "小明"); 
  7.  System.out.println("name已經賦值"); 
  8.  String name = jedis.get("name"); 
  9.  System.out.println("賦值后獲取name的值為:"+name); 
  10.  jedis.del("name"); 
  11.  System.out.println("name已經刪除"); 
  12.  String nameT = jedis.get("name"); 
  13.  System.out.println("刪除后獲取name的值為:"+nameT);  
  14.  } 
  15. //結果 
  16. name已經賦值 
  17. 賦值后獲取name的值為:小明 
  18. name已經刪除 
  19. 刪除后獲取name的值為:null 

四、設置用戶名和密碼

1、在配置文件中redis_6379.conf直接添加requirepass 123456

2、通過命令添加

設置密碼

  1. #設置密碼 
  2. config set requirepass 123456 
「建議收藏」手把手教你從零搭建一個redis服務

查看密碼

  1. config get requirepass 

需要驗證密碼以后才可以查看

「建議收藏」手把手教你從零搭建一個redis服務

測試代碼

  1.  public static void main(String[] args) { 
  2.  //創建redis對象 
  3.  String ip = ""; 
  4.  Jedis jedis=new Jedis(ip,6379);//鏈接redis 
  5.  jedis.auth("123456"); 
  6.  //記錄操作個數 
  7.  jedis.set("name", "小明"); 
  8.  System.out.println("name已經賦值"); 
  9.  String name = jedis.get("name"); 
  10.  System.out.println("賦值后獲取name的值為:"+name); 
  11.  jedis.del("name"); 
  12.  System.out.println("name已經刪除"); 
  13.  String nameT = jedis.get("name"); 
  14.  System.out.println("刪除后獲取name的值為:"+nameT); 
  15.   
  16.  } 
  17.  #結果 
  18. name已經賦值 
  19. 賦值后獲取name的值為:小明 
  20. name已經刪除 
  21. 刪除后獲取name的值為:null 

五、應用中碰到的問題

鏈接被拒絕或者超時問題

「建議收藏」手把手教你從零搭建一個redis服務

redis剛開始配置的ip是默認ip和端口127.0.0.1:6379,這個ip只能服務的本地進行鏈接。解決辦法:

在配置文件中把這個ip給注釋

「建議收藏」手把手教你從零搭建一個redis服務

在阿里雲中配置安全組

修改好配置文件和安全組以后,可以通過阿里雲服務的外網ip和redis的端口訪問。

但是呢,又報一個問題,保護模式下拒絕訪問

「建議收藏」手把手教你從零搭建一個redis服務

根據提示修改配置文件redis_6379.conf中屬性protected-mode no,並重啟服務

再次測試代碼連接正常~

【編輯推薦】


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM