博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
20分钟快速了解Redis
阅读量:4641 次
发布时间:2019-06-09

本文共 4118 字,大约阅读时间需要 13 分钟。

Redis可以说是目前最火爆的NoSQL数据库!

 

过去几年,Memcached很盛行,现在有很多公司已将Memcached替换成了Redis。当然,很多人替换并不清楚为什么,只是感觉不想让主流抛弃,这也充分反映了目前Redis的强势。

 

Redis是基于内存的数据结构存储开源系统,采用C语言编写,运行效率极高。可作为内存数据库、缓存或消息代理中间件,前两种情况实际当中使用更多些。

 

Redis与Memcached一样,以<key,value>二元键值对的形式存储数据,但与Memcached最大的不同在于Redis支持更多的数据类型,包括String、Hash、List、Set、Sorted Set等。

 

Redis目前发展很快,当前版本是3,其官方网址是:http://redis.io/ 源码地址:https://github.com/antirez/redis

 

由于采用ANSI C编写,Redis官方支持POSIX类型系统如linux等,Windows环境下有第三方的移植程序,但一般只做开发调试用,真正部署还是运行在linux系统上,才能发挥其威力。

 

Redis的安装部署R

 

下面我们就在CentOS 6上进行安装部署,具体步骤如下:

 

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

这是当前的最新版本,可以到官网下载页面查看最新版本或安装以前的版本。

 

2.tar xzf redis-3.0.5.tar.gz 解压后,cd redis-3.0.5 到Redis主目录

 

3.make 编译,注意可能会出现机器上缺少依赖包的提示,按提示安装依赖包,直到make成功。

 

4.make test 运行测试,一路显示ok通过(需要安装TCL依赖包,见提示)。

 

 

这时在src目录下会多出几个可执行程序,其中redis-server是服务主程序。我们运行redis-server --help看看有哪些参数:

 

 

5. ./src/redis-server & 后台启动Redis,会显示成功画面,但会有三个警告提示。redis的提示很详细,我们照着做修改即可。

 

echo 511 > /proc/sys/net/core/somaxconn

vim /etc/sysctl.conf 加入vm.overcommit_memory = 1

vim /etc/rc.local 加入 echo never > /sys/kernel/mm/transparent_hugepage/enabled

 

后两个重启生效。再次运行redis-server命令,只存在一个没有指定config文件使用缺省配置的警告。启动画面如下:

 

 

我们看到,服务已启动,监听的端口号是6379

 

6. ./src/redis-cli 运行提供的客户端程序,体验下简单操作命令。

 

 

redis所有支持命令在 http://redis.io/commands 上可以查到。

 

7. ./redis-cli shutdown 关闭redis服务。

 

8. make install 将redis命令安装到bin目录下,成为系统命令。

 

Redis配置参数

 

前面我们启动redis,没有指定配置文件,一般情况下,我们需要指定配置文件启动。在redis主目录下,有个redis.conf配置文件模板。cp redis.conf /etc 复制到etc目录下。

 

redis.conf文件里的配置参数有详细的解释说明,下面是几个常用参数:

 

daemonize 缺省是no, 一般使用改为yes,这样启动redis-server时自动是后台运行方式。

 

port 6379 指定端口号,可以调整自己需要的端口值。

 

tcp-backlog 511 这个值就是前面需要调整somaxconn值的原因,它涉及到TCP连接时accept queue队列的大小,是取它们的最小值。这个参数和redis高并发处理请求密切相关,根据实际运行情况调整。

 

bind 只接受来自某IP的请求,安全考虑,缺省不限制。

 

tcp-keepalive 60 主动检测客户端连接是否正常,官方建议是60s

 

loglevel notice 定义日志级别

logfile "" 定义日志文件位置

 

save 900 1 存储数据到硬盘策略,这条定义的是900s内如有1个key值发生变化,就执行save存数据快照到硬盘操作。

 

dbfilename dump.rdb 指定数据快照文件名

dir ./ 指定数据快照文件目录

 

调整好参数后,我们用redis-server /etc/redis.conf 命令启动即可。

 

Java程序访问Redis

 

Redis支持的客户端操作语言非常丰富,达到40多种。就Java来说,也有很多访问驱动实现,我们最常用的还是Jedis。

 

Jedis源码地址: https://github.com/xetorthio/jedis 活跃度很高,能够跟上Redis服务端发布的最新功能,而且使用简单,基本和Redis命令行语法相似。

 

下面我们就在spring工程下简单使用下Jedis:

 

1. pom.xml 中配置Jedis和单元测试jar包。

 

<dependency>

<groupId>redis.clients</groupId>

<artifactId>jedis</artifactId>

<version>2.7.2</version>

</dependency>

 

<dependency>

<groupId>junit</groupId>

<artifactId>junit</artifactId>

<version>4.10</version>

<scope>test</scope>

</dependency>

 

<dependency>

<groupId>org.springframework</groupId>

<artifactId>spring-test</artifactId>

<version>${spring.version}</version>

<scope>test</scope>

</dependency>

 

2. spring配置xml文件配置Jedis连接服务器相关参数。

 

<bean id="poolConfig" class="redis.clients.jedis.JedisPoolConfig">

<property name="maxTotal" value="4096"/>

<property name="maxIdle" value="200"/>

<property name="maxWaitMillis" value="3000"/>

<property name="testOnBorrow" value="true" />

<property name="testOnReturn" value="true" />

</bean>

 

<bean id="jedisPool" class="redis.clients.jedis.JedisPool">

<constructor-arg index="0" ref="poolConfig"/>

<constructor-arg index="1" value="127.0.0.1"/>

<constructor-arg index="2" value="6379" type="int"/>

</bean>

 

3. 编写测试代码:

 

@RunWith(SpringJUnit4ClassRunner.class)

@ContextConfiguration(locations = "classpath:spring-test.xml")

public class RedisTest extends AbstractJUnit4SpringContextTests {

 

@Autowired

private JedisPool jedisPool;

 

@Test

public void basicOpTest(){

 

Jedis jedis = jedisPool.getResource();

 

jedis.set("person.001.name", "frank");

jedis.set("person.001.city", "beijing");

 

String name = jedis.get("person.001.name");

String city = jedis.get("person.001.city");

 

assertEquals("frank",name);

assertEquals("beijing",city);

 

jedis.del("person.001.name");

Boolean result = jedis.exists("person.001.name");

assertEquals(false,result);

 

result = jedis.exists("person.001.city");

assertEquals(true,result);

 

jedis.close();

}

}

 

eclipse下JUnit Test运行单元测试通过!

 

 

读完本篇,你应该了解如下内容:

1.Redis是基于内存的数据存储系统,数据以<key,value>形式存储。value支持多种数据类型,包括String、Hash、List、Set、Sorted Set等。

 

2.Redis采用C语言开发,安装运行在linux等POSIX系统上,windows系统上有第三方移植,可做开发测试。

 

3.Java常用的Redis客户端编程驱动是Jedis。

 

本文摘自微信号:Java架构师

 

转载于:https://www.cnblogs.com/jelynn/p/5192236.html

你可能感兴趣的文章
eclipse 快捷键Open Implementation 直接退出
查看>>
minix中管道文件和设备文件的读写
查看>>
JAXB - Annotations, Annotations for Enums: XmlEnum, XmlEnumValue
查看>>
context 插图
查看>>
文件管理器中不支持的wma歌曲也显示可以播放的音乐图标
查看>>
Java基础学习-流程控制语句
查看>>
Shell中read的常用方式
查看>>
01javascript数据类型
查看>>
asp.net实现md5加密方法详解
查看>>
AJAX
查看>>
table 的thead th 固定 tbody滚动例子
查看>>
并行计算思考----回溯法求解数独问题
查看>>
设计模式:模板模式
查看>>
和菜鸟一起学OK6410之ADC模块
查看>>
代理 模式
查看>>
[git] 细说commit (git add/commit/diff/rm/reset 以及 index 的概念)
查看>>
DOM Core和HTML DOM的区别
查看>>
SurfaceView+MediaPlay的bug们
查看>>
网络表示学习总结
查看>>
完成评论功能
查看>>