zoukankan      html  css  js  c++  java
  • Redis的部署使用文档

    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 <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

    Redis的部署使用文档
    2条回复
    简述:  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
    

      

  • 相关阅读:
    改变this指向的三个函数call, apply, bind的实现
    vscode 前端常用插件推荐
    Java SPI详解
    数据技术分享
    深入SpringMVC视图解析器
    .gitignore文件失效的解决方案
    Spring的事件监听机制
    Spring MVC 配置类 WebMvcConfigurerAdapter
    一起来读Netty In Action之传输(三)
    Tomcat性能调优参数简介
  • 原文地址:https://www.cnblogs.com/L-H-R-X-hehe/p/3970876.html
Copyright © 2011-2022 走看看