zoukankan      html  css  js  c++  java
  • Linux-NoSQL之Redis(一)

    1.Redis介绍

    redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型)。这些数据类型都支持push/pop、add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。在此基础上,redis支持各种不同方式的排序。与memcached一样,为了保证效率,数据都是缓存在内存中。区别的是redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。

    Redis 是一个高性能的key-value数据库。

    2.Redis安装

    cd /usr/local/src

    $ wget http://download.redis.io/releases/redis-2.8.21.tar.gz
    $ tar xzf redis-2.8.21.tar.gz
    $ cd redis-2.8.21
    $ make

    wget http://download.redis.io/releases/redis-2.8.21.tar.gz

    make PREFIX=/usr/local/redis install

    mkdir /usr/local/redis/etc

    cp /usr/local/src/redis-2.8.21/redis.conf /usr/local/redis/etc

    wget http://www.apelearn.com/study_v2/.redis_conf -O /usr/local/redis/etc/redis.conf 2>/dev/null

    update==>

    启动脚本

    wget http://www.apelearn.com/study_v2/.redis_init -O /etc/init.d/redis 2>/dev/null

    useradd -s /sbin/nologin redis

    mkdir /usr/local/redis/var

    chmod 777 /usr/local/redis/var

    chmod 755 /etc/init.d/redis

    3.启动redis

    vi /etc/init.d/redis   #编辑,添加以下代码

    #!/bin/sh

    # chkconfig:   2345 90 10

    # description:  Redis is a persistent key-value database

    # redis    Startup script for redis processes

    # processname: redis

    redis_path="/usr/local/bin/redis-server"

    redis_conf="/etc/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

    :wq! #保存退出

    chmod 755 /etc/init.d/redis  #添加脚本执行权限

    chkconfig --add redis  #添加开启启动

    chkconfig --level 2345 redis on  #设置启动级别

    chkconfig --list redis  #查看启动级别

    service redis restart  #重新启动redis

    系统运维  www.osyunwei.com  温馨提醒:qihang01原创内容 版权所有,转载请注明出处及原文链接

    4、设置redis配置文件参数

    mkdir -p /usr/local/redis/var  #创建redis数据库存放目录

    vi /etc/redis.conf  #编辑

    daemonize yes  #以后台daemon方式运行redis

    pidfile "/var/run/redis.pid"  #redis以后台运行,默认pid文件路径/var/run/redis.pid

    port 6379  #默认端口

    bind 127.0.0.1 #默认绑定本机所有ip地址,为了安全,可以只监听内网ip

    timeout 300 #客户端超时设置,单位为秒

    loglevel verbose  #设置日志级别,支持四个级别:debug、notice、verbose、warning

    logfile stdout  #日志记录方式,默认为标准输出,logs不写文件,输出到空设备/deb/null

    logfile "/usr/local/redis/var/redis.log"  #可以指定日志文件路径

    databases 16  #开启数据库的数量

    save 900 1

    save 300 10

    save 60 10000

    创建本地数据库快照,格式:save * *

    900秒内,执行1次写操作

    300秒内,执行10次写操作

    60秒内,执行10000次写操作

    rdbcompression yes #启用数据库lzf压缩,也可以设置为no

    dbfilename dump.rdb  #本地快照数据库名称

    dir "/usr/local/redis/var/"   #本地快照数据库存放目录

    requirepass 123456  #设置redis数据库连接密码

    maxclients 10000 #同一时间最大客户端连接数,0为无限制

    maxmemory 1024MB #设定redis最大使用内存,值要小于物理内存,必须设置

    appendonly yes  #开启日志记录,相当于MySQL的binlog

    appendfilename "appendonly.aof"   #日志文件名,注意:不是目录路径

    appendfsync everysec #每秒执行同步,还有两个参数always、no一般设置为everysec,相当于MySQL事物日志的写方式

    :wq! #保存退出

    service redis restart #重启

    5、测试redis数据库

    redis-cli -a 123456  #连接redis数据库,注意:-a后面跟redis数据库密码

    set name osyunwei.com  #写数据

    get name  #读取数据

    exit #退出redis数据库控制台

    redis-benchmark -h 127.0.0.1 -p 6379 -c 1000 -n 100000  #1000个并发连接,100000个请求,测试127.0.0.1端口为6379的redis服务器性能

  • 相关阅读:
    Spring 由哪些模块组成?
    spring 支持哪些 ORM 框架 ?
    @Autowired 注解有什么用?
    spring JDBC API 中存在哪些类?
    有哪些类型的通知(Advice)?
    @Component, @Controller, @Repository, @Service 有何区别?
    @Qualifier 注解有什么用?
    什么是 Aspect?
    什么是通知(Advice)?
    spring bean 容器的生命周期是什么样的?
  • 原文地址:https://www.cnblogs.com/Nyan-Workflow-FC/p/5737496.html
Copyright © 2011-2022 走看看