一、环境

服务器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. Codeforces Round #521 (Div. 3) D. Cutting Out 【二分+排序】

    任意门:http://codeforces.com/contest/1077/problem/D D. Cutting Out time limit per test 3 seconds memory ...

  2. maven的.m2文件夹

    安装完maven是没有.m2文件夹的. Maven缺省的本地仓库路径为${user.home}/.m2/repository 在linux中以.开头的文件夹都是隐藏的.当使用maven命令的时候,ma ...

  3. Notepad++ 插件之 TextFX (安装及作用)

    <安装:打开 notepad++  插件 -> Plugin Manager -> Show Plugin Manager -> available ->选中 TextF ...

  4. 使用带有数组的 ng-bind

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

  5. 小白袍 -- Chapter 1.1 避不开的编解码

    1.1  避不开的编解码 能阅读本文的想开都是从事计算机开发工作的,那么弱弱的问自己一下,有没有受到过编码的纠缠呢?有没有动过心思,如果没有编码该多好? 1.1.1  这个翻译你得捏着鼻子用 要想说明 ...

  6. 【TOJ 3005】Triangle(判断点是否在三角形内+卡精度)

    描述 Given the coordinates of the vertices of a triangle,And a point. You just need to judge whether t ...

  7. PostgreSQL异步主从流复制搭建

    1 总体规划   Master库 Slave库 操作系统 CentOS Linux release 7.5.1804 CentOS Linux release 7.5.1804 处理器 1 1 内存 ...

  8. php面向对象基础知识整理之类中的属性和方法的使用

    <?php /** * class Index * 类包含什么 * 1.创建类 * 2.类的属性和类中方法 * 3.类中访问修饰符 * 4.类的封装.继承.多态 */ // 创建类,创建的类名是 ...

  9. Linux 必会

    一.一般命令:1.cd 进入磁盘文件夹2.ls- 查看当前文件夹包含哪些文件,注意-后面的3.pwd 立刻知道目前所在哪个文件及4.mkdir 创建文件夹5.touch touch命令用于修改文件或者 ...

  10. python3 练习题100例 (二十五)打印一个n层金字塔

    题目内容: 打印一个n层(1<n<20)金字塔,金字塔由“+”构成,塔尖是1个“+”,下一层是3个“+”,居中排列,以此类推. 注意:每一行的+号之后均无空格,最后一行没有空格. 输入格式 ...