通过repcached实现memcached主从复制
一、环境
服务器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主从复制的更多相关文章
- Repcached实现memcached复制
1.介绍 repcached是日本人开发的实现memcached复制功能,它是一个单 master单 slave的方案,但它的master/slave都是可读写的,而且可以相互同步,如果 ma ...
- Memcached实战之复制----基于repcached的主从【转】
由于 Memcached 自己没有防止单点的措施,因为为了保障 Memcached 服务的高可用,我们需要借助外部的工具来实现高可用的功能.本文引入 Repcached 这个工具,通过使用该工具我们可 ...
- 非root用户Memcached repcached安装
安装memcached前先要确定系统是否安装了gcc: 1.解压安装包: tar -zxf memcached-1.2.8-repcached-2.2.tar.gz 2.编译: 系统应安装了libev ...
- Memcached高可用组件之repcached
在前边的tomcat session server msm的那篇博客我们用memcached做tomcat session服务器,默认官方memcached是不支持主从同步的,为了解决memcache ...
- Memcached repcached 高可用
Memcached + repcached 高可用环境 repcached 就是一个让memcached的机器能够互为主从,前端可以加一台HAProxy,后端两台memcached互为主从后,写入任何 ...
- 【转】centos安装memcached+php多服务器共享+session多机共享问题
参考博文: centos安装memcached 源码安装 Yum安装Memcache Memcached内存分配优化及使用问题 <转>php+memcached 实现session共享 P ...
- memcached学习(5). memcached的应用和兼容程序
mixi在提供服务的初期阶段就使用了memcached. 随着网站访问量的急剧增加,单纯为数据库添加slave已无法满足需要,因此引入了memcached. 此外,我们也从增加可扩展性的方面进行了验证 ...
- memcached全面剖析--5
memcached的应用和兼容程序 mixi案例研究 mixi在提供服务的初期阶段就使用了memcached. 随着网站访问量的急剧增加,单纯为数据库添加slave已无法满足需要,因此引入了memca ...
- Memcached全面剖析–5. memcached的应用和兼容程序
作者:长野雅广(Masahiro Nagano) 原文链接:http://gihyo.jp/dev/feature/01/memcached/0005 我是Mixi的长野.memcached的连载最 ...
随机推荐
- 2018.12.24 Spring中的aop演示(也就是运用aop技术实现代理模式)
Aop的最大意义是:在不改变原来代码的前提下,也不对源代码做任何协议接口要求.而实现了类似插件的方式,来修改源代码,给源代码插入新的执行代码. 1.spring中的aop演示 aop:面向方面编程.不 ...
- ASP.NET SignalR 与LayIM配合,轻松实现网站客服聊天室(四) 添加表情、群聊功能
休息了两天,还是决定把这个尾巴给收了.本篇是最后一篇,也算是草草收尾吧.今天要加上表情功能和群聊.基本上就差不多了,其他功能,读者可以自行扩展或者优化.至于我写的代码方面,自己也没去重构.好的,我们开 ...
- Spring 的AOP底层实现技术:JDK和CGLIB动态代理
Spring 的AOP实现技术之JDK的动态代理技术实例: 接口:IUserService (Spring的AOP是动态AOP,实现技术:JDK提供的动态代理和cglib代理,cglib它可以为没有实 ...
- DisparityCostVolumeEstimator.cpp
#include "DisparityCostVolumeEstimator.hpp" #include "DisparityCostVolume.hpp" # ...
- 商城管理系统项目(前台+后台+管理员+用户+html+jsp)
管理员后台 用户前台 如果下载项目报错,加包即可(包已经打包放在下载地址) 数据库:mysql drop database shoppingmall; create database shopping ...
- MVC学习七:Razor布局之加载分部视图【PartialView】
Partial View 顾名思义就是Html代码片段,应用于此HTML代码多次被页面加载时使用.(类似于WebForm程序中的用户控件) 注:PartialView和正常的View页面在访问时没有任 ...
- 制作npm插件vue-toast-m实例练习
制作npm插件vue-toast-m实例练习(消息弹窗) 一.使用npm插件 import VueToast from 'vue-toast-demo-cc' Vue.use(VueToast) th ...
- spring入门(五) spring mvc+hibernate
核心是让SessionFactory由Spring管理 1.引入依赖 <!-- https://mvnrepository.com/artifact/org.springframework/sp ...
- CPU运行的流程
- django项目创建requirements.txt文件
workon+虚拟环境名 然后输入 pip freeze > requirements.txt