怎么使 Mysql 数据同步


Posted in PHP onOctober 09, 2006

怎么使 Mysql 数据同步 先假设有主机 A 和 B ( Linux 系统),主机 A 的 IP 分别是 1.2.3.4 (当然,也可以是动态的),主机 B 的 IP 是 5.6.7.8 。两个主机都装上了 PHP+Mysql ,现在操作的是主机 A 上的资料,如果另外一个主机 B 想跟 A 的资料进行同步,应该怎么做呢?  

OK,我们现在就动手。  

首先,如果要想两个主机间的资料同步,一种方法就是主机 A 往主机 B 送资料,另外一种主法就是主机 B 到主机 A 上拿资料,因为 A 的 IP 是动态的(假设),所以我们就得从主机 A 往主机 B 送资料。  

在主机 B 上创建一个 Mysql 账户。  
# GRANT ALL ON test.* TO user@% IDENTIFIED BY "password"; //创建用户 user,可以从任何机器访问到主机 B 上的 test 数据库。  

如果这里显示错误,先把 % 改为一个 IP ,然后再利用 phpMyAdmin 把 IP 改为 % ,测试无误后就可以写 php 程序。  

<?  
$link=mysql_pconnect("localhost","user","password");  
mysql_pconnect("localhost","user","password"); //连接本机(主机A)的数据库  
mysql_select_db("test"); //选择数据库test  

$re=mysql_query("select * from table order by id desc");  
$num=mysql_numrows($re);  
if (!empty($num)) {  
$id=mysql_result($re,0,"id"); //获得本机table表的最大ID  
}  

mysql_close($link); //关闭与本机数据库的连接  

$link=mysql_pconnect("5.6.7.8","test","test");  
mysql_pconnect("5.6.7.8","test","test"); //连接主机B的数据库  
mysql_select_db("test"); //选择数据库test,此数据库应该与主机A上test数据库的结构一样。  
$re=mysql_query("select * from table order by id desc");  
$num=mysql_numrows($re);  
if (!empty($num)) {  
$remote_id=mysql_result($re,0,"id"); //获得主机Btable表的最大ID  
}  

if ($id>$remote_id) {  
$result_id=$id-$remote_id; //如果主机A中table的最大ID大于主机B中table表的最大ID,说明两个  
} 的资料不同  

mysql_close($link); //关闭主机B的数据库连接  

$link=mysql_pconnect("localhost","user","password");  
mysql_pconnect("localhost","user","password");  
mysql_select_db("test");  

if (empty($result_id)) $result_id=0;  
if (empty($remote_id)) $remote_id=0; //如果主机B中的table的最大ID为空(里面没有资料),那么就等0  

$re=mysql_query("select * from table limit $remote_id,$result_id"); //取出主机A中table表与主机B中table表里不同的资料  
$num=mysql_numrows($re);  
if (!empty($num)) {  
for ($i=0;$i<$num;$i++) {  
$test[$i]=mysql_result($re,$i,"test"); //把不同的资料放入一个数组里  
}  
}  
mysql_close($link); //关闭主机A的数据库连接  

$link=mysql_pconnect("5.6.7.8","user","password");  
mysql_pconnect("5.6.7.8","user","pasword");  
mysql_select_db("test");  

for ($j=0;$j<$i;$j++) { //这里的i等于在比较主机A与主机B上table表不同资料的数量  

mysql_query("insert into table (test) values(\'$test[$j]\')");  

}  

mysql_close($link); //关闭主机B的数据库连接  

?>  

这时就初步实现了 A 主机和 B 主机数据的同步,但现在还需要人手动每次去激活这个程序,有没有办法把它作为一个脚本一样的,放在 crontab 里面指定时间自动执行呢?  

在安装 php 时会自动生一个叫 php 的可执行文件,一般在/你安装的 php 目录 /bin 下面,不过较底的版本好像没有,如果没有这个文件,你就得升级你的 php 。  

#php -q test.php  

php 原本是应用在网页应用的?因此它会送出 HTML 的 Header?但是在此我们是要将 php 用作 Shell Script?"-q" 就是表示不要送出 Header 的意思.  

最后编辑 /etc/crontab 里的文件,加上下面这一句。  

0 0 * * * root /home/httpd/html/test //每天晚上零点执/home/httpd/html/test文件(具体使用方法请查看cron的相关资料)  

