Redis的部署使用文檔

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

環境:CentOS 5.5  x64

下載安裝:

  1. cd /root/tools 
  2. wget http://redis.googlecode.com/files/redis-2.4.2.tar.gz 
  3. tar zxvf redis-2.4.2.tar.gz 
  4. cd redis-2.4.2 
  5. make && make install 
  6. cp redis.conf  /etc/ 
  7. cd  
  1. vi /etc/redis.conf 
  1. daemonize yes 
  2. pidfile /var/run/redis.pid 
  3. port 6379 
  4.  
  5. #bind 127.0.0.1 
  6. timeout 600 
  7. loglevel notice 
  8. logfile /elain/logs/redis/redis.log 
  9.  
  10. databases 16 
  11.  
  12. save 900 1 
  13. save 300 10 
  14. save 60 10000 
  15.  
  16. rdbcompression yes 
  17. dbfilename dump.rdb 
  18.  
  19. dir /elain/data/redis/ 
  20.  
  21. # maxclients 128 
  22.  
  23. appendonly yes 
  24. appendfilename appendonly.aof 
  25.  
  26. # appendfsync always 
  27. appendfsync everysec 
  28. # appendfsync no 
  29.  
  30. requirepass elain 
  31.  
  32. no-appendfsync-on-rewrite no 
  33. auto-aof-rewrite-percentage 100 
  34. auto-aof-rewrite-min-size 64mb 
  35.  
  36. slowlog-log-slower-than 10000 
  37.  
  38. slowlog-max-len 1024 
  39.  
  40. really-use-vm yes 
  41. vm-enabled yes 
  42. vm-swap-file /tmp/redis.swap 
  43. vm-max-memory 0 
  44. vm-page-size 32 
  45. vm-pages 134217728 
  46. vm-max-threads 4 
  47.  
  48. hash-max-zipmap-entries 512 
  49. hash-max-zipmap-value 64 
  50.  
  51. list-max-ziplist-entries 512 
  52. list-max-ziplist-value 64 
  53.  
  54. set-max-intset-entries 512 
  55.  
  56. zset-max-ziplist-entries 128 
  57. zset-max-ziplist-value 64 
  58.  
  59. activerehashing yes 
  60.  
  61. # include /path/to/local.conf 
  62. # include /path/to/other.conf 

啓動:

  1. redis-server /etc/redis.conf 

開機加自啓動:

  1. echo "redis-server /etc/redis.conf" >>/etc/rc.local 

測試:

  1. [root@md03 ~]# redis-cli -a elain 
  2. redis 127.0.0.1:6379> set elain 123456 
  3. OK 
  4. redis 127.0.0.1:6379> get elain 
  5. "123456" 

查看狀態信息:

  1. [root@md04 ~]# redis-cli info 
  2. redis_version:2.4.2 
  3. redis_git_sha1:00000000 
  4. redis_git_dirty:0 
  5. arch_bits:64 
  6. multiplexing_api:epoll 
  7. process_id:2204 
  8. uptime_in_seconds:25 
  9. uptime_in_days:0 
  10. lru_clock:2013834 
  11. used_cpu_sys:0.00 
  12. used_cpu_user:0.00 
  13. used_cpu_sys_children:0.00 
  14. used_cpu_user_children:0.00 
  15. connected_clients:1 
  16. connected_slaves:0 
  17. client_longest_output_list:0 
  18. client_biggest_input_buf:0 
  19. blocked_clients:0 
  20. used_memory:17505392 
  21. used_memory_human:16.69M 
  22. used_memory_rss:1617920 
  23. used_memory_peak:17496792 
  24. used_memory_peak_human:16.69M 
  25. mem_fragmentation_ratio:0.09 
  26. mem_allocator:jemalloc-2.2.1 
  27. loading:0 
  28. aof_enabled:1 
  29. changes_since_last_save:5 
  30. bgsave_in_progress:0 
  31. last_save_time:1320372561 
  32. bgrewriteaof_in_progress:0 
  33. total_connections_received:1 
  34. total_commands_processed:0 
  35. expired_keys:0 
  36. evicted_keys:0 
  37. keyspace_hits:2 
  38. keyspace_misses:8 
  39. pubsub_channels:0 
  40. pubsub_patterns:0 
  41. latest_fork_usec:0 
  42. vm_enabled:1 
  43. role:master 
  44. aof_current_size:237 
  45. aof_base_size:237 
  46. aof_pending_rewrite:0 
  47. vm_conf_max_memory:0 
  48. vm_conf_page_size:32 
  49. vm_conf_pages:134217728 
  50. vm_stats_used_pages:3 
  51. vm_stats_swapped_objects:3 
  52. vm_stats_swappin_count:0 
  53. vm_stats_swappout_count:3 
  54. vm_stats_io_newjobs_len:0 
  55. vm_stats_io_processing_len:0 
  56. vm_stats_io_processed_len:0 
  57. vm_stats_io_active_threads:0 
  58. vm_stats_blocked_clients:0 
  59. db0:keys=4,expires=0 

