Chinaunix首页 | 论坛 | 博客
  • 博客访问: 4998626
  • 博文数量: 921
  • 博客积分: 16037
  • 博客等级: 上将
  • 技术积分: 8469
  • 用 户 组: 普通用户
  • 注册时间: 2006-04-05 02:08
文章分类

全部博文(921)

文章存档

2020年(1)

2019年(3)

2018年(3)

2017年(6)

2016年(47)

2015年(72)

2014年(25)

2013年(72)

2012年(125)

2011年(182)

2010年(42)

2009年(14)

2008年(85)

2007年(89)

2006年(155)

分类: 数据库开发技术

2012-01-06 15:14:48

简述:  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
  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
  8. vi /etc/redis.conf
 
  1. daemonize yes
  2. pidfile /var/run/redis.pid
  3. port 6379
  4. #bind 127.0.0.1
  5. timeout 600
  6. loglevel notice
  7. logfile /elain/logs/redis/redis.log
  8. databases 16
  9. save 900 1
  10. save 300 10
  11. save 60 10000
  12. rdbcompression yes
  13. dbfilename dump.rdb
  14. dir /elain/data/redis/
  15. # maxclients 128
  16. appendonly yes
  17. appendfilename appendonly.aof
  18. # appendfsync always
  19. appendfsync everysec
  20. # appendfsync no
  21. requirepass elain
  22. no-appendfsync-on-rewrite no
  23. auto-aof-rewrite-percentage 100
  24. auto-aof-rewrite-min-size 64mb
  25. slowlog-log-slower-than 10000
  26. slowlog-max-len 1024
  27. really-use-vm yes
  28. vm-enabled yes
  29. vm-swap-file /tmp/redis.swap
  30. vm-max-memory 0
  31. vm-page-size 32
  32. vm-pages 134217728
  33. vm-max-threads 4
  34. hash-max-zipmap-entries 512
  35. hash-max-zipmap-value 64
  36. list-max-ziplist-entries 512
  37. list-max-ziplist-value 64
  38. set-max-intset-entries 512
  39. zset-max-ziplist-entries 128
  40. zset-max-ziplist-value 64
  41. activerehashing yes
  42. # include /path/to/local.conf
  43. # include /path/to/other.conf

启动:
redis-server /etc/redis.conf

开机加自启动:
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 里添加以下几行,重启即可:
slave-serve-stale-data yes
slaveof 主服务器IP 6379
masterauth

注:以上主从配置做了密码验证,也可不做验证,不用加masterauth 选项

附上启动脚本:
脚本用法:

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

redis官方文档:http://redis.io/documentation
redis官方操作命令全集:
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

阅读(2562) | 评论(0) | 转发(1) |
给主人留下些什么吧!~~