服务器(2)--搭建Redis服务器和集群


背景:最近在学习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();
	}


2)使用连接池

   //使用连接池
	@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、要想获得更深的理解,自己亲自尝试一下就可以了。





  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值