Jedis编程设计:ShardJedis/ShardJedisPool

基于Jedis实现Redis分片的理解

http://m.blog.csdn.net/blog/wenzhibinbin_pt/22808939

 

Jedis编程设计:ShardJedis/ShardJedisPool

http://www.verydemo.com/demo_c288_i90831.html

 

Jedis分片及扩容

http://blog.csdn.net/lang_man_xing/article/details/38405269

 

1.       扩容问题:

因为使用了一致性哈稀进行分片,那么不同的key分布到不同的Redis-Server上,当我们需要扩容时,需要增加机器到分片列表中,这时候会使得同样的key算出来落到跟原来不同的机器上,这样如果要取某一个值,会出现取不到的情况,对于这种情况,Redis的作者提出了一种名为Pre-Sharding的方式:

Pre-Sharding方法是将每一个台物理机上,运行多个不同断口的Redis实例,假如有三个物理机,每个物理机运行三个Redis实际,那么我们的分片列表中实际有9Redis实例,当我们需要扩容时,增加一台物理机,步骤如下:

A.     在新的物理机上运行Redis-Server

B.      该Redis-Server从属于(slaveof)分片列表中的某一Redis-Server(假设叫RedisA);

C.      等主从复制(Replication)完成后,将客户端分片列表中RedisAIP和端口改为新物理机上Redis-ServerIP和端口;

D.     停止RedisA

这样相当于将某一Redis-Server转移到了一台新机器上。Prd-Sharding实际上是一种在线扩容的办法,但还是很依赖Redis本身的复制功能的,如果主库快照数据文件过大,这个复制的过程也会很久,同时会给主库带来压力。所以做这个拆分的过程最好选择为业务访问低峰时段进行。

 再总结一下这里的扩容:其实这里的扩容很简单的思想:就是前期我们可能只用到两三个服务器,但是但是担心后期要扩容,所以前期就现在每一个机器上面再装两个redis,这样就有9个redis嘛,后面如果确实服务器不够,需要扩容,就重新找一台新机来代替9个中的一个redis,有人说,这样不还是9个么,是的,但是以前服务器上面有三个redis,压力很大的,这样做,相当于单独分离出来并且将数据一起copy给新的服务器。值得注意的是,还需要修改客户端被代替的redis的IP和端口为现在新的服务器,只要顺序不变,不会影响一致性哈希分片(刚才上面刚说了哈)。

2.       单点故障问题:

还是用到Redis主从复制的功能,两台物理主机上分别都运行有Redis-Server,其中一个Redis-Server是另一个的从库,采用双机热备技术,客户端通过虚拟IP访问主库的物理IP,当主库宕机时,切换到从库的物理IP。只是事后修复主库时,应该将之前的从库改为主库(使用命令slaveof no one),主库变为其从库(使命令slaveof IP PORT),这样才能保证修复期间新增数据的一致性。


转载于:https://my.oschina.net/u/347386/blog/525541

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
引用\[1\]:Caused by: java.lang.ClassNotFoundException: redis.clients.jedis.UnifiedJedis at java.net.URLClassLoader$1.run(URLClassLoader.java:372) ~\[na:1.8.0_20\] at java.net.URLClassLoader$1.run(URLClassLoader.java:361) ~\[na:1.8.0_20\] at java.security.AccessController.doPrivileged(Native Method) ~\[na:1.8.0_20\] at java.net.URLClassLoader.findClass(URLClassLoader.java:360) ~\[na:1.8.0_20\] at java.lang.ClassLoader.loadClass(ClassLoader.java:424) ~\[na:1.8.0_20\] at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308) ~\[na:1.8.0_20\] at java.lang.ClassLoader.loadClass(ClassLoader.java:357) ~\[na:1.8.0_20\] ... 56 common frames omitted 引用\[2\]:只要将redis启动器中的lettuce排除在外,注意版本号不要写,默认会继承父项目的版本号以防jar包冲突。 <!-- redis启动器--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> <exclusions> <exclusion> <groupId>io.lettuce</groupId> <artifactId>lettuce-core</artifactId> </exclusion> </exclusions> </dependency> <!-- jedis连接池--> <dependency> <groupId>redis.clients</groupId> <artifactId>jedis</artifactId> </dependency> 引用\[3\]:在pom中导入jetcache坐标中的redis与springboot版本冲突导致, <dependency> <groupId>com.alicp.jetcache</groupId> <artifactId>jetcache-starter-redis</artifactId> <version>2.7.0.M1</version> <!--这里版本不唯一,也可能是别的版本--> </dependency> 解决方法: 问题:Caused by: java.lang.NoClassDefFoundError: redis/clients/jedis/ConnectionPoolConfig 回答: 这个错误是由于缺少redis.clients.jedis.ConnectionPoolConfig类引起的。根据引用\[1\],可能是由于缺少redis.clients.jedis.UnifiedJedis类导致的。解决这个问题的方法有两种。一种是根据引用\[2\],在项目的pom文件中排除lettuce-core依赖,然后添加jedis依赖。另一种是根据引用\[3\],检查项目中的redis和springboot版本是否冲突,如果有冲突,可以尝试升级或降级其中一个版本以解决冲突。 #### 引用[.reference_title] - *1* *3* [【Spring常见错误】java.lang.NoClassDefFoundError: redis/clients/jedis/UnifiedJedis](https://blog.csdn.net/qq_52360069/article/details/125275138)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [springboot整合redis中 出现Caused by: java.lang.NoClassDefFoundError: redis/clients/jedis/util/Pool](https://blog.csdn.net/qq_45059663/article/details/113608498)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值