设为首页 收藏本站
查看: 517|回复: 0

[经验分享] Redis的部署使用文档

[复制链接]

尚未签到

发表于 2016-12-18 09:18:10 | 显示全部楼层 |阅读模式
  简述:  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 
  测试:

  • [iyunv@md03 ~]# redis-cli -a elain 
  • redis 127.0.0.1:6379> set elain 123456 
  • OK 
  • redis 127.0.0.1:6379> get elain 
  • "123456" 
  查看状态信息:

  • [iyunv@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
  本文出自 “elain的技术博客” 博客,请务必保留此出处http://elain.blog.iyunv.com/3339379/705846

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-315819-1-1.html 上篇帖子: redis实践使用大总体 下篇帖子: redis 配置说明
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表