一步一步教你网站同步镜像(2)

时间:2008-07-31 14:42:00 

MySQL

MySQL数据同步主要有三种方式:

1.利用MySQL自身的数据库同步功能

2.利用MySQL数据库的特性(数据库存在固顶目录,并且以文件形式存储),进行数据库目录同步以达到数据同步目的
3.利用专用的MySQL数据库同步软件

1. 利用MySQL自身的数据库同步功能(下面参考自网上的文章,写的非常详细了)

MySQL从3.23.15版本以后提供数据库复制功能。利用该功能可以实现两个数据库同步,主从模式,互相备份模式的功能.

数据库同步复制功能的设置都在mysql的设置文件中体现。mysql的配置文件(一般是my.cnf),在unix环境下在/etc/mysql/my.cnf 或者在mysql用户的home目录下的my.cnf。

windows环境中,如果c:根目录下有my.cnf文件则取该配置文件。当运行mysql的winmysqladmin.exe工具时候,该工具会把c:根目录下的my.cnf 命名为mycnf.bak。并在winnt目录下创建my.ini。mysql服务器启动时候会读该配置文件。所以可以把my.cnf中的内容拷贝到my.ini文件中,用my.ini文件作为mysql服务器的配置文件。

设置范例环境:

操作系统:window2000 professional

mysql:4.0.4-beta-max-nt-log

A ip:10.10.10.22

B ip:10.10.10.53

A:设置

1.增加一个用户最为同步的用户帐号:

GRANT FILE ON *.* TO backup@'10.10.10.53' IDENTIFIED BY ‘1234’

2.增加一个数据库作为同步数据库:

create database backup

B:设置

1.增加一个用户最为同步的用户帐号:

GRANT FILE ON *.* TO backup@'10.10.10.22' IDENTIFIED BY ‘1234’

2.增加一个数据库作为同步数据库:

create database backup

主从模式:A->B

A为master

修改A mysql的my.ini文件。在mysqld配置项中加入下面配置: 

server-id=1

log-bin

        #设置需要记录log 可以设置log-bin=c:mysqlbakmysqllog 设置日志文件的目录,
  #其中mysqllog是日志文件的名称,mysql将建立不同扩展名,文件名为mysqllog的几个日志文件。
  binlog-do-db=backup #指定需要日志的数据库
  重起数据库服务。
  用show master status 命令看日志情况。
  B为slave
  修改B mysql的my.ini文件。在mysqld配置项中加入下面配置:
  server-id=2
  master-host=10.10.10.22
  master-user=backup #同步用户帐号
  master-password=1234
  master-port=3306
  master-connect-retry=60 预设重试间隔60秒
  replicate-do-db=backup 告诉slave只做backup数据库的更新
  重起数据库
  用show slave status看同步配置情况。
  注意:由于设置了slave的配置信息,mysql在数据库目录下生成master.info
  所以如有要修改相关slave的配置要先删除该文件。否则修改的配置不能生效。
  双机互备模式。
  如果在A加入slave设置,在B加入master设置,则可以做B->A的同步。
  在A的配置文件中 mysqld 配置项加入以下设置:
  master-host=10.10.10.53
  master-user=backup
  master-password=1234
  replicate-do-db=backup
  master-connect-retry=10
  在B的配置文件中 mysqld 配置项加入以下设置:
  log-bin=c:mysqllogmysqllog
  binlog-do-db=backup
  注意:当有错误产生时*.err日志文件。同步的线程退出,当纠正错误后要让同步机制进行工作,运行slave start
  重起AB机器,则可以实现双向的热备。
  测试:
  向B批量插入大数据量表AA(1872000)条
  A数据库每秒钟可以更新2500条数据。



2.数据库目录同步,方法和文件同步一样,设置好需要同步的两个数据库目录就可以了! 缺点很明显,数据同步只能单向进行,可以作为备份方案

3.用专用的MySQL同步软件进行同步

这方面的软件有SQLBalance 和MyReplicator ,优点是方便直观,还有很多争强功能!
缺点和2一样,只能单项同步!

当然你也可以修改镜像网站的程序为提交数据到母数据库,读取则在当前镜像下的数据,不过,修改起来麻烦!普通用户修改也非常难!呵呵,大家了解一下就可以!给大家一个思路!有能力的朋友可以试试阿!

标签:mysql,数据库,同步,SQL
0
投稿

猜你喜欢

  • 选购国外虚拟主机的五点经验

    2010-03-23 12:40:00
  • Dedecms和Ucenter整合出现-uc服务端编码与DedeCMS编码不一致!要求您的uc服务端编码为:gbk编码”

    2011-05-10 17:07:00
  • 站长访谈:对自己的事业树立一种信仰

    2007-09-19 13:09:00
  • 服务器虚拟化的必须考虑的十大因素

    2010-08-15 18:35:00
  • “麦易网”中国商人自己的网上贸易平台

    2009-01-14 14:42:00
  • 使用Xshell连接VMware上的Linux虚拟机(图文步骤)

    2021-10-29 21:15:10
  • PHPWind v7.3.2好友个人空间中相册链接错误

    2009-05-31 17:15:00
  • 百度凤鸣计划:BTOC商城网站实施战略分析

    2009-10-17 21:03:00
  • 详解Linux多线程编程(不限Linux)

    2021-03-16 03:10:06
  • Linux下如何查看版本信息的方法步骤

    2023-10-08 16:25:42
  • 最大限度提高AdWords广告效果的6大途径

    2009-06-01 11:34:00
  • Windows2003服务器安装及设置教程——组件安全篇

    2010-02-08 12:58:00
  • 提高PR值的十个方法

    2009-01-08 11:38:00
  • 360安全卫士手机安全软件内测版以提供下载

    2009-10-13 08:56:00
  • 一文带你深入理解Linux中的nohup命令

    2023-07-10 11:19:21
  • Google推出根据人口特征进行竞价的广告功能

    2008-01-29 13:04:00
  • DedeCMS整合PHPWind超级简单教程

    2009-07-18 19:11:00
  • IIS优化指南

    2010-08-15 18:49:00
  • LZCMS谈如何设计合适的广告位置

    2010-05-07 17:37:00
  • 精挑细选网站关键词

    2007-11-29 12:43:00
  • asp之家 网站运营 m.aspxhome.com