OK,到这里差不多就已完成 Mysql 数据的同步了,如果各位还有兴趣的话,可以想一个连编辑、删除都能同步的更好的办法。

PHP 相关文章推荐
用PHP连接Oracle for NT 远程数据库
Oct 09 PHP
mysql 的 like 问题,超强毕杀记!!!
Jan 18 PHP
php新建文件自动编号的思路与实现
Jun 27 PHP
php多个文件及图片上传实例详解
Nov 10 PHP
PHP中使用CURL获取页面title例子
Jan 07 PHP
php实现将数组转换为XML的方法
Mar 09 PHP
PHP stream_context_create()函数的使用示例
May 12 PHP
PHP类型约束用法示例
Sep 28 PHP
PHP将数据导出Excel表中的实例(投机型)
Jul 31 PHP
php批量转换文件夹下所有文件编码的函数类
Aug 06 PHP
PHP+redis实现的购物车单例类示例
Feb 02 PHP
php实现微信小程序授权登录功能(实现流程)
Nov 13 PHP
PHP 中的类
Oct 09 #PHP
用PHP实现验证码功能
Oct 09 #PHP
汉字转化为拼音(php版)
Oct 09 #PHP
如何限制访问者的ip(PHPBB的代码)
Oct 09 #PHP
substr()函数中文版
Oct 09 #PHP
如何使用PHP中的字符串函数
Oct 09 #PHP
vBulletin Forum 2.3.xx SQL Injection
Oct 09 #PHP
You might like
PHP 读取Postgresql中的数组
2013/04/14 PHP
深入php socket的讲解与实例分析
2013/06/13 PHP
如何利用http协议发布博客园博文评论
2015/08/03 PHP
PHP的mysqli_thread_id()函数讲解
2019/01/24 PHP
JavaScript基本对象
2007/01/11 Javascript
jquery如何实现锚点链接之间的平滑滚动
2013/12/02 Javascript
js中style.display=&quot;&quot;无效的解决方法
2014/10/30 Javascript
Javascript前端UI框架Kit使用指南之kitjs的对话框组件
2014/11/28 Javascript
DOM节点删除函数removeChild()用法实例
2015/01/12 Javascript
Angular 2父子组件数据传递之@ViewChild获取子组件详解
2017/07/04 Javascript
基于滚动条位置判断的简单实例
2017/12/14 Javascript
一种angular的方法级的缓存注解(装饰器)
2018/03/13 Javascript
vue2.0 + ele的循环表单及验证字段方法
2018/09/18 Javascript
微信公众号获取用户地理位置并列出附近的门店的示例代码
2019/07/25 Javascript
JS实现秒杀倒计时特效
2020/01/02 Javascript
基于JQuery和DWR实现异步数据传递
2020/10/16 jQuery
[46:55]完美世界DOTA2联赛决赛 FTD vs Phoenix 第三场 11.08
2020/11/11 DOTA
Python爬虫框架Scrapy安装使用步骤
2014/04/01 Python
python正则表达式中的括号匹配问题
2014/12/14 Python
python3写爬取B站视频弹幕功能
2017/12/22 Python
python opencv3实现人脸识别(windows)
2018/05/25 Python
对TensorFlow的assign赋值用法详解
2018/07/30 Python
Python使用numpy产生正态分布随机数的向量或矩阵操作示例
2018/08/22 Python
python根据list重命名文件夹里的所有文件实例
2018/10/25 Python
python plotly绘制直方图实例详解
2019/07/22 Python
感知器基础原理及python实现过程详解
2019/09/30 Python
在Python中使用filter去除列表中值为假及空字符串的例子
2019/11/18 Python
win10安装tesserocr配置 Python使用tesserocr识别字母数字验证码
2020/01/16 Python
Tensorflow中k.gradients()和tf.stop_gradient()用法说明
2020/06/10 Python
python 无损批量压缩图片(支持保留图片信息)的示例
2020/09/22 Python
scrapy结合selenium解析动态页面的实现
2020/09/28 Python
python中绕过反爬虫的方法总结
2020/11/25 Python
工作中个人的自我评价
2013/12/31 职场文书
2013年军训通讯稿
2014/02/05 职场文书
办公室主任岗位职责范本
2015/03/31 职场文书
养成教育工作总结
2015/08/13 职场文书