-----使用技术手段解决问题,坚信注重每一个细节,把熟悉的做到一种极致,一定会有创新出现。-----

(转载)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

注:以上主从配置做了密码验证,也可不做验证,不用加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 #设置最大内存,达到最大内存设置后,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

好文章必须转载:http://www.elain.org/?p=505

posted @ 2012-11-14 12:33  ZhuQue  阅读(5742)  评论(0编辑  收藏  举报
多年性能测试、测试管理经验,专注银行、支付、电商行业,倾向于性能、安全、 监控、调优、模型、管理等方向的研究。
使用技术手段解决问题,坚信注重每一个细节,把熟悉的做到一种极致,一定会有创新出现。