我们在做web系统部署的时候往往涉及到两台甚至多台数据库的备份,为了数据安全考虑(虽然说到底不过是一堆0 1,但是价值千金啊),所以我们还是乖乖做同步把!

1、准备两台Linux服务器(主、从)

2、安装好Mysql

3、在配置文件/etc/my.cnf(MySQL中为mysql.ini)修改开启二进制日志

log-bin=mysql-bin

修改方法:打开配置文件后在

[mysqld]中添加内容:

server-id =   #确保在整个MySQL集群中唯一

log-bin=/var/log/mysql/mysql-bin.log  #日志存放位置

log-bin-index = binlog.index

4、重启mysql服务​

service mysql restart

5、查看配置是否正常

​show variables like 'log-bin';

6.开始主从复制

第一步:在主服务器中创建一个从服务器中可以登陆的MySQL用户

mysql>GRANT REPLICATION SLAVE ON *.*TO '用户名'@'从服务器ip' IDENTIFIED BY '密码';

mysql>FLUSH PRIVILEGES;

第二步:查看主服务器MySQL二进制文件名和位置

mysql> SHOW MASTER STATUS;

第三步:告知二进制文件名和位置

在从服务器中执行(注意标点符号,最后才是分号)

mysql > CHANGE MASTER TO

      >MASTER_HOST='主服务器地址',

      >MASTER_USER='创建的用户名',

      >MASTER_PASSWORD='密码',

      >MASTER_LOG_FILE='mysql-bin.000048(根据自己的修改)',

      >MASTER_LOG_POS=(自己修改);

完成主从复制;

7、测试主从复制

在从服务器中执行

mysql > START SLAVE;      #开启复制mysql

      > SHOW  SLAVE  STATUS\G;  #查看主从复制是否成功
                数据库同步成功

当看到Slave_IO_Running: YES、Slave_SQL_Running:

YES才表明状态正常

8、实际测试:

登陆主服务器主MySQL:show database;

登陆从服务器MySQL:show databases;

主数据库进行如下操作:

(1)创建数据库和表

​create database test; use test;

create table tab1(id int auto_increment,name varchar(),primary key(id));

show databases;

show tables;

(2)从数据库也查看数据库和表,看数据是否同步了

9、出错请看

问题一:mysql服务器启动不了

出错:Starting MySQL... ERROR! The server quit without updating PID file

解决办法:找到mysql安装目录下面的data目录,删除mysql-relay-log.index

问题二:不能同步

进入slave服务器,运行:

mysql > show slave status\G;

        .......

解决办法一:

Slave_SQL_Running: No

1.程序可能在slave上进行了写操作

2.也可能是slave机器重起后,事务回滚造成的.

一般是事务回滚造成的:

解决办法二:

mysql > stop slave;

mysql > set GLOBAL SQL_SLAVE_SKIP_COUNTER=;

mysql > start slava;

注意:如果实在不行就在从服务器里边执行如下操作

mysql > stop slave; 

      >reset  slave;

      > 重新配置同步(见第六步)

      >start  slave;

至此数据库同步完成!

     当你发现自己的才华撑不起野心时,就请安静下来学习吧!

