just do it

redis简介

一、Redis简要介绍

Redis —— REmote DIctionary Server,可以直接理解为远程字典服务,也就是基于Key-Value模式Memcached+Database Persistence。
如果真要把Redis与Memcached进行对比,参考下图:

《redis简介》

 

Memcached是在Server端实现的ShardingRedis没有对应的实现,据说3.0系列开始支持,不过这话貌似说了2年之久。

二、安装

下载&解压:

 

1
2
wget http://redis.googlecode.com/files/redis-2.4.16.tar.gz  
tar zxvf redis-2.4.16.tar.gz

Redis可以解压至任何目录,一个make安装即可获得执行、配置文件。
安装(这里将redis解压到/opt/目录下):

1
2
cd /opt/redis-2.4.16  
make

make之后,我们会得到以下可执行文件:
redis-server:Redis服务器的daemon启动程序
redis-cli:Redis命令行操作工具。或者通过telnet进行纯文本协议操作
redis-benchmark:Redis性能测试工具,测试Redis在你的系统及你的配置下的读写性能
文件位于src目录下
此外,还会得到一个默认的配置文件——redis.conf。
最好,把它拷贝到固定的目录下,例如:/etc/redis/目录下!

1
2
mkdir /etc/redis  
cp redis.conf /etc/redis

三、运行

1
redis-server /etc/redis/redis.conf

四、测试

通过客户端命令redis-cli访问Redis

1
2
3
4
5
 redis-cli  
 redis> set name lmt  
 OK  
 redis> get name   
 "lmt"

进行数据测试:

1
redis-benchmark -l

这个测试会一直进行下去,直到你Ctrl+C:


====== PING (inline) ======
10000 requests completed in 0.12 seconds
50 parallel clients
3 bytes payload
keep alive: 1

99.31% <= 1 milliseconds 99.53% <= 2 milliseconds 99.64% <= 3 milliseconds 99.70% <= 4 milliseconds 99.74% <= 5 milliseconds 99.78% <= 6 milliseconds 99.82% <= 7 milliseconds 99.84% <= 8 milliseconds 99.86% <= 9 milliseconds 99.89% <= 10 milliseconds 99.91% <= 11 milliseconds 99.93% <= 12 milliseconds 99.96% <= 13 milliseconds 99.98% <= 14 milliseconds 100.00% <= 15 milliseconds 81300.81 requests per second ====== PING ====== 10000 requests completed in 0.12 seconds 50 parallel clients 3 bytes payload keep alive: 1 99.96% <= 1 milliseconds 100.00% <= 1 milliseconds 84033.61 requests per second ^CET (10 keys): 26200.00

五、关闭

也可通过客户端命令redis-cli完成Redis关闭操作:

1
redis-cli shutdown

六、调优

1./etc/sysctl.conf
前面启动Redis时,看到如下警告:
# WARNING overcommit_memory is set to 0! Background save may fail under low memory condition. To fix this issue add 'vm.overcommit_memory = 1' to /etc/sysctl.conf and then reboot or run the command 'sysctl vm.overcommit_memory=1' for this to take effect

需要修改/etc/sysctl.conf文件:

1
vi /etc/sysctl.conf

末尾追加vm.overcommit_memory = 1
然后执行sysctl vm.overcommit_memory=1,使之生效:

2./proc/sys/vm/overcommit_memory
为了调整内存分配策略,需要配置/proc/sys/vm/overcommit_memory
0, 表示内核将检查是否有足够的可用内存供应用进程使用;如果有足够的可用内存,内存申请允许;否则,内存申请失败,并把错误返回给应用进程。
1, 表示内核允许分配所有的物理内存,而不管当前的内存状态如何。
2, 表示内核允许分配超过所有物理内存和交换空间总和的内存

默认为0,如果内存情况比较紧张的话,设为1:

1
echo 1 > /proc/sys/vm/overcommit_memory

3.redis.conf
前面启动Redis后,总是在命令行里不断跳着各种日志,很麻烦。即便通过“&”,领其后台运行,也无济于事。这就需要修改redis.conf,以Daemo模式运行!
redis.conf参数:
daemonize:是否以后台daemon方式运行
pidfile:pid文件位置
port:监听的端口号
timeout:请求超时时间
loglevel:log信息级别
logfile:log文件位置
databases:开启数据库的数量
save * *:保存快照的频率,第一个*表示多长时间(秒级),第三个*表示执行多少次写操作。在一定时间内执行一定数量的写操作时,自动保存快照。可设置多个条件。
rdbcompression:是否使用压缩
dbfilename:数据快照文件名(只是文件名,不包括目录)
dir:数据快照的保存目录(这个是目录)
appendonly:是否开启appendonlylog,开启的话每次写操作会记一条log,这会提高数据抗风险能力,但影响效率。
appendfsync:appendonlylog如何同步到磁盘(三个选项,分别是每次写都强制调用fsync、每秒启用一次fsync、不调用fsync等待系统自己同步)
slaveof :主从配置,在redis-slave上配置master的ip port,即可。

例如,我们可以修改为如下方式:
daemonize yes #守护进程模式
save 60 1000 #当时间间隔超过60秒,或存储超过1000条记录时,进行持久化。
maxmemory 256mb #分配256MB内存

PS:切记,一定要设定maxmemmory,且配置大小要小于物理内存,留有足够的内存供系统使用。

公司一同学的Redis,某期间数据暴涨,导致内存吃紧,SWAP加剧,直接宕机。就是因为没有设置maxmemmory。

七、系统服务
通常只分配给用于部署的账户操作service命令的权限。主要是为了确保系统安全。

1
2
touch /etc/init.d/redis-server  
chmod +x /etc/init.d/redis-server

编辑/etc/init.d/redis-server,键入如下内容:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
#!/bin/bash  
#  
# redis    Startup script for redis processes  
#  
# author: snowolf  
#  
# processname: redis  
 
redis_path="/usr/local/bin/redis-server"  
redis_conf="/etc/redis/redis.conf"  
redis_pid="/var/run/redis.pid"  
 
# Source function library.  
. /etc/rc.d/init.d/functions  
 
[ -x $redis_path ] || exit 0  
 
RETVAL=0  
prog="redis"  
 
 
# Start daemons.  
start() {  
    if [ -e $redis_pid -a ! -z $redis_pid ];then  
        echo $prog" already running...."  
        exit 1  
    fi  
 
    echo -n $"Starting $prog "  
    # Single instance for all caches  
    $redis_path $redis_conf  
    RETVAL=$?  
    [ $RETVAL -eq 0 ] && {  
        touch /var/lock/subsys/$prog  
        success $"$prog"  
    }  
    echo  
    return $RETVAL  
}  
 
 
# Stop daemons.  
stop() {  
    echo -n $"Stopping $prog "  
    killproc -d 10 $redis_path  
    echo  
    [ $RETVAL = 0 ] && rm -f $redis_pid /var/lock/subsys/$prog  
 
    RETVAL=$?  
    return $RETVAL  
}  
 
 
# See how we were called.  
case "$1" in  
        start)  
            start  
            ;;  
        stop)  
            stop  
            ;;  
        status)  
            status $prog  
            RETVAL=$?  
            ;;  
        restart)  
            stop  
            start  
            ;;  
        condrestart)  
            if test "x`pidof redis`" != x; then  
                stop  
                start  
            fi  
            ;;  
        *)  
            echo $"Usage: $0 {start|stop|status|restart|condrestart}"  
            exit 1  
esac  
exit $RETVAL

# service redis-server restart
Stopping redis [失败]
Starting redis [确定]
# service redis-server status
redis (pid 14965) 正在运行...

点赞