redis主从+哨兵模式只解决了读的分布式操作,大大提高了性能;但是写操作,只有主主机器才能进行,从机器无法进行写操作。此时,Twemproxy也就出现了。

这个模式单纯的安装有些复杂,需要引入很多的辅助工具:

autoconf:下载地址 http://ftp.gnu.org/gnu/autoconf/

Automake  :下载地址http://ftp.gnu.org/gnu/automake/

libtool:下载地址 http://ftp.gnu.org/gnu/libtool/

twemproxy下载地址:https://codeload.github.com/twitter/twemproxy/zip/master

记住,都要高版本的,版本太旧,容易出问题》

安装步骤,我是根据尚学堂视频进行操作的,大体流程如下:

这里的安装目录都在usr目录下,这样可以偷懒不配置环境变量,如果更改安装目录,那你自己去配置环境变量,我这里找到一篇微博,此人是自己配置环境变量的,

可以参考 : http://blog.csdn.net/kk185800961/article/details/53364334

接下来我将逐步分解过程:

1、首先将安装好的压缩包全部上传到linux服务器,我这里有3台虚拟机,redis服务分别部署在这3台不同的虚拟机上面(如果不会,请参考我的《Redis的安装、服务配置》一文);

而twemproxy代理我仅仅部署在CentOS1(192.168.238.128)上面,文件传输路径为/home/tool/sourceDir目录下,并解压

安装是要有先后顺序的,依次安装autoconf、autoMake、libtool、twemproxy-master;

进入/home/tool/sourceDir目录下,分别开始安装:

安装autoconf:

[root@server autoconf-2.69]# cd autoconf-2.69
[root@server autoconf-2.69]# ./configure --prefix=/usr
[root@server autoconf-2.69]# make && make install

安装automake:

[root@server automake-1.15.]# cd automake-1.15.
[root@server automake-1.15.]# ./configure --prefix=/usr
[root@serverautomake-1.15.]# make && make install

安装libtool:

[root@server libtool-2.4.]# cd libtool-2.4.
[root@server libtool-2.4.]# ./configure --prefix=/usr
[root@server libtool-2.4.]# make && make install

安装twemproxy:

[root@server twemproxy-master]# cd twemproxy
[root@server twemproxy-master]# aclocal
[root@server twemproxy-master]# autoconf
[root@server twemproxy-master]# mkdir config
[root@server twemproxy-master]# autoheader
[root@server twemproxy-master]# libtoolize
[root@server twemproxy-master]# automake -a
[root@server twemproxy-master]# ./configure
[root@server twemproxy-master]# make
[root@server twemproxy-master]# make install

# 配置文件 nutcracker.yml(我的都是真实IP)(注意:此文件必须要找到安装目录下的nutcracker命令,放在此命令同目录的conf文件夹下

具体配置信息:

alpha:
     listen: 192.168.238.128:22121
    hash: fnv1a_64
    distribution: ketama
    auto_eject_hosts: true
   redis: true
   server_retry_timeout: 2000
   server_failure_limit: 1
   servers:
        - 192.168.238.128:6379:1
        - 192.168.238.131:6379:1
        - 192.168.238.132:6379:1

测试配置文件:

首先需要将redis的服务全部启动,然后启动twemproxy

接下来进入代理模式中:

OK,配置完成,接下来可以进行你需要的操作了。

再来说说问题:

问题实在太多了,举几个最容易发现的问题吧。

1、在代理中,keys * 不可执行

2、对字符串操作,当CentOS1、CentOS3、CentOS4之前就有相同的key时候,通过代理拿到的值永远都是本机的(CentOS1),其余的拿不到

3、对无序集合也是一样的,CentOS4的值是:

  

CentOS3的值是:

通过代理拿到的值,不知道怎么回事,一直都是CentOS4里面的,CentOS3的值一直拿不到,搞不懂是什么原理

 以上说的情况,都是redis服务之前就有这些键值情况下出现的,如果全部通过Twemproxy进行设置,然后在通过Twemproxy进行拿值,是不会出现这样的问题的。

还是一点也很要命,通过Twemproxy设置的值,各个redis服务是不同步的,只要某一台redis服务宕机了,里面的数据也就拿不到了。

当然,以上问题,肯定是有解决办法的,以后会继续学习和完善这些问题。