Linux两台服务器mysql数据库同步的更多相关文章

  1. linux下两台服务器文件实时同步方案设计和实现

    inux下两台服务器文件实时同步方案设计和实现 假设有如下需求: 假设两个服务器: 192.168.0.1 源服务器  有目录 /opt/test/ 192.168.0.2 目标服务器  有目录 /o ...

  2. mysql 忘记密码,赋予用户权限,两台服务器的数据库之间快速导入

    mysql 忘记密码: 1.首先service mysql stop mysqld --skip-grant-tables &  开启数据库 然后就可以mysql -uroot 直接进数据库, ...

  3. Centos 6.5 rsync+inotify 两台服务器文件实时同步

    rsync和inotify是什么我这里就不在介绍了,有专门的文章介绍这两个工具. 1.两台服务器IP地址分别为: 源服务器:192.168.1.2 目标服务器:192.168.1.3 @todo:从源 ...

  4. 【原】linux两台服务器之间免密登录方法

    搭建集群机器192.168.0.100和192.168.0.200里,需要两台机器中间相互拷贝文件: 方式一:下载192.168.0.100机器文件到本地,再将本地文件拷贝到B机器 方式二:192.1 ...

  5. Linux 两台服务器之间传输文件和文件夹

    今天处理一个项目要迁移的问题,突然发现这么多图片怎么移过去,可能第一时间想到的是先从这台服务器下载下来,然后再上传到另外一台服务器上面去,这个方法确实是可行,但是实在是太费时间了,今天我就教大家怎么快 ...

  6. linux下两台服务器文件实时同步方案实现-乾颐堂

    假设有如下需求: 假设两个服务器: 192.168.0.1 源服务器  有目录 /opt/test/ 192.168.0.2 目标服务器  有目录 /opt/bak/test/ 实现的目的就是保持这两 ...

  7. Linux 两台服务器之间传递文件

    参考: https://www.cnblogs.com/clovershell/p/9870603.html linux采用scp命令拷贝文件到本地,拷贝本地文件到远程服务器   // 假设远程服务器 ...

  8. linux两台服务器之间文件/文件夹拷贝

    跨服务器拷贝需要用到的命令是scp. ----------------------拷贝文件夹---------------------------------------------- 把当前文件夹t ...

  9. Linux 两台服务器之间传输文件

    一.scp命令的使用 1.传输文件(不包括目录) 命令格式:scp 源文件路径目录/需要传输的文件 目标主机的用户名@目标主机IP/主机别名:目标主机存储目录 举个例子:scp /root/ceshi ...

随机推荐

  1. isinstance方法判断可迭代和迭代器

    from collections import Iterable print(isinstance([],Iterable)) print(isinstance( {}, Iterable)) pri ...

  2. PHP cal_info() 函数

    ------------恢复内容开始------------ 实例 返回格利高里历法的信息: <?phpprint_r(cal_info(0));?> 运行实例 » 定义和用法 cal_i ...

  3. 谁来教我渗透测试——黑客必须掌握的Linux基础

    上一篇我们学习了Windows基础,今天我们来看一看作为一名渗透测试工程师都需要掌握哪些Linux知识.今天的笔记一共分为如下三个部分: Linux系统的介绍 Linux系统目录结构.常用命令 Lin ...

  4. win系统下git代码批量克隆,批量更新

    @REM 根据实际情况设置GIT路径及本地仓库地址 set path=%path%;"D:\Program Files\Git\cmd" set project_path=F:\g ...

  5. 基于asp.net core 从零搭建自己的业务框架(一)

    前言 asp.net core版本选择2.2,只是因为个人习惯了vs2017,代码以及设计皆可移植到vs2019,用asp.net core 3.0以及以上运行起来 项目类似选择web api,基础设 ...

  6. [Err] 126 - Incorrect key file for table '/tmp/#sql_1cdc_0.MYI'; try to repair it

    网上给出的原因倾向于MySQL的tmpdir的临时目录磁盘空间不足,如果检查确实时空间不足,请调整量tmpdir和slave_load_tmpdir,然后重启mysql服务.调整的方法是 locate ...

  7. 消息队列和事件循环(Event Loop)

    产生原因 为什么会有消息队列和事件循环呢?首先最关键的一点在于JS是个单线程,并且主线程非常繁忙,既要处理 DOM,又要计算样式,还要处理布局,同时还需要处理 JavaScript 任务以及各种输入事 ...

  8. 异步文件通道Java NIO你需要了解多少,来看看这篇文章

    在Java 7,AsynchronousFileChannel 被添加到了Java NIO中.使用AsynchronousFileChannel可以实现异步地读取和写入文件数据. 创建一个Asynch ...

  9. GhostNet:more features from cheap operation

  10. java从零到变身爬虫大神

    刚开始先从最简单的爬虫逻辑入手 爬虫最简单的解析面真的是这样 import org.jsoup.Jsoup; import org.jsoup.nodes.Document; import java. ...