怎么使 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与javascript对多项选择的处理
Oct 09 PHP
php入门教程 精简版
Dec 13 PHP
如何使用Linux的Crontab定时执行PHP脚本的方法
Dec 19 PHP
php代码收集表单内容并写入文件的代码
Jan 29 PHP
destoon文章模块调用企业会员资料的方法
Aug 22 PHP
PHP会话控制:Session与Cookie详解
Sep 27 PHP
php基于base64解码图片与加密图片还原实例
Nov 03 PHP
php+mysql实现用户注册登陆的方法
Jan 03 PHP
PHP curl伪造IP地址和header信息代码实例
Apr 27 PHP
图文详解phpstorm配置Xdebug进行调试PHP教程
Jun 13 PHP
php基于单例模式封装mysql类完整实例
Oct 18 PHP
php图形jpgraph操作实例分析
Feb 22 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使用pear自带的mail类库发邮件的方法
2015/07/08 PHP
浅析Yii2 GridView实现下拉搜索教程
2016/04/22 PHP
php设计模式之原型模式分析【星际争霸游戏案例】
2020/03/23 PHP
PHP执行系统命令函数实例讲解
2021/03/03 PHP
用Javascript同时提交多个Web表单的方法
2009/12/26 Javascript
javascript与CSS复习(三)
2010/06/29 Javascript
JavaScript调用堆栈及setTimeout使用方法深入剖析
2013/02/16 Javascript
js关闭父窗口时关闭子窗口
2013/04/01 Javascript
Javascript中的String对象详谈
2014/03/03 Javascript
Adapter适配器模式在JavaScript设计模式编程中的运用分析
2016/05/18 Javascript
Vue.js 递归组件实现树形菜单(实例分享)
2016/12/21 Javascript
jQuery实现的简单拖拽功能示例【测试可用】
2018/08/14 jQuery
关于vue2强制刷新,解决页面不会重新渲染的问题
2019/10/29 Javascript
Node.js中的异步生成器与异步迭代详解
2021/01/31 Javascript
[56:58]VP vs Optic 2018国际邀请赛小组赛BO2 第一场 8.16
2018/08/17 DOTA
[43:47]完美世界DOTA2联赛PWL S3 LBZS vs Phoenix 第一场 12.09
2020/12/11 DOTA
简单的Python2.7编程初学经验总结
2015/04/01 Python
Python数据类型详解(一)字符串
2016/05/08 Python
python编程嵌套函数实例代码
2018/02/11 Python
对pandas中Series的map函数详解
2018/07/25 Python
Python简单I/O操作示例
2019/03/18 Python
对python特殊函数 __call__()的使用详解
2019/07/02 Python
python实现简单颜色识别程序
2020/02/19 Python
CSS3制作苹果风格键盘特效
2015/02/26 HTML / CSS
MySQL面试题
2014/01/12 面试题
介绍一下ICMP(Internet Control Message Protocol)Internet控制信息协议
2016/11/26 面试题
优秀求职信范文分享
2014/01/26 职场文书
大学生两会学习心得体会
2014/03/10 职场文书
食品安全工作方案
2014/05/07 职场文书
乡镇群众路线教育实践活动整改措施
2014/10/04 职场文书
2015年社区流动人口工作总结
2015/05/12 职场文书
反腐倡廉观后感
2015/06/08 职场文书
PHP使用QR Code生成二维码实例
2021/07/07 PHP
python开发飞机大战游戏
2021/07/15 Python
「租借女友」第2季樱泽墨角色PV&新视觉图公开
2022/03/21 日漫
《进击的巨人》新联动CM 兵长强势出击兽巨人
2022/04/05 日漫