一气之下,我抢过面试官电脑花10分钟搭建了MySQL主从架构,面试官蒙了

  • 四. 配置从服务器

    • 1) 在/etc/my.cnf 中修改或者增加以下内容:
  • 2) 重启从服务器的MySQL

  • 3) 配置同步

  • 4) 启动同步

  • 5) 查看slave确保两个值都为yes

  • 五. 验证主从复制结果:

    • 1) 在主服务器上创建数据库
  • 2) 查看主从服务器的数据库是否同步

  • 后续

面试官给下了死命令:三台服务器,搭建一个MySQL主从架构,能不能搞定?

我一看距离下一家面试还有20分钟。

行,10分钟给你搞定,并写好文档。

一. 系统实验环境


[root@itlaoxin162 ~]# uname -r

3.10.0-1062.12.1.el7.x86_64

内核是3.10.0

[root@itlaoxin162 ~]# cat /etc/redhat-release

CentOS Linux release 7.7.1908 (Core)

系统版本是centos 7.7

master: 192.168.1.162

slave1; 192.168.1.163

slave2: 192.168.1.71

二. 安装MySQL5.7


1)下载MySQL 源

[root@itlaoxin162 ~]# wget https://dev.mysql.com/get/mysql57-community-release-el7-9.noarch.rpm

2)repo的安装

[root@itlaoxin162 ~]# rpm -ivh mysql57-community-release-el7-9.noarch.rpm

警告:mysql57-community-release-el7-9.noarch.rpm: 头V3 DSA/SHA1 Signature, 密钥 ID 5072e1f5: NOKEY

准备中… ################################# [100%]

正在升级/安装…

1:mysql57-community-release-el7-9 ################################# [100%]

删除旧的MySQL

[root@itlaoxin162 ~]# rpm -qa |grep mysql

php-mysql-5.4.16-48.el7.x86_64

mysql57-community-release-el7-9.noarch

[root@itlaoxin162 ~]# rpm -e php-mysql-5.4.16-48.el7.x86_64

3)开始安装MySQL

[root@itlaoxin162 ~]# yum -y install mysql-community-server

在这里插入图片描述

4)启动MySQL

[root@itlaoxin162 ~]# systemctl start mysqld.service

[root@itlaoxin162 ~]# systemctl status mysqld.service

在这里插入图片描述

5) 查看版本:

[root@itlaoxin162 ~]# mysql -V

mysql Ver 14.14 Distrib 5.7.34, for Linux (x86_64) using EditLine wrapper

6) 设置新密码:

MySQL

[root@itlaoxin162 ~]# mysql

Welcome to the MySQL monitor. Commands end with ; or \g.

Your MySQL connection id is 5

Server version: 5.7.34 MySQL Community Server (GPL)

Copyright © 2000, 2021, Oracle and/or its affiliates.

修改密码为ITlaoxin123

mysql> alter user ‘root’@‘localhost’ identified by ‘ITlaoxin123’ ;

Query OK, 0 rows affected (0.01 sec)

此时在192.168.1.162服务器上安装MySQL5.7 就算完成了。

同样的,我们我们需要在从服务器192.168.1.63 和192.168.1.71上安装数据库。

安装数据库的方式和master一样,此处省略,请参考master的数据库安装方法。

三台MySQL搭建好之后,需要把时间同步开启,防火墙关闭:

7) 同步主服务器:

关闭防火墙和selinux

[root@itlaoxin-163 ~]# setenforce 0

[root@itlaoxin-163 ~]# systemctl stop firewalld

同步服务器:

[root@itlaoxin-163 ~]# /usr/sbin/ntpdate 192.168.1.162

25 Apr 18:50:18 ntpdate[75307]: no server suitable for synchronization found

[root@itlaoxin-163 ~]#

三. 配置MySQL master主服务器


1.) 在/etc/my.cnf 中修改或者增加以下内容

[root@itlaoxin162 ~]# tail -n 3 /etc/my.cnf

server-id = 11

log-bin=master-bin

log-slave-updates=true

[root@itlaoxin162 ~]#

2) 重启MySQL服务

[root@itlaoxin162 ~]# systemctl restart mysqld

3) 登录MySQL程序,给服务器授权

给服务器授权

mysql> grant replication slave on . to ‘myslave’@‘192.168.1.%’ identified by ‘ZMedu123456’;

Query OK, 0 rows affected, 1 warning (0.01 sec)

刷新

mysql> flush privileges;

Query OK, 0 rows affected (0.01 sec)

查看主服务器的状态:

mysql> show master status;

±------------------±---------±-------------±-----------------±------------------+

| File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |

±------------------±---------±-------------±-----------------±------------------+

| master-bin.000001 | 602 | | | |

±------------------±---------±-------------±-----------------±------------------+

1 row in set (0.00 sec)

file列显示的日志名,position 列显示偏移量

四. 配置从服务器


1) 在/etc/my.cnf 中修改或者增加以下内容:

[root@itlaoxin-163 ~]# tail -n 3 /etc/my.cnf

server-id = 22 ## 这里的ID不能与主服务器相同

relay-log=relay-log-bin ## 从主服务器上同步日志到本地

relay-log-index=slave-relay-bin.index ## 定义relay-log的位置和名称

[root@itlaoxin-163 ~]#

2) 重启从服务器的MySQL

登陆MySQL

[root@itlaoxin-163 ~]# mysql -uroot -p

Enter password:

3) 配置同步

根据主服务器的结果来更改下面的master_log_file 和master_log_post 的参数

mysql> change master to master_host=‘192.168.1.162’,master_user=‘myslave’,master_password=‘ZMedu123456’,master_log_file=‘master-bin.000001’,master_log_pos=602;

Query OK, 0 rows affected, 2 warnings (0.02 sec)

4) 启动同步

mysql> start slave;

Query OK, 0 rows affected (0.35 sec)

mysql>

5) 查看slave确保两个值都为yes

mysql> show slave status \G

*************************** 1. row ***************************

Slave_IO_State: Waiting for master to send event
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

分享

首先分享一份学习大纲,内容较多,涵盖了互联网行业所有的流行以及核心技术,以截图形式分享:

(亿级流量性能调优实战+一线大厂分布式实战+架构师筑基必备技能+设计思想开源框架解读+性能直线提升架构技术+高效存储让项目性能起飞+分布式扩展到微服务架构…实在是太多了)

其次分享一些技术知识,以截图形式分享一部分:

Tomcat架构解析:

算法训练+高分宝典:

Spring Cloud+Docker微服务实战:

最后分享一波面试资料:

切莫死记硬背,小心面试官直接让你出门右拐

1000道互联网Java面试题:

Java高级架构面试知识整理:

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
扩展到微服务架构…实在是太多了)

其次分享一些技术知识,以截图形式分享一部分:

Tomcat架构解析:

[外链图片转存中…(img-U0syToiG-1713436742535)]

算法训练+高分宝典:

[外链图片转存中…(img-Ma7DjHQn-1713436742535)]

Spring Cloud+Docker微服务实战:

[外链图片转存中…(img-oO1t7Acb-1713436742535)]

最后分享一波面试资料:

切莫死记硬背,小心面试官直接让你出门右拐

1000道互联网Java面试题:

[外链图片转存中…(img-cKBYtkSv-1713436742535)]

Java高级架构面试知识整理:

[外链图片转存中…(img-z3UlhDm8-1713436742535)]

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值