简述: 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
本文出自 “elain的技术博客” 博客,请务必保留此出处http://elain.blog.51cto.com/3339379/705846
相关推荐
redis部署6.2.6最新稳定版文档和程序redis部署6.2.6最新稳定版文档和程序redis部署6.2.6最新稳定版文档和程序redis部署6.2.6最新稳定版文档和程序redis部署6.2.6最新稳定版文档和程序redis部署6.2.6最新稳定版文档和...
本部署文档介绍了一个由六台虚拟服务器组成的Redis集群,这些服务器运行于两台物理机上。 **服务器IP及端口分配如下:** - 172.16.23.1:7901 (Master) - 172.16.23.1:7902 (Slave) - 172.16.23.1:7903 (Slave) - ...
### Redis部署文档知识点详解 #### 一、概览与重要性 Redis,作为一款高性能的键值(Key-Value)存储系统,不仅提供了快速的数据访问速度,还支持数据的持久化,使其成为IT行业,尤其是Web应用开发、大数据处理、...
【Redis 使用及集群部署】 Redis 是一款高性能的键值存储数据库,广泛应用于缓存、消息队列、数据持久化等领域。本文将详细介绍 Redis 的安装、使用以及集群部署。 ### 一、Redis 安装 #### Windows 安装 1. 从 ...
Redis监控是管理Redis部署和集群健康状况的重要环节,监控可以使用专门的工具如Redis-stat。部署监控工具可以对Redis实例的性能指标、内存使用、连接状态等进行实时监控。 ### 注意事项 在部署过程中,还需注意...
本文档将详细介绍如何在CentOS 6.5环境下搭建Redis 3.0集群,并通过具体的步骤指导用户完成整个部署过程。 #### 二、环境准备与要求 **系统环境**: CentOS 6.5 **硬件要求**: 至少3台主机或虚拟机(为了简化示例...
单点redis及集群redis部署方法
redis升级和部署6.2.6最新稳定版文档和程序.zipredis升级和部署6.2.6最新稳定版文档和程序.zipredis升级和部署6.2.6最新稳定版文档和程序.zipredis升级和部署6.2.6最新稳定版文档和程序.zipredis升级和部署6.2.6最新...
在这个压缩包中,包含了Redis的安装包`redis-3.2.9.tar.gz`以及一份名为`ecology-redis单机部署文档.doc`的详细部署指南。以下将详细介绍Redis单机部署的相关知识点。 1. **Redis下载与安装** Redis的安装通常从其...
在IT行业中,项目部署、数据库连接池管理和分布式缓存服务是关键环节,这些内容在"项目、数据库连接池、redis部署文档"中得到了详细的阐述。本篇将详细讲解标题和描述中涉及的知识点。 首先,项目部署是软件开发...
### Redis Cluster 部署与配置详解 #### 一、Redis Cluster 概述 Redis Cluster 是 Redis 3.0 版本引入的一项重要特性,它允许用户将 Redis 实例分组形成一个集群来提供高可用性和数据分区能力。通过这种方式,可以...
在Linux系统中,FTP(File Transfer Protocol)和Redis都是常用的服务。FTP用于文件传输,而Redis则是一个高性能的键值...请参考提供的“linux上ftp和redis部署手册.docx”文档,获取更详细的操作指南和注意事项。
Redis以其出色的性能、丰富的数据类型和灵活的部署方式,在众多应用场景中发挥着重要作用。掌握Redis的基本原理和常用命令对于开发高效稳定的应用至关重要。希望本文能够帮助读者更好地理解和使用Redis。
### Redis安装部署知识点 #### 一、概要与术语 - **Redis**(Remote Dictionary Server)是一种开源的、高性能的键值对存储系统,被广泛应用于缓存、消息队列等场景。 - **键值对存储**:Redis采用键值对的方式...
本文档详细介绍如何在单台机器上搭建一个包含六个节点的Redis集群。 ##### 准备环境 1. **安装环境准备**: - 系统:假设使用的是Linux系统。 - IP地址:示例中使用的IP地址为172.16.8.130。 - 软件:Redis ...
三、部署Redis 为了方便管理,需要将Redis的常用命令移动到统一的文件夹中。首先,创建新的文件夹bin和etc,用于存放Redis的可执行文件和配置文件。然后,执行文件移动命令,将Redis的可执行文件和配置文件移动到...
【Redis 安装部署和操作手册】 Redis 是一个高性能、开源、内存中的数据结构存储系统,常被用作数据库、缓存和消息中间件。它提供了丰富的数据结构,包括字符串、散列、列表、集合、有序集合、位图、HyperLogLogs...