主從同步配置:
只需把/etc/redis.conf 複製到 從機上,主、從機上把127.0.0.1 IP 改成本機ip,然後在從機上的redis.conf 裏添加以下幾行,重啓即可:

  1. slave-serve-stale-data yes 
  2. slaveof 主服務器IP 6379 
  3. masterauth <master-password> 

注:以上主從配置做了密碼驗證,也可不做驗證,不用加masterauth 選項

附上啓動腳本:
腳本用法:

  1. /etc/init.d/redis-server start|restart|stop 
  1. #!/bin/sh   
  2. #   
  3. # redis - this script starts and stops the redis-server daemon   
  4. #   
  5. # chkconfig:   - 85 15   
  6. # description:  Redis is a persistent key-value database   
  7. # processname: redis-server   
  8. # config:      /etc/redis.conf   
  9. # config:      /etc/sysconfig/redis   
  10. # pidfile:     /var/run/redis.pid   
  11.   
  12. # Source function library.   
  13. . /etc/rc.d/init.d/functions   
  14.   
  15. # Source networking configuration.   
  16. . /etc/sysconfig/network   
  17.   
  18. # Check that networking is up.   
  19. [ "$NETWORKING" = "no" ] && exit 0   
  20.   
  21. redis="/usr/local/bin/redis-server"   
  22. prog=$(basename $redis)   
  23.   
  24. REDIS_CONF_FILE="/etc/redis.conf"   
  25.   
  26. [ -f /etc/sysconfig/redis ] && . /etc/sysconfig/redis   
  27.   
  28. lockfile=/var/lock/subsys/redis   
  29.   
  30. start() {   
  31.     [ -x $redis ] || exit 5   
  32.     [ -f $REDIS_CONF_FILE ] || exit 6   
  33.     echo -n $"Starting $prog: "   
  34.     daemon $redis $REDIS_CONF_FILE   
  35.     retval=$?   
  36.     echo   
  37.     [ $retval -eq 0 ] && touch $lockfile   
  38.     return $retval   
  39. }   
  40.   
  41. stop() {   
  42.     echo -n $"Stopping $prog: "   
  43.     killproc $prog -QUIT   
  44.     retval=$?   
  45.     echo   
  46.     [ $retval -eq 0 ] && rm -f $lockfile   
  47.     return $retval   
  48. }   
  49.   
  50. restart() {   
  51.     stop   
  52.     start   
  53. }   
  54.   
  55. reload() {   
  56.     echo -n $"Reloading $prog: "   
  57.     killproc $redis -HUP   
  58.     RETVAL=$?   
  59.     echo   
  60. }   
  61.   
  62. force_reload() {   
  63.     restart   
  64. }   
  65.   
  66. rh_status() {   
  67.     status $prog   
  68. }   
  69.   
  70. rh_status_q() {   
  71.     rh_status >/dev/null 2>&1   
  72. }   
  73.   
  74. case "$1" in   
  75.     start)   
  76.         rh_status_q && exit 0   
  77.         $1   
  78.         ;;   
  79.     stop)   
  80.         rh_status_q || exit 0   
  81.         $1   
  82.         ;;   
  83.     restart|configtest)   
  84.         $1   
  85.         ;;   
  86.     reload)   
  87.         rh_status_q || exit 7   
  88.         $1   
  89.         ;;   
  90.     force-reload)   
  91.         force_reload   
  92.         ;;   
  93.     status)   
  94.         rh_status   
  95.         ;;   
  96.     condrestart|try-restart)   
  97.         rh_status_q || exit 0   
  98.         ;;   
  99.     *)   
  100.         echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart|reload|force-reload}"   
  101.         exit 2   
  102. esac

