簡述: redis是一個key-value存儲系統。和Memcached類似,它支持存儲的value類型相對更多,包括string(字符串)、list(鏈表)、set(集合)和zset(有序集合)。這些數據類型都支持push/pop、add/remove及取交集並集和差集及更豐富的操作,而且這些操作都是原子性的。在此基礎上,redis支持各種不同方式的排序。與memcached一樣,爲了保證效率,數據都是緩存在內存中。區別的是redis會週期性的把更新的數據寫入磁盤或者把修改操作寫入追加的記錄文件,並且在此基礎上實現了master-slave(主從)同步。
環境:CentOS 5.5 x64
下載安裝:
- cd /root/tools
- wget http://redis.googlecode.com/files/redis-2.4.2.tar.gz
- tar zxvf redis-2.4.2.tar.gz
- cd redis-2.4.2
- make && make install
- cp redis.conf /etc/
- cd
- vi /etc/redis.conf
- daemonize yes
- pidfile /var/run/redis.pid
- port 6379
- #bind 127.0.0.1
- timeout 600
- loglevel notice
- logfile /elain/logs/redis/redis.log
- databases 16
- save 900 1
- save 300 10
- save 60 10000
- rdbcompression yes
- dbfilename dump.rdb
- dir /elain/data/redis/
- # maxclients 128
- appendonly yes
- appendfilename appendonly.aof
- # appendfsync always
- appendfsync everysec
- # appendfsync no
- requirepass elain
- no-appendfsync-on-rewrite no
- auto-aof-rewrite-percentage 100
- auto-aof-rewrite-min-size 64mb
- slowlog-log-slower-than 10000
- slowlog-max-len 1024
- really-use-vm yes
- vm-enabled yes
- vm-swap-file /tmp/redis.swap
- vm-max-memory 0
- vm-page-size 32
- vm-pages 134217728
- vm-max-threads 4
- 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
- zset-max-ziplist-entries 128
- zset-max-ziplist-value 64
- activerehashing yes
- # include /path/to/local.conf
- # include /path/to/other.conf
啓動:
- redis-server /etc/redis.conf
開機加自啓動:
- echo "redis-server /etc/redis.conf" >>/etc/rc.local
測試:
- [root@md03 ~]# redis-cli -a elain
- redis 127.0.0.1:6379> set elain 123456
- OK
- redis 127.0.0.1:6379> get elain
- "123456"
查看狀態信息:
- [root@md04 ~]# redis-cli info
- redis_version:2.4.2
- redis_git_sha1:00000000
- redis_git_dirty:0
- arch_bits:64
- multiplexing_api:epoll
- process_id:2204
- uptime_in_seconds:25
- uptime_in_days:0
- lru_clock:2013834
- used_cpu_sys:0.00
- used_cpu_user:0.00
- used_cpu_sys_children:0.00
- used_cpu_user_children:0.00
- connected_clients:1
- connected_slaves:0
- client_longest_output_list:0
- client_biggest_input_buf:0
- blocked_clients:0
- used_memory:17505392
- used_memory_human:16.69M
- used_memory_rss:1617920
- used_memory_peak:17496792
- used_memory_peak_human:16.69M
- mem_fragmentation_ratio:0.09
- mem_allocator:jemalloc-2.2.1
- loading:0
- aof_enabled:1
- changes_since_last_save:5
- bgsave_in_progress:0
- last_save_time:1320372561
- bgrewriteaof_in_progress:0
- total_connections_received:1
- total_commands_processed:0
- expired_keys:0
- evicted_keys:0
- keyspace_hits:2
- keyspace_misses:8
- pubsub_channels:0
- pubsub_patterns:0
- latest_fork_usec:0
- vm_enabled:1
- role:master
- aof_current_size:237
- aof_base_size:237
- aof_pending_rewrite:0
- vm_conf_max_memory:0
- vm_conf_page_size:32
- vm_conf_pages:134217728
- vm_stats_used_pages:3
- vm_stats_swapped_objects:3
- vm_stats_swappin_count:0
- vm_stats_swappout_count:3
- vm_stats_io_newjobs_len:0
- vm_stats_io_processing_len:0
- vm_stats_io_processed_len:0
- vm_stats_io_active_threads:0
- vm_stats_blocked_clients:0
- db0:keys=4,expires=0
主從同步配置:
只需把/etc/redis.conf 複製到 從機上,主、從機上把127.0.0.1 IP 改成本機ip,然後在從機上的redis.conf 裏添加以下幾行,重啓即可:
- slave-serve-stale-data yes
- slaveof 主服務器IP 6379
- masterauth <master-password>
注:以上主從配置做了密碼驗證,也可不做驗證,不用加masterauth 選項
附上啓動腳本:
腳本用法:
- /etc/init.d/redis-server start|restart|stop
- #!/bin/sh
- #
- # redis - this script starts and stops the redis-server daemon
- #
- # chkconfig: - 85 15
- # description: Redis is a persistent key-value database
- # processname: redis-server
- # config: /etc/redis.conf
- # config: /etc/sysconfig/redis
- # pidfile: /var/run/redis.pid
- # Source function library.
- . /etc/rc.d/init.d/functions
- # Source networking configuration.
- . /etc/sysconfig/network
- # Check that networking is up.
- [ "$NETWORKING" = "no" ] && exit 0
- redis="/usr/local/bin/redis-server"
- prog=$(basename $redis)
- REDIS_CONF_FILE="/etc/redis.conf"
- [ -f /etc/sysconfig/redis ] && . /etc/sysconfig/redis
- lockfile=/var/lock/subsys/redis
- start() {
- [ -x $redis ] || exit 5
- [ -f $REDIS_CONF_FILE ] || exit 6
- echo -n $"Starting $prog: "
- daemon $redis $REDIS_CONF_FILE
- retval=$?
- echo
- [ $retval -eq 0 ] && touch $lockfile
- return $retval
- }
- stop() {
- echo -n $"Stopping $prog: "
- killproc $prog -QUIT
- retval=$?
- echo
- [ $retval -eq 0 ] && rm -f $lockfile
- return $retval
- }
- restart() {
- stop
- start
- }
- reload() {
- echo -n $"Reloading $prog: "
- killproc $redis -HUP
- RETVAL=$?
- echo
- }
- force_reload() {
- restart
- }
- rh_status() {
- status $prog
- }
- rh_status_q() {
- rh_status >/dev/null 2>&1
- }
- case "$1" in
- start)
- rh_status_q && exit 0
- $1
- ;;
- stop)
- rh_status_q || exit 0
- $1
- ;;
- restart|configtest)
- $1
- ;;
- reload)
- rh_status_q || exit 7
- $1
- ;;
- force-reload)
- force_reload
- ;;
- status)
- rh_status
- ;;
- condrestart|try-restart)
- rh_status_q || exit 0
- ;;
- *)
- echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart|reload|force-reload}"
- exit 2
- 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