redis代理集群(Twemproxy)(1)的更多相关文章

  1. Redis分布式集群几点说道

    原文地址:http://www.cnblogs.com/verrion/p/redis_structure_type_selection.html  Redis分布式集群几点说道 Redis数据量日益 ...

  2. 【Redis】Redis分布式集群几点说道

    Redis数据量日益增大,使用的公司越来越多,不仅用于做缓存,同时趋向于存储这一块,这样必促使集群的发展,各个公司也在收集适合自己的集群方案,目前行业用的比较多的是下面几种集群架构,大部分都是采用分片 ...

  3. Redis Cluster集群知识学习总结

    Redis集群解决方案有两个: 1)  Twemproxy: 这是Twitter推出的解决方案,简单的说就是上层加个代理负责分发,属于client端集群方案,目前很多应用者都在采用的解决方案.Twem ...

  4. Redis cluster集群:原理及搭建

    Redis cluster集群:原理及搭建 2018年03月19日 16:00:55 阅读数:6120 1.为什么使用redis? redis是一种典型的no-sql 即非关系数据库 像python的 ...

  5. 15、Redis的集群

     写在前面的话:读书破万卷,编码如有神 -------------------------------------------------------------------------------- ...

  6. Redis Cluster集群搭建<原>

    一.环境配置 一台window 7上安装虚拟机,虚拟机中安装的是centos系统. 二.目标     Redis集群搭建的方式有多种,根据集群逻辑的位置,大致可以分为三大类:基于客户端分片的Redis ...

  7. redis集群与分片(1)-redis服务器集群、客户端分片

    下面是来自知乎大神的一段说明,个人觉得非常清晰,就收藏了. 为什么集群? 通常,为了提高网站响应速度,总是把热点数据保存在内存中而不是直接从后端数据库中读取.Redis是一个很好的Cache工具.大型 ...

  8. Redis缓存集群方案

    由于单台Redis服务器的内存管理能力有限,使用过大内存的Redis又会使得服务器的性能急剧下降,一旦服务器发生故障将会影响更大范围业务,而Redis 3.0 beta1支持的集群功能还不适合生产环境 ...

  9. Redis Cluster 集群使用(3)

    简介 Redis3.0版本之前,可以通过Redis Sentinel(哨兵)来实现高可用(HA),从3.0版本之后,官方推出了Redis Cluster,它的主要用途是实现数据分片(Data Shar ...

随机推荐

  1. 批量插入,update

    #####setting 1create table t as select * from all_objects where 1 =2; ###.模拟逐行提交的情况,注意观察执行时间DECLAREB ...

  2. 1121 - Reverse the lights 思维题

    http://www.ifrog.cc/acm/problem/1121 我看到这些翻转的题就怕,可能要练下这些专题. 我最怕这类题了. 一开始想了下dp, dp[i][0 / 1]表示完成了前i位, ...

  3. 单周期cpu设计代码解读

    目录 写在前面 单周期cpu设计代码讲解 概念回顾 Verilog代码讲解 写在前面 欢迎转载,转载请说明出处. 单周期cpu设计代码讲解 概念回顾 一.电子计算机的部件 分为:中央处理器(cpu). ...

  4. 判断网站织梦DedeCms版本的方法

    这个方法可以判断出目标网站所使用的织梦DedeCms是哪个版本的,打了哪一天的补丁. 在需要判断网站织梦版本的的URL路径后面添加/data/admin/ver.txt 如官方的:http://www ...

  5. [20190625]记录npm的一些常用命令

    1. 安装依赖包 npm install -g packageName //全局安装npm install packageName --save //安装在项目下并写入package.json文件中n ...

  6. css 02

    Css 02 Url  ./  http://www. Src  引入 拿取过来内容 Href 引用 连接前往 a  link 现在所有的命名 请按照下面我说的去命名 可以使用字母 数字 下划线组成  ...

  7. 解决ajax 遇到session失效后自动跳转的问题

    在项目中,经常会遇到session失效后,点击任何链接无反应的情况!这样给客户的体验就不是很好,以为是系统出了故障!所以在项目中我们会处理session失效后的跳转问题(一般给用户提示,并跳转后登录页 ...

  8. SQL Server一个特殊的阻塞案例分析2

    最近发现一个非常奇怪的阻塞问题,如下截图所示(来自监控工具DPA),会话583被会话1036阻塞,而且阻塞发生在tempdb,被阻塞的SQL如下截图所示,会话等待类型为LCK_M_S 因为DPA工具不 ...

  9. windows 10 无法使用内置管理员账户打开应用的解决方案

    步骤 运行regedit.msc: 依次找到:HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\System\ ...

  10. C#实现灰度图像和彩色图像的4种镜像

    一:灰度图像的水平镜像核心代码:  二:灰度图像的竖直镜像 核心代码:三:彩色图像的水平镜像 核心代码: 四:彩色图像的竖直镜像 核心代码: