Twemproxy,也叫Nutcraker。是一个Twtter开源的一个Redis和Memcache代理服务器。 Redis作为一个高效的缓存服务器,非常具有应用价值。但是当使用比较多的时候,就希望可以通过某种方式 统一进行管理。避免每个应用每个客户端管理连接的松散性,同时在一定程度上变得可以控制。 搜索了不少的开源代理项目,知乎实现的Python分片客户端。Node的代理中间层,还有各种Restfull的开源代理。

Twemproxy是一个代理服务器,可以通过它减少Memcached或Redis服务器所打开的连接数。

优点:

1、通过代理的方式减少缓存服务器的连接数

2、自动在多台缓存服务器间共享数据

3、通过不同的策略与散列函数支持一致性散列

4、通过配置的方式禁用失败的结点

5、运行在多个实例上,客户端可以连接到首个可用的代理服务器

6、支持请求的流式与批处理,因而能够降低来回的消耗

一、安装依赖项

  1. yum install automake
  2. yum install libtool

二、更新Autoconf版本。

Twemproxy需要2.64或更高版本。否则编译的时候报错:

autoreconf: Entering directory `.'

autoreconf: configure.ac: not using Gettext

autoreconf: running: aclocal --force -I m4

configure.ac:8: error: Autoconf version 2.64 or higher is required

configure.ac:8: the top level

autom4te: /usr/bin/m4 failed with exit status: 63

aclocal: autom4te failed with exit status: 63

autoreconf: aclocal failed with exit status: 63

下载新版本:  #wget http://ftp.gnu.org/gnu/autoconf/autoconf-2.69.tar.gz

  1. rpm -qf /usr/bin/autoconf
  2. autoconf-2.63-5.1.el6.noarch
  3.  
  4. rpm -e --nodeps autoconf-2.63 #卸载当前版本
  5.  
  6. tar zxvf autoconf-2.69.tar.gz #解压安装
  7. cd autoconf-2.69
  8. ./configure --prefix=/usr #编译
  9. make && make install #安装
  10. /usr/bin/autoconf -V #查看是否安装成功

三、安装Twemproxy

1、 安装git命令

  1. yum install git -y

2、 下载

  1. git clone https://github.com/twitter/twemproxy.git

3、 安装

  1. cd twemproxy
  2. autoreconf -fvi
  3. ./configure --prefix=/usr/local/twemproxy
  4. make -j 8
  5. make install

4、 配置文件

添加pid文件目录和配置文件conf目录

  1. cd /usr/local/twemproxy
  2. mkdir run conf

添加proxy配置文件

  1. cd conf
  1. vim nutcracker.yml
  2.  
  3. alpha:
  4. listen: 127.0.0.1:22222 #使用哪个端口启动Twemproxy
  5. hash: fnv1a_64 #指定具体的hash函数
  6. distribution: ketama #具体的hash算法
  7. auto_eject_hosts: true #是否在结点无法响应的时候临时摘除结点
  8. timeout: 400 #超时时间(毫秒)
  9. redis: true #是否是Redis的proxy
  10. server_retry_timeout: 3000 #重试的时间(毫秒)
  11. server_failure_limit: 1 #结点故障多少次就算摘除掉
  12. servers: #下面表示所有的Redis节点(IP:端口号:权重 别名)
  13. - 192.168.1.10:6379:1 master0
  14. - 192.168.1.7:6379:1 master1

5、 启动twemproxy服务

nutcracker -t 测试配置文件

nutcracker: configuration file 'conf/nutcracker.yml' syntax is ok

启动服务:

  1. nutcracker -d -c /usr/local/twemproxy/conf/nutcracker.yml -p /usr/local/twemproxy/run/redisproxy.pid -o /usr/local/twemproxy/run/redisproxy.log

6nutcracker用法与命令选项

Usage: nutcracker [-?hVdDt] [-v verbosity level] [-o output file]

[-c conf file] [-s stats port] [-a stats addr]

[-i stats interval] [-p pid file] [-m mbuf size]

Options:

-h, –help              : 查看帮助文档,显示命令选项

-V, –version           : 查看nutcracker版本

-t, –test-conf         : 测试配置脚本的正确性

-d, –daemonize           : 以守护进程运行

-D, –describe-stats : 打印状态描述

-v, –verbosity=N   : 设置日志级别 (default: 5, min: 0, max: 11)

-o, –output=S        : 设置日志输出路径,默认为标准错误输出 (default: stderr)

-c, –conf-file=S     : 指定配置文件路径 (default: conf/nutcracker.yml)

-s, –stats-port=N   : 设置状态监控端口,默认22222 (default: 22222)

-a, –stats-addr=S  : 设置状态监控IP,默认0.0.0.0 (default: 0.0.0.0)

-i, –stats-interval=N    : 设置状态聚合间隔 (default: 30000 msec)

-p, –pid-file=S         : 指定进程pid文件路径,默认关闭 (default: off)

-m, –mbuf-size=N      : 设置mbuf块大小,以bytes单位 (default: 16384 bytes)

7、最近在新的公司要上twemproxy方案了,使用过程中出现了一下小问题:

1).yml配置文件中每个参数值对分隔符”:”后需要有一个空格

2)不同层次的参数需要缩进区分,最好使用tab键缩进,否则nutcracker进程不能启动。

3)在auto_eject_hosts: true的时候,关闭一个redis实例后,写入数据还是提示“(error) ERR Connection refused”。这个与server_retry_timeout参数设置太小有关,默认值30000msec是一个很好的选择。

CentOS6.5安装Twemproxy集群的更多相关文章

  1. Centos6.6 安装Mysql集群

    一.环境准备 1.1系统IP设置 准备三台服务器安装Centos6.6 64位操作系统,IP地址及角色分配如下: Node                 IP Address            ...

  2. 36. CentOS-6.3安装Mysql集群

    安装要求 安装环境:CentOS-6.3安装方式:源码编译安装 软件名称:mysql-cluster-gpl-7.2.6-linux2.6-x86_64.tar.gz下载地址:http://mysql ...

  3. redis CentOS6.5安装及集群部署

    .下载redis source包 链接:https://pan.baidu.com/s/122ZCjNvjl9Jx6M2YsLrncw 密码:92ze 2.解压 tar -xzf redis-3.2. ...

  4. CentOS6.5 安装Storm集群

    1.首先安装依赖包 [root@Hadoop-NN-01 ~]# yum install uuid* [root@Hadoop-NN-01 ~]# yum install libuuid [root@ ...

  5. CentOS6.5 安装Spark集群

    一.安装依赖软件Scala(所有节点) 1.下载Scala:http://www.scala-lang.org/files/archive/scala-2.10.4.tgz 2.解压: [root@H ...

  6. CentOS6.5安装HBase集群及多HMaster配置

    1.配置SSH免登录 请参考:http://www.cnblogs.com/hunttown/p/5470357.html 服务器配置: Hadoop-NN-01 主Hadoop-NN-02 备Had ...

  7. CentOS6.5 安装Zookeeper集群

    1.下载解压 2.配置环境变量:vi ~/.bashrc   或者   vi /etc/profile [hadoopuser@Linux01 ~]$ vi ~/.bashrc # zookeeper ...

  8. CentOS6.5 安装Kafka集群

    1.安装zookeeper 参考文档:http://www.cnblogs.com/hunttown/p/5452138.html 2.下载:https://www.apache.org/dyn/cl ...

  9. 安装hadoop集群服务器(hadoop1.2.1)

    摘要:hadoop,一个分布式系统基础架构,可以充分利用集群的威力进行高速运算和存储.本文主要介绍hadoop的安装与集群服务器的配置. 准备文件: ▪ VMware11.0.0      ▪ Cen ...

随机推荐

  1. PCL—低层次视觉—关键点检测(Harris)

    除去NARF这种和特征检测联系比较紧密的方法外,一般来说特征检测都会对曲率变化比较剧烈的点更敏感.Harris算法是图像检测识别算法中非常重要的一个算法,其对物体姿态变化鲁棒性好,对旋转不敏感,可以很 ...

  2. sencha touch 类的使用

    sencha touch 有一套自己的类机制,可以以面向对象的方式去写代码,封装业务逻辑,sencha touch 的组件.插件.api等都建立在这一套类机制的上面 在实际开发中,我们需要遵循这一套机 ...

  3. 部署OpenStack问题汇总(二)--openstack dashboard 问题解决方案

    在打开dashboard的时候报错: LocationParseError at /admin/ (LocationParseError(...), 'Failed to parse: Failed ...

  4. Unity3D Shader落雪效果

    Shader "Custom/Snow" { Properties { _MainTex ("Base (RGB)", 2D) = "white&qu ...

  5. Spring Cloud Eureka 服务消费者

    参考<spring cloud 微服务实战> 现在已经构建了服务注册中心和服务提供中心,下面就来构建服务消费者: 服务消费者主要完成:发现服务和消费服务.其中服务的发现主要由Eureka的 ...

  6. #if 和 #ifdef 条件编译注意

    之前写程序很少用到这两个条件编译,只是在头文件的开头使用过 #ifdef ....<CODE>....  #endif,他是防止头文件被重复包含,导致的变量被多处声明或定义. 最近写程序发 ...

  7. javascript中top、clientTop、scrollTop、offsetTop的讲解(转载加总结)

    scrollHeight: 获取对象的滚动高度. scrollLeft:设置或获取位于对象左边界和窗口中目前可见内容的最左端之间的距离 scrollTop:设置或获取位于对象最顶端和窗口中可见内容的最 ...

  8. Java基础之理解封装,继承,多态三大特性

    目录 封装 继承 多态 封装 封装隐藏了类的内部实现机制,可以在不影响使用的情况下改变类的内部结构,同时也保护了数据.对外界而已它的内部细节是隐藏的,暴露给外界的只是它的访问方法. 代码理解 publ ...

  9. jqueryui和easyui区别

    jQuery自带的一个可选UI库,但是非常可惜,一些关键的组件没有包含进去,如TreeView, DataGrid,还需要寻找第三方的插件. EasyUI是某公司开发的一套对私免费,对公收费的UI库, ...

  10. myeclipse bug

    在.metadata上方就不在workspace里面,复制黏贴在下方才可以发布运行