一、输入命令,yum install gcc-c++
二、输入命令,yum install -y tcl
三、下载redis-3.0.5.tar.gz,我是放到/home/redis,进去目录/home/redis,输入命令,tar xvzf redis-3.0.5.tar.gz
四、进去解压后的目录,输入命令,cd redis-3.0.5
五、输入命令,make MALLOC=libc
六、启动,输入命令,src/redis-server redis.conf
七、中止,输入命令,src/redis-cli shutdown
附:
一、设置为非持久化,编辑redis.conf
#save 900 1
#save 300 10
#save 60 10000c++
save ""redis
二、主从复制,在从节点配置slaveof 主服务器的IP 端口,Redis的同步机制是,从节点主动向主节点请求同步,若是主节点设置了密码,还要设置masterauth 主节点密码apache
三、设置密码,配置requirepass 密码服务器
四、高可用Sentinel,配置sentinel.conf,配置sentinel monitor mymaster 10.16.70.62 6379 1,启动命令,src/redis-sentinel sentinel.confui
五、容许其它机器访问,编辑redis.conf,注释bind线程
六、后台模式,编辑redis.conf,daemonize yes、pidfile ./pidfile.pidserver
经常使用命令,带密码对象
src/redis-cli -a 密码 -p 端口 shutdown同步
src/redis-cli -a 密码 -p 端口 dbsizeit
附JedisPoolConfig配置
JedisPoolConfig config = new JedisPoolConfig(); //链接耗尽时是否阻塞, false报异常,ture阻塞直到超时, 默认true config.setBlockWhenExhausted(true); //设置的逐出策略类名, 默认DefaultEvictionPolicy(当链接超过最大空闲时间,或链接数超过最大空闲链接数) config.setEvictionPolicyClassName("org.apache.commons.pool2.impl.DefaultEvictionPolicy"); //是否启用pool的jmx管理功能, 默认true config.setJmxEnabled(true); //MBean ObjectName = new ObjectName("org.apache.commons.pool2:type=GenericObjectPool,name=" + "pool" + i); 默 认为"pool" config.setJmxNamePrefix("pool"); //是否启用后进先出, 默认true config.setLifo(true); //最大空闲链接数, 默认8个 config.setMaxIdle(8); //最大链接数, 默认8个 config.setMaxTotal(8); //获取链接时的最大等待毫秒数(若是设置为阻塞时BlockWhenExhausted),若是超时就抛异常, 小于零:阻塞不肯定的时间, 默认-1 config.setMaxWaitMillis(-1); //逐出链接的最小空闲时间 默认1800000毫秒(30分钟) config.setMinEvictableIdleTimeMillis(1800000); //最小空闲链接数, 默认0 config.setMinIdle(0); //每次逐出检查时 逐出的最大数目 若是为负数就是 : 1/abs(n), 默认3 config.setNumTestsPerEvictionRun(3); //对象空闲多久后逐出, 当空闲时间>该值 且 空闲链接>最大空闲数 时直接逐出,再也不根据MinEvictableIdleTimeMillis判断 (默认逐出策略) config.setSoftMinEvictableIdleTimeMillis(1800000); //在获取链接的时候检查有效性, 默认false config.setTestOnBorrow(false); //在空闲时检查有效性, 默认false config.setTestWhileIdle(false); //逐出扫描的时间间隔(毫秒) 若是为负数,则不运行逐出线程, 默认-1 config.setTimeBetweenEvictionRunsMillis(-1); JedisPool pool = new JedisPool(config, "localhost",); int timeout=3000; new JedisSentinelPool(master, sentinels, poolConfig,timeout);//timeout 读取超时