2024年Java最全MYSQL主从同步详细教程,面试官让我回家等通知

最后

针对最近很多人都在面试,我这边也整理了相当多的面试专题资料,也有其他大厂的面经。希望可以帮助到大家。

image

上述的面试题答案都整理成文档笔记。 也还整理了一些面试资料&最新2021收集的一些大厂的面试真题(都整理成文档,小部分截图)

image

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

MYSQL主从搭建


1、实验环境

| 数据库角色 | IP | 系统版本 | mysql版本 | 数据 |

| :-: | :-: | :-: | :-: | :-: |

| Master | 192.168.10.11 | CentOS 7.4 | 5.7.30 | 有数据 |

| Slave | 192.168.10.12 | CentOS 7.4 | 5.7.30 | 无数据 |

2、两台主机安装相同的mysql

搭建教程

3、配置主从数据库

  • master 库配置

  • 开启日志(server-id=1,log-bin=xx)

[root@localhost ~]# cat /etc/my.cnf

[mysqld]

basedir = /usr/local/mysql

datadir = /data/mysql

socket = /tmp/mysql.sock

port = 3306

pid-file = /data/mysql/mysql.pid

user = mysql

skip-name-resolve

server-id=1

log-bin=hebao_log.bin

[root@localhost ~]#

  • 创建授权用户,授权( grant replication slave on *.* to 'liuaoni'@'%' identified by '123456')

[root@localhost ~]# mysql -uroot -proot

mysql: [Warning] Using a password on the command line interface can be insecure.

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

Your MySQL connection id is 2

Server version: 5.7.30-log MySQL Community Server (GPL)

Copyright © 2000, 2020, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its

affiliates. Other names may be trademarks of their respective

owners.

Type ‘help;’ or ‘\h’ for help. Type ‘\c’ to clear the current input statement.

mysql> grant replication slave on . to ‘liuaoni’@‘%’ identified by ‘123456’;

Query OK, 0 rows affected, 1 warning (0.01 sec) replication 复制权限

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 |

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

| hebao_log.000001 | 592 | | | |

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

1 row in set (0.00 sec)

mysql>

  • Slave 数据库配置

mysql> change master to master_host=‘192.168.10.11’,master_user=‘liuaoni’,master_password=‘123456’,master_log_file=‘hebao_log.000001’,master_log_pos=592;

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

mysql> start slave;

Query OK, 0 rows affected (0.01 sec)

mysql> show slave status\G;

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

Slave_IO_State: Waiting for master to send event

Master_Host: 192.168.10.11

Master_User: liuaoni

Master_Port: 3306

Connect_Retry: 60

Master_Log_File: xx_log.000004

Read_Master_Log_Pos: 836

Relay_Log_File: localhost-relay-bin.000004

Relay_Log_Pos: 317

Relay_Master_Log_File: xx_log.000004

Slave_IO_Running: Yes

Slave_SQL_Running: Yes

Replicate_Do_DB:

Replicate_Ignore_DB:

Replicate_Do_Table:

Replicate_Ignore_Table:

看到 Slave_IO_Running: Yes

Slave_SQL_Running: Yes 都为yes就好

  • 测试:

主上创建数据库:

mysql> create database Master_db;

Query OK, 1 row affected (0.14 sec)

mysql>

从上查看:

mysql> show databases;

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

| Database |

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

| information_schema |

| Master_db |

| mysql |

| mysql_back |

| performance_schema |

| sys |

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

6 rows in set (0.00 sec)

mysql常用配置文件参数:

| 参数 | 说明 |

| :-: | :-- |

| port = 3306 | 设置监听端口 |

| socket = /tmp/mysql.sock | 指定套接字文件位置 |

| basedir = /usr/local/mysql | 指定MySQL的安装路径 |

| datadir = /data/mysql | 指定MySQL的数据存放路径 |

| pid-file = /data/mysql/mysql.pid | 指定进程ID文件存放路径 |

| user = mysql | 指定MySQL以什么用户的身份提供服务 |

| skip-name-resolve | 禁止MySQL对外部连接进行DNS解析 使用这一选项可以消除MySQL进行DNS解析的时间。 若开启该选项,则所有远程主机连接授权都要使用IP地址方 式否则MySQL将无法正常处理连接请求 |

MYSQL 备份与恢复


  • 数据库备份方案

  • 全量备份:某一个时间点上的所有数据或应用进行一个完全的拷贝,备份时间长,数据恢复快

  • 增量备份:是指在一次完全备份或上一次增量备份后,以后每次的备份只需备份与前一次相比增加 或者被修改的文件。没有重复数据备份时间短恢复数据必须按一定的顺序进行

  • 差异备份:备份上一次的完全备份后发生变化的所有文件。差异备份是指 在一次全备份后进行差异备份的这段时间内那些以增加或者修改文件的备份。在恢复时,只需要对第一次全量备份最后一次差异备份进行恢复

  • MYSQL 备份工具mysqldump

语法:

mysqldump [OPTIONS] database [tables …]

mysqldump [OPTIONS] --all-databases [OPTIONS]

mysqldump [OPTIONS] --databases [OPTIONS] DB1 [DB2 DB3…]

常用的OPTIONS:

-uUSERNAME 指定数据库用户名

-hHOST 指定服务器主机,请使用ip地址

-pPASSWORD 指定数据库用户的密码

-P# 指定数据库监听的端口,这里的#需用实际的端口号代替,如-P3307

  • 备份整个数据库(全备)

分享

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

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

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

Tomcat架构解析:

算法训练+高分宝典:

Spring Cloud+Docker微服务实战:

最后分享一波面试资料:

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

1000道互联网Java面试题:

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

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

[外链图片转存中…(img-6Sb6NQh0-1714866961276)]

最后分享一波面试资料:

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

1000道互联网Java面试题:

[外链图片转存中…(img-Yv6TUFEy-1714866961277)]

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

[外链图片转存中…(img-vGzIKyFM-1714866961277)]

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

  • 26
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值