redis 服务器/客户端安装与配置

1 redis server
   
    1.1 获取redis源码包 //官网 http://redis.io/
   
    wget -c http://redis.googlecode.com/files/redis-2.4.15.tar.gz
   
    1.2 解包
   
    tar zxf redis-2.4.15.tar.gz
   
    cd redis-2.4.15
   
    1.3 安装
   
    make PREFIX=/usr/local/redis install
   
    //安装完成后,会/usr/local/redis/bin/目录下生成5个可执行文件,
   
    ls /usr/local/redis/bin/
   
    redis-benchmark  redis-check-aof  redis-check-dump  redis-cli  redis-server
   
    redis-server:Redis服务器的daemon启动程序
   
    redis-cli:Redis命令行操作工具。
   
    redis-benchmark:Redis性能测试工具,测试Redis在你的系统及你的配置下的读写性能
   
    redis-check-dump: 检查file.rdb 文件
   
    redis-check-aof:检查file.aof 文件
   
    1.4 配置redis
   
    //建立conf与var目录
   
    mkdir -p /usr/local/redis/conf
   
    mkdir -p /usr/local/redis/var
   
    //redis.conf
   
    cat > /usr/local/redis/conf/redis.conf 《 EOF
   
    #daemonize:是否以后台daemon方式运行
   
    daemonize yes
   
    #pidfile:pid文件位置
   
    pidfile /var/run/redis.pid
   
    #bind:监听的ip地址
   
    bind 10.0.100.70
   
    #port:监听的端口号
   
    port 6379
   
    #timeout:请求超时时间,单位秒
   
    timeout 120
   
    #loglevel:log信息级别,支持四个级别,debug,notice,verbose,warning
   
    loglevel warning
   
    #日志文件位置
   
    logfile /usr/local/redis/var/redis.log
   
    #databases:开启数据库的数量
   
    databases 16
   
    ##snapshoot
   
    #save * *:保存快照的频率,第一个*表示多长时间,第二个*表示执行多少次写操作。在一定时间内执行一定数量的写操作时,自动保存快照。可设置多个条件。
   
    #在900秒之内,redis至少发生1次修改则redis抓快照到磁盘
   
    save 900 1
   
    #在300秒之内,redis至少发生100次修改则redis抓快照到磁盘
   
    save 300 100
   
    #在60秒之内,redis至少发生10000次修改则redis抓快照到磁盘
   
    save 60 10000
   
    #rdbcompression:是否使用压缩
   
    rdbcompression yes
   
    #dbfilename:数据快照文件名(只是文件名,不包括目录)
   
    dbfilename dump.rdb
   
    #dir:数据快照的保存目录(这个是目录)
   
    dir /usr/local/redis/var
   
    ##aof
   
    #appendonly:是否开启appendonlylog,AOF是另一种持久化方式,开启的话每次写操作会记一条log,这会提高数据抗风险能力,但影响效率。
   
    appendonly no
   
    #appendfsync:appendonlylog如何同步到磁盘(三个选项,分别是每次写都强制调用fsync、每秒启用一次fsync、不调用fsync等待系统自己同步)
   
    appendfsync everysec
   
    no-appendfsync-on-rewrite no
   
    auto-aof-rewrite-percentage 100
   
    auto-aof-rewrite-min-size 64mb
   
    ##slow log
   
    #如果操作时间大于0.001秒,记录slow log,这个log是记录在内存中的,可以用redis-cli slowlog get 命令查看
   
    slowlog-log-slower-than 10000
   
    #slow log 的最大长度
   
    slowlog-max-len 128
   
    ##virtual memory
   
    #是否使用虚拟内存
   
    vm-enabled no
   
    #swap文件,不同redis swap文件不能共享。而且生产环境下,不建议放在tmp目录。
   
    vm-swap-file /tmp/redis.swap
   
    #vm大小限制。0 不限制,建议60-80% 可用内存大小
   
    vm-max-memory 0
   
    #根据缓存内容大小调整,默认32字节
   
    vm-page-size 32
   
    #page数。每 8 page 会占用1字节内存
   
    vm-pages 134217728
   
    #m 最大io线程数。注意: 0 标志禁止使用vm(开关真多)
   
    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
   
    ##limit
   
    #最大使用内存单位<bytes>,默认情况下redis会占用可用的所有内存
   
    maxmemory 256000000
   
    #maxclients 最大连接数, 0 表示不限制
   
    maxclients 1024
   
    ##replication
   
    requirepass dongnan
   
    #slave
   
    #master的ip地址与端口号
   
    #slaveof 10.0.100.70 6379
   
    #设置slave到master的认证
   
    #masterauth dongnan
   
    #在master服务器挂掉或者同步失败时,从服务器是否继续提供服务
   
    slave-serve-stale-data yes
   
    EOF
   
    1.5 启动redis
   
    /usr/local/redis/bin/redis-server /usr/local/redis/conf/redis.conf
   
    //redis 进程与端口号
   
    ps -ef | grep redis
   
    root     19426     1  0 13:44 ?        00:00:00 /usr/local/redis/bin/redis-server /usr/local/redis/conf/redis.conf
   
    lsof -i :6379
   
    COMMAND     PID USER   FD   TYPE  DEVICE SIZE NODE NAME
   
    redis-ser 19426 root    4u  IPv4 7257634       TCP *:6379 (LISTEN)
   
    1.6 验证redis
   
    telnet 10.0.100.70 6379
   
    Trying 10.0.100.70…
   
    Connected to monitor.test.com (10.0.100.70)。
   
    Escape character is '^]'.
   
    set name test
   
    +OK
   
    get name
   
    $4
   
    test
   
    quit
   
    +OK
   
    Connection closed by foreign host.
   
    //使用redis-cli
   
    /usr/local/redis/bin/redis-cli -h 10.0.100.70 info
   
    redis_version:2.4.15
   
    redis_git_sha1:00000000
   
    redis_git_dirty:0
   
    arch_bits:64
   
    multiplexing_api:epoll
   
    gcc_version:4.4.4
   
    process_id:16508
   
    uptime_in_seconds:602110
   
    uptime_in_days:6
   
    lru_clock:1948675
   
    used_cpu_sys:129.20
   
    used_cpu_user:117.94
   
    used_cpu_sys_children:14.57
   
    used_cpu_user_children:158.95
   
    connected_clients:1
   
    connected_slaves:0
   
    client_longest_output_list:0
   
    client_biggest_input_buf:0
   
    blocked_clients:0
   
    used_memory:594999992
   
    used_memory_human:567.44M
   
    used_memory_rss:172482560
   
    used_memory_peak:594999904
   
    used_memory_peak_human:567.44M
   
    mem_fragmentation_ratio:0.29
   
    mem_allocator:jemalloc-2.2.5
   
    loading:0
   
    aof_enabled:0
   
    changes_since_last_save:0

bgsave_in_progress:0
   
    last_save_time:1340097972
   
    bgrewriteaof_in_progress:0
   
    total_connections_received:34
   
    total_commands_processed:6946723
   
    expired_keys:0
   
    evicted_keys:0
   
    keyspace_hits:32
   
    keyspace_misses:0
   
    pubsub_channels:0
   
    pubsub_patterns:0
   
    latest_fork_usec:9602
   
    vm_enabled:0
   
    role:master
   
    db0:keys=1969249,expires=0
   
    1.7 关闭redis
   
    /usr/local/redis/bin/redis-cli -h 10.0.100.70  -p 6379 shutdown

你可能感兴趣的:(redis 服务器/客户端安装与配置)