什么是redis
Redis 是一个高性能的key-value数据库。 redis的出现,很大程度补偿了memcached这类key/value存储的不足,在部 分场合可以对关系数据库起到很好的补充作用。它提供了Java,C/C++,C#,PHP,JavaScript,Perl,Object-C,Python,Ruby,Erlang等客户端,使用很方便。[1]
redis 的应用场景
缓存(数据查询、短连接、新闻内容、商品内容等等)。(最多使用)
分布式集群架构中的session分离。
聊天室的在线好友列表。
任务队列。(秒杀、抢购、12306等等)
应用排行榜。
网站访问统计。
数据过期处理(可以精确到毫秒)
centos下安装redis
- https://redis.io/ 下载redis源码使用gcc编译
tar -zxvf redis-3.0.0.tar.gz
make - 安装到指定目录
- make PREFIX=/usr/local/redis install
- 拷贝配置文件redis.conf到安装目录下
redis-server redis 服务器
redis-cli rides命令行客户端
启动Redis
redis默认端口是6379 - 前端启动方式
bin/redis-server
缺点是关闭窗口后程序结束 后端启动方式
- 修改redis.conf
daemonize yes - ./bin/redis-server ./redis.conf
查看服务
Ps aux|grep redis
Jedis 结合Spring
- !-- 连接池配置 -->
- <bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">
- <!-- 最大连接数 -->
- <property name="maxTotal" value="30" />
- <!-- 最大空闲连接数 -->
- <property name="maxIdle" value="10" />
- <!-- 每次释放连接的最大数目 -->
- <property name="numTestsPerEvictionRun" value="1024" />
- <!-- 释放连接的扫描间隔(毫秒) -->
- <property name="timeBetweenEvictionRunsMillis" value="30000" />
- <!-- 连接最小空闲时间 -->
- <property name="minEvictableIdleTimeMillis" value="1800000" />
- <!-- 连接空闲多久后释放,当空闲时间>该值 且 空闲连接>最大空闲连接数 时直接释放 -->
- <property name="softMinEvictableIdleTimeMillis" value="10000" />
- <!-- 获取连接时的最大等待毫秒数,小于零:阻塞不确定的时间,默认-1 -->
- <property name="maxWaitMillis" value="1500" />
- <!-- 在获取连接的时候检查有效性,默认false -->
- <property name="testOnBorrow" value="true" />
- <!-- 在空闲时检查有效性,默认false -->
- <property name="testWhileIdle" value="true" />
- <!-- 连接耗尽时是否阻塞,false报异常,ture阻塞直到超时,默认true -->
- <property name="blockWhenExhausted" value="false" />
- </bean>
- <!-- redis单机 通过连接池 -->
- <bean id="jedisPool" class="redis.clients.jedis.JedisPool" destroy-method="close">
- <constructor-arg name="poolConfig" ref="jedisPoolConfig"/>
- <constructor-arg name="host" value="192.168.25.145"/>
- <constructor-arg name="port" value="6379"/>
- </bean>
- <!--集群版-->
- <!--<bean id="redisClient" class="redis.clients.jedis.JedisClientCluster">-->
- <!--<constructor-arg name="nodes">-->
- <!--<set>-->
- <!--<bean class="redis.clients.jedis.HostAndPort">-->
- <!--<constructor-arg name="host" value="192.168.25.130"/>-->
- <!--<constructor-arg name="port" value="7001"/>-->
- <!--</bean>-->
- <!--<bean class="redis.clients.jedis.HostAndPort">-->
- <!--<constructor-arg name="host" value="192.168.25.130"/>-->
- <!--<constructor-arg name="port" value="7002"/>-->
- <!--</bean>-->
- <!--<bean class="redis.clients.jedis.HostAndPort">-->
- <!--<constructor-arg name="host" value="192.168.25.130"/>-->
- <!--<constructor-arg name="port" value="7003"/>-->
- <!--</bean>-->
- <!--<bean class="redis.clients.jedis.HostAndPort">-->
- <!--<constructor-arg name="host" value="192.168.25.130"/>-->
- <!--<constructor-arg name="port" value="7004"/>-->
- <!--</bean>-->
- <!--<bean class="redis.clients.jedis.HostAndPort">-->
- <!--<constructor-arg name="host" value="192.168.25.130"/>-->
- <!--<constructor-arg name="port" value="7005"/>-->
- <!--</bean>-->
- <!--<bean class="redis.clients.jedis.HostAndPort">-->
- <!--<constructor-arg name="host" value="192.168.25.130"/>-->
- <!--<constructor-arg name="port" value="7006"/>-->
- <!--</bean>-->
- <!--</set>-->
- <!--</constructor-arg>-->
- <!--</bean>-->
- <!--<bean id="jedisClientCluster" class="cn.zsp.taotao.portalal.dao.impl.JedisClientClusterluster"></bean>-->
- 修改redis.conf