首页 > 代码库 > Redis的部署使用文档

Redis的部署使用文档

Redis的部署使用文档

 

简述:  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

Redis的部署使用文档2条回复简述:  redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符 串)、list(链表)、set(集合)和zset(有序集合)。这些数据类型都支持push/pop、add/remove及取交集并集和差集及更丰富 的操作,而且这些操作都是原子性的。在此基础上,redis支持各种不同方式的排序。与memcached一样,为了保证效率,数据都是缓存在内存中。区 别的是redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。环境:CentOS 5.5  x64下载安装:cd /root/toolswget http://redis.googlecode.com/files/redis-2.4.2.tar.gztar zxvf redis-2.4.2.tar.gzcd redis-2.4.2make && make installcp redis.conf  /etc/cdvi /etc/redis.confdaemonize yespidfile /var/run/redis.pidport 6379#bind 127.0.0.1timeout 600loglevel noticelogfile /elain/logs/redis/redis.logdatabases 16save 900 1save 300 10save 60 10000rdbcompression yesdbfilename dump.rdbdir /elain/data/redis/# maxclients 128appendonly yesappendfilename appendonly.aof# appendfsync alwaysappendfsync everysec# appendfsync norequirepass elainno-appendfsync-on-rewrite noauto-aof-rewrite-percentage 100auto-aof-rewrite-min-size 64mbslowlog-log-slower-than 10000slowlog-max-len 1024really-use-vm yesvm-enabled yesvm-swap-file /tmp/redis.swapvm-max-memory 0vm-page-size 32vm-pages 134217728vm-max-threads 4hash-max-zipmap-entries 512hash-max-zipmap-value 64list-max-ziplist-entries 512list-max-ziplist-value 64set-max-intset-entries 512zset-max-ziplist-entries 128zset-max-ziplist-value 64activerehashing 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 elainredis 127.0.0.1:6379> set elain 123456OKredis 127.0.0.1:6379> get elain"123456"查看状态信息:[root@md04 ~]# redis-cli inforedis_version:2.4.2redis_git_sha1:00000000redis_git_dirty:0arch_bits:64multiplexing_api:epollprocess_id:2204uptime_in_seconds:25uptime_in_days:0lru_clock:2013834used_cpu_sys:0.00used_cpu_user:0.00used_cpu_sys_children:0.00used_cpu_user_children:0.00connected_clients:1connected_slaves:0client_longest_output_list:0client_biggest_input_buf:0blocked_clients:0used_memory:17505392used_memory_human:16.69Mused_memory_rss:1617920used_memory_peak:17496792used_memory_peak_human:16.69Mmem_fragmentation_ratio:0.09mem_allocator:jemalloc-2.2.1loading:0aof_enabled:1changes_since_last_save:5bgsave_in_progress:0last_save_time:1320372561bgrewriteaof_in_progress:0total_connections_received:1total_commands_processed:0expired_keys:0evicted_keys:0keyspace_hits:2keyspace_misses:8pubsub_channels:0pubsub_patterns:0latest_fork_usec:0vm_enabled:1role:masteraof_current_size:237aof_base_size:237aof_pending_rewrite:0vm_conf_max_memory:0vm_conf_page_size:32vm_conf_pages:134217728vm_stats_used_pages:3vm_stats_swapped_objects:3vm_stats_swappin_count:0vm_stats_swappout_count:3vm_stats_io_newjobs_len:0vm_stats_io_processing_len:0vm_stats_io_processed_len:0vm_stats_io_active_threads:0vm_stats_blocked_clients:0db0:keys=4,expires=0主从同步配置:只需把/etc/redis.conf 复制到 从机上,主、从机上把127.0.0.1 IP 改成本机ip,然后在从机上的redis.conf 里添加以下几行,重启即可:slave-serve-stale-data yesslaveof 主服务器IP 6379masterauth <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 0redis="/usr/local/bin/redis-server"prog=$(basename $redis)REDIS_CONF_FILE="/etc/redis.conf"[ -f /etc/sysconfig/redis ] && . /etc/sysconfig/redislockfile=/var/lock/subsys/redisstart() {[ -x $redis ] || exit 5[ -f $REDIS_CONF_FILE ] || exit 6echo -n $"Starting $prog: "daemon $redis $REDIS_CONF_FILEretval=$?echo[ $retval -eq 0 ] && touch $lockfilereturn $retval}stop() {echo -n $"Stopping $prog: "killproc $prog -QUITretval=$?echo[ $retval -eq 0 ] && rm -f $lockfilereturn $retval}restart() {stopstart}reload() {echo -n $"Reloading $prog: "killproc $redis -HUPRETVAL=$?echo}force_reload() {restart}rh_status() {status $prog}rh_status_q() {rh_status >/dev/null 2>&1}case "$1" instart)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 2esacredis官方文档:http://redis.io/documentationredis官方操作命令全集:http://redis.io/commandsreids 各接口使用方法请参考官方文档附录:配置文件 redis.conf 详解daemonize  yes                                  #是否以后台进程运行,默认为nopidfile  /var/run/redis.pid                     #如以后台进程运行,则需指定一个pid,默认为/var/run/redis.pidbind 127.0.0.1                                  #绑定主机IP,默认值为127.0.0.1(注释)port   6379                                     #监听端口,默认为6379timeout  300                                    #超时时间,默认为300(秒)loglevel  notice                                #日志记slave-serve-stale-data yes:在master服务器挂掉或者同步失败时,从服务器是否继续提供服务。录等级,有4个可选值,debug,verbose(默认 值),notice,warninglogfile   /var/log/redis.log                    #日志记录方式,默认值为stdoutdatabases  16                                   #可用数据库数,默认值为16,默认数据库为0save 900 1                                      #900秒(15分钟)内至少有1个key被改变save 300 10                                     #300秒(5分钟)内至少有300个key被改变save 60 10000                                   #60秒内至少有10000个key被改变rdbcompression yes                              #存储至本地数据库时是否压缩数据,默认为yesdbfilename dump.rdb                             #本地数据库文件名,默认值为dump.rdbdir ./                                          #本地数据库存放路径,默认值为 ./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条件来同步 的,所以有的数据会在一段时间内只存在于内存中。默认值为noappendfilename   appendonly.aof                 #更新日志文件名,默认值为appendonly.aof(注释)appendfsync  everysec                           #更新日志条件,共有3个可选值。no表示等操作系统进行数据缓存同步到磁盘,always表示每次更新操作后手动调用fsync()将数据写到磁 盘,everysec表示每秒同步一次(默认值)。really-use-vm yesvm-enabled  yes                                 #是否使用虚拟内存,默认值为novm-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 标志禁止使用vmhash-max-zipmap-entries 512hash-max-zipmap-value 64list-max-ziplist-entries 512list-max-ziplist-value 64set-max-intset-entries 512activerehashing yes

  

Redis的部署使用文档