redis官方文檔:http://redis.io/documentation
redis官方操作命令全集:http://redis.io/commands
reids 各接口使用方法請參考官方文檔


附錄:
配置文件 redis.conf 詳解

daemonize  yes                                  #是否以後臺進程運行,默認爲no
pidfile  /var/run/redis.pid                     #如以後臺進程運行,則需指定一個pid,默認爲/var/run/redis.pid
bind 127.0.0.1                                  #綁定主機IP,默認值爲127.0.0.1(註釋)
port   6379                                     #監聽端口,默認爲6379
timeout  300                                    #超時時間,默認爲300(秒)
loglevel  notice                                #日誌記slave-serve-stale-data yes:在master服務器掛掉或者同步失敗時,從服務器是否繼續提供服務。錄等級,有4個可選值,debug,verbose(默認值),notice,warning
logfile   /var/log/redis.log                    #日誌記錄方式,默認值爲stdout
databases  16                                   #可用數據庫數,默認值爲16,默認數據庫爲0
save 900 1                                      #900秒(15分鐘)內至少有1個key被改變
save 300 10                                     #300秒(5分鐘)內至少有300個key被改變
save 60 10000                                   #60秒內至少有10000個key被改變
rdbcompression yes                              #存儲至本地數據庫時是否壓縮數據,默認爲yes
dbfilename dump.rdb                             #本地數據庫文件名,默認值爲dump.rdb
dir ./                                          #本地數據庫存放路徑,默認值爲 ./

slaveof 10.0.0.12 6379                          #當本機爲從服務時,設置主服務的IP及端口(註釋)
masterauth elain                                #當本機爲從服務時,設置主服務的連接密碼(註釋)
slave-serve-stale-data yes                      #在master服務器掛掉或者同步失敗時,從服務器是否繼續提供服務。
requirepass elain                               #連接密碼(註釋)

maxclients 128                                  #最大客戶端連接數,默認不限制(註釋)
maxmemory <bytes>                               #設置最大內存,達到最大內存設置後,Redis會先嚐試清除已到期或即將到期的Key,當此方法處理後,任到達最大內存設置,將無法再進行寫入操作。(註釋)
appendonly no                                   #是否在每次更新操作後進行日誌記錄,如果不開啓,可能會在斷電時導致一段時間內的數據丟失。因爲redis本身同步數據文件是按上面save條件來同步的,所以有的數據會在一段時間內只存在於內存中。默認值爲no
appendfilename   appendonly.aof                 #更新日誌文件名,默認值爲appendonly.aof(註釋)
appendfsync  everysec                           #更新日誌條件,共有3個可選值。no表示等操作系統進行數據緩存同步到磁盤,always表示每次更新操作後手動調用fsync()將數據寫到磁盤,everysec表示每秒同步一次(默認值)。

really-use-vm yes
vm-enabled  yes                                 #是否使用虛擬內存,默認值爲no
vm-swap-file /tmp/redis.swap                    #虛擬內存文件路徑,默認值爲/tmp/redis.swap,不可多個Redis實例共享
vm-max-memory 0                                 #vm大小限制。0:不限制,建議60-80% 可用內存大小。
vm-page-size 32                                 #根據緩存內容大小調整,默認32字節。
vm-pages 134217728                              #page數。每 8 page,會佔用1字節內存。
vm-page-size                                    #vm-pages 等於 swap 文件大小
vm-max-threads 4                                #vm 最大io線程數。注意: 0 標誌禁止使用vm
hash-max-zipmap-entries 512
hash-max-zipmap-value 64

list-max-ziplist-entries 512
list-max-ziplist-value 64
set-max-intset-entries 512
activerehashing yes

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章