背景:最近在学习Redis服务器,搭建的步骤记录一下吧~~~
一、Redis
REmote DIctionary Server(Redis) 是一个由Salvatore Sanfilippo写的key-value存储系统。
Redis是一个开源的使用ANSI C语言编写、遵守BSD协议、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。
它通常被称为数据结构服务器,因为值(value)可以是 字符串(String), 哈希(Map), 列表(list), 集合(sets) 和 有序集合(sorted sets)等类型。
二、单机版
安装步骤:
1、安装gcc编译环境
yum install gcc-c++
2、上传源码,并解压
tar -zxvf redis-3.0.0.tar.gz
3、make
4、make install PREFIX=/usr/local/redis
5、启动
两种启动方式:前端启动,后台启动
前端启动:/redis-server
后台启动:
1)复制redis.conf到redis的安装目录
2)修改redis.conf。修改daemonize yes
3) ./redis-server redis.conf
查看redis进程
6、测试
使用redis-cli客户端
三、集群版
redis-cluster结构图:
架构细节:
(1)所有的redis节点彼此互联(PING-PONG机制),内部使用二进制协议优化传输速度和带宽
(2)节点的fail是通过集群中超过半数的节点检测失效时才生效
(3)客户端与redis节点直连,不需要中间proxy层.客户端不需要连接集群所有节点,连接集群中任何一个可用节点即可
(4)redis-cluster把所有的物理节点映射到[0-16383]slot上,cluster 负责维护node<->slot<->value
Redis 集群中内置了 16384 个哈希槽,当需要在 Redis 集群中放置一个 key-value 时,redis 先对 key 使用 crc16 算法算出一个结果,然后把结果对 16384 求余数,这样每个 key 都会对应一个编号在 0-16383 之间的哈希槽,redis 会根据节点数量大致均等的将哈希槽映射到不同的节点
搭建步骤:
集群中应该至少有三个节点,每个节点有一备份节点。需要6台服务器。
搭建伪分布式,需要6个redis实例。
1、在创建一个redis-cluster目录,并在其下创建6个redis实例指定redis.conf端口从7001到7006
mkdir redis-cluster
2、修改redis.conf 打开Cluster-enable yes前面的注释。
3、需要一个ruby脚本。在redis源码文件夹下的src目录下。redis-trib.rb。把redis-trib.rb文件复制到到redis-cluster目录下。
5、执行ruby脚本之前,需要安装ruby环境。
yum install ruby
yum install rubygems
安装redis-trib.rb运行依赖的ruby的包。gem install redis-3.0.0.gem
6、启动所有的redis实例。
可以写一个脚本,同时启动redis实例:
./start-all.sh
7、创建集群
./redis-trib.rb create --replicas 1 192.168.25.131:7001 192.168.25.153:7002 192.168.25.153:7003 192.168.25.153:7004 192.168.25.153:7005 192.168.25.153:7006
8、测试
连接集合中任何一台服务器都可以
redis01/redis-cli -p 7001 -c (-c必须有,否则连接失败)
四、如何使用redis的java客户端
1、连接单机版
先把jedis依赖的jar包添加到工程中。
1)不使用连接池
//单机版测试
@Test
public void testJedisSingle() throws Exception {
//创建一个Jedis对象
Jedis jedis = new Jedis("192.168.25.131", 6379);
jedis.set("test", "hello jedis");
String string = jedis.get("test");
System.out.println(string);
jedis.close();
}
//使用连接池
@Test
public void testJedisPool() throws Exception {
//创建一个连接池对象
//系统中应该是单例的。
JedisPool jedisPool = new JedisPool("192.168.25.153", 6379);
//从连接池中获得一个连接
Jedis jedis = jedisPool.getResource();
String result = jedis.get("test");
System.out.println(result);
//jedis必须关闭
jedis.close();
//系统关闭时关闭连接池
jedisPool.close();
}
2、连接集群版
//连接redis集群
@Test
public void testJedisCluster() throws Exception {
//创建一个JedisCluster对象
Set<HostAndPort> nodes = new HashSet<>();
nodes.add(new HostAndPort("192.168.25.153", 7001));
nodes.add(new HostAndPort("192.168.25.153", 7002));
nodes.add(new HostAndPort("192.168.25.153", 7003));
nodes.add(new HostAndPort("192.168.25.153", 7004));
nodes.add(new HostAndPort("192.168.25.153", 7005));
nodes.add(new HostAndPort("192.168.25.153", 7006));
//在nodes中指定每个节点的地址
//jedisCluster在系统中是单例的。
JedisCluster jedisCluster = new JedisCluster(nodes);
jedisCluster.set("name", "zhangsan");
jedisCluster.set("value", "100");
String name = jedisCluster.get("name");
String value = jedisCluster.get("value");
System.out.println(name);
System.out.println(value);
//系统关闭时关闭jedisCluster
jedisCluster.close();
}
五、学习心得
1、静下心来仔细认真的梳理,其实并不难。
2、要想获得更深的理解,自己亲自尝试一下就可以了。