一、环境

服务器A:ubuntu server 12.04(192.168.1.111)

服务器B:ubuntu server 12.04 (47.50.13.111)

二、memcached安装

sudo apt-get install memcached

安装完成后可以启动一下,看是否安装好了:

# sudo memcached -d -m 128 -p 11211 -u root

# telnet 127.0.0.1 11211
Trying 127.0.0.1...
Connected to 127.0.0.1.
Escape character is '^]'.
set name 0 0 5
hello
STORED
get name
hello

可以存取数据即代表安装完成。

三、repcached安装

https://sourceforge.net/projects/repcached/files/repcached/ 下载repcached安装包(memcached-1.2.8-repcached-2.2.1.tar.gz),然后解压安装:

# tar zxvf memcached-1.2.8-repcached-2.2.tar.gz

# cd memcached-1.2.8-repcached-2.2/

# ./configure --enable-replication

# make

# make install

正常情况下按上面的安装就可以了,但也有可能会遇到以下问题:

1、machine `i686-pc-linux' not recognized 错误

解决办法是在./configure时加上参数:--build=i686-pc-linux-gnu

2、configure: error: no acceptable C compiler found in $PATH See `config.log' for more details.

这是因为没有安装c编译器,安装gcc即可:

# apt-get install gcc

3、memcached.c:696:30: error: ‘IOV_MAX’ undeclared (first use in this function)

把memcached.c中55行~60行代码:

  55 /* FreeBSD 4.x doesn't have IOV_MAX exposed. */
56 #ifndef IOV_MAX
57 #if defined(__FreeBSD__) defined(__APPLE__)
58 # define IOV_MAX 1024
59 #endif
60 #endif

换为:

  55 /* FreeBSD 4.x doesn't have IOV_MAX exposed. */
56 #ifndef IOV_MAX
57 /*#if defined(__FreeBSD__) defined(__APPLE__)*/
58 # define IOV_MAX 1024
59 #endif
60 /*#endif*/

即把 57 行和60行注释掉。

四、主从配置

我们要把服务器B作为Master,把服务器A作为Slave,首先在服务器A(Master)上配置如下:

# /usr/local/bin/memcached -p 11211 -v -d -u root

replication: listen

在服务器B(Slave)上配置如下:

# /usr/local/bin/repcached -p 11212 -x 47.50.13.111 -v -d -u root

replication: connect (peer=47.50.13.111:11212) 

replication: marugoto copying

replication: accept

这里看到出现了一个11212,Memcached默认服务端口是11211,默认同步监听端口是11212。

这一步要确保在Slave上可以telnet上Master服务器。

如果telnet失败,一般会是iptables把11211/11212端口阻止了,打开即可。

可以通过netstat命令查看:

# netstat -tupln  grep memcached

tcp        0      0 0.0.0.0:11211           0.0.0.0:*               LISTEN      2044/memcached
tcp 0 0 0.0.0.0:11212 0.0.0.0:* LISTEN 2044/memcached
tcp6 0 0 :::11211 :::* LISTEN 2044/memcached
udp 0 0 0.0.0.0:11211 0.0.0.0:* 2044/memcached
udp6 0 0 :::11211 :::* 2044/memcached

五、验证

在Master上创建数据:

# telnet 127.0.0.1 11211
Trying 127.0.0.1...
Connected to 127.0.0.1.
Escape character is '^]'.
set name 0 0 5
atwal
STORED

在Slave上查看数据:

$ telnet 127.0.0.1 11211
Trying 127.0.0.1...
Connected to 127.0.0.1.
Escape character is '^]'.
get name
VALUE name 0 5
atwal
END

可以看到数据已经同步了。

通过repcached实现memcached主从复制的更多相关文章

  1. Repcached实现memcached复制

    1.介绍     repcached是日本人开发的实现memcached复制功能,它是一个单 master单 slave的方案,但它的master/slave都是可读写的,而且可以相互同步,如果 ma ...

  2. Memcached实战之复制----基于repcached的主从【转】

    由于 Memcached 自己没有防止单点的措施,因为为了保障 Memcached 服务的高可用,我们需要借助外部的工具来实现高可用的功能.本文引入 Repcached 这个工具,通过使用该工具我们可 ...

  3. 非root用户Memcached repcached安装

    安装memcached前先要确定系统是否安装了gcc: 1.解压安装包: tar -zxf memcached-1.2.8-repcached-2.2.tar.gz 2.编译: 系统应安装了libev ...

  4. Memcached高可用组件之repcached

    在前边的tomcat session server msm的那篇博客我们用memcached做tomcat session服务器,默认官方memcached是不支持主从同步的,为了解决memcache ...

  5. Memcached repcached 高可用

    Memcached + repcached 高可用环境 repcached 就是一个让memcached的机器能够互为主从,前端可以加一台HAProxy,后端两台memcached互为主从后,写入任何 ...

  6. 【转】centos安装memcached+php多服务器共享+session多机共享问题

    参考博文: centos安装memcached 源码安装 Yum安装Memcache Memcached内存分配优化及使用问题 <转>php+memcached 实现session共享 P ...

  7. memcached学习(5). memcached的应用和兼容程序

    mixi在提供服务的初期阶段就使用了memcached. 随着网站访问量的急剧增加,单纯为数据库添加slave已无法满足需要,因此引入了memcached. 此外,我们也从增加可扩展性的方面进行了验证 ...

  8. memcached全面剖析--5

    memcached的应用和兼容程序 mixi案例研究 mixi在提供服务的初期阶段就使用了memcached. 随着网站访问量的急剧增加,单纯为数据库添加slave已无法满足需要,因此引入了memca ...

  9. Memcached全面剖析–5. memcached的应用和兼容程序

    作者:长野雅广(Masahiro Nagano)  原文链接:http://gihyo.jp/dev/feature/01/memcached/0005 我是Mixi的长野.memcached的连载最 ...

随机推荐

  1. TSP 遗传算法

    GA——遗传算法 同模拟退火算法一样,都是现代优化算法之一.模拟退火是在一定接受程度的情况下仍然接受一个比较差的解. 遗传算法,是真真正正的和大自然的遗传进化有着非常紧密的联系的,当然遗传进化的只是在 ...

  2. [19/03/18-星期一] 常用类_Math(数学)类&Rondom(随机数)类

    一.Math(数学)类(单独一个Java.Math 包中) java.lang.Math提供了一系列静态方法用于科学计算;其方法的参数和返回值类型一般为double型.如果需要更加强大的数学运算能力, ...

  3. [18/11/7] Java的基础概念

    java语言的优势是跨平台 ,计算机界的英语,是IT行业的第一大语言 特点是多线程 分布式 健壮性 面向对象 java和JavaScript的关系 雷锋和雷峰塔的关系 或卡巴斯基和巴基斯坦的关系有个基 ...

  4. 2018.10.7 理解Hibernate的工作原理及其中的ORM详解

    复习 hibernate框架 简介j及其搭建: hibernate是一个开源框架,它是对象关联关系映射的框架,它对JDBC做了轻量级的封装,而我们java程序员可以使用面向对象的思想来操纵数据库. 1 ...

  5. Very Deep Convolutional Networks for Large-scale Image Recognition(vggnet)

    vggNet是从AlexNet而来,主要探索卷积神经网络的深度与性能之间的关系,通过反复堆叠3x3的卷积核(c中有1x1的卷积核,也只有c中有,c是16层)和2x2的最大池化层,vggNet构筑了16 ...

  6. java安装以及jdk和jre安装(简单了解)

    轻松了解JDK是什么 什么是jdk? JDK是学好Java的第一步.不管是你要学习java编程,还是要搭建jsp web开发环境,或者是android开发环境都离不开它. jdk是什么呢?jdk的是j ...

  7. 【luogu P3410 拍照】 题解

    题目链接:https://www.luogu.org/problemnew/show/P3410 这个题就是求一个最大权闭合图 在一个图中,一些点构成一个集合,且集合中的出边指向的终点也在这个集合中, ...

  8. AngularJS 控制器函数

    <!DOCTYPE html><html><head><meta http-equiv="Content-Type" content=&q ...

  9. ipython notebook开通远程

    之前只是会用,别人告诉我命令和大概怎么设置的,今天自己搭建才发现一知半解搞不定啊. 目的:远程通过ipython notebook调用服务器. 服务器是ubuntu16.04 本地机器win7 配置方 ...

  10. 重写viewWillAppear 和 viewWillDisAppear时[super viewWillAppear] 和 [super viewWillDisappear]的调用位置

    参考网址:https://stackoverflow.com/questions/3906704/when-should-i-call-super 在写代码的过程中如果重写了viewWillAppea ...