Mysql二进制日志
简介Mysql二进制日志文件是非常重要,记录了所有对MySQL数据库的修改事件,包括增删改查事件和对表结构的修改事件,所以本文主要记录Mysql二进制文件如何开启和类型。
作用:记录了所有对MySQL数据库的修改事件,包括增删改查事件和对表结构的修改事件
二进制日志的开启
show variables like "%log_bin%";

如果没有开启,就去配置my.cnf,在[mysqld]下增加
log-bin = binlog
log-bin-index = binlog.index
格式:
binlog_format={STATEMENT|ROW|MIXED}
- 1、语句(statement):默认的记录格式,基于段
- 2、行(row):定义的并非数据本身而是这一行的数据是什么
- 3、混合模式(mixed):交替使用行和语句、由mysql服务器自行判断

二进制日志格式对复制的影响
基于SQL语句(statement)复制(SBR)
优点
- 1、生成的日志量少,节约网络传输IO
- 2、并不强制要求主从数据库的表定义完全相同
- 3、相比于基于行的复制方式更为灵活
缺点
- 1、对于非确定性事件,无法保证主从复制数据的一致性
- 2、对于存储过程,触发器,自定义函数进行的修改也可能造成数据不一致
- 3、相比于基于行的复制方式在从上执行时需要更多的行锁
基于行的复制(PBR)
优点
- 1、可以应用于任何SQL的复制包括非确定函数,存储过程等
- 2、可以减少数据库锁的使用
- 3、对主从数据的一致性更加有保证
缺点
- 1、要求主从数据库的表结构相同,否则可能会中断复制
- 2、无法在从上单独执行触发器
在使用Docker时,经常会犯一个错,误以为latest镜像会自己更像到最小版本,其实这样理解是有问题的,latest就是一个标签,没有自动更新到最新版本的功能,本文就是对latest标签进行介绍。
Uncaught TypeError: Cannot destructure property 'Menu' of 'remote' as it is undefined.
某些时候在寻找某个接口反映较慢的排除方法,除了从网络和服务器的硬件上面排除外,可能还需要我们通过PHP-FPM来排查问题。所以本文我们将说明如何通过PHP-FPM来查询慢日志,帮我们来排查相关问题。
在于前端攻城狮的兄弟们开发接口的时候,总会遇到一些奇怪的问题。比如IOS对某个字段要求要整数,如果PHP这边返回过去是字符串那么APP就会崩溃。虽然他们可以捕获异常,但是有些时候我们更想后端的攻城狮能否提供一种统一的数据类型,前端想怎么转换就是他们自己的事情,本文我们将给大家带来这方面的处理。
本文主要总结下在日常工作中使用Git命令的基本总结。
快速生成表格
在使用Git的过程中,不想每次都输入用户名和密码去拉取代码,所以就需要保存这些信息,那么既然有保存了,就必须有清除功能。
在Mac电脑中,如何对Git的用户名和密码进行修改呢?起初不懂Mac,所以整了很久,本文将记录如何对这个进行操作,以便后期使用。
Docker编译镜像出现:fetch http://dl-cdn.alpinelinux.org/alpine/v3.12/main/x86_64/APKINDEX.tar.gz
ERROR: http://dl-cdn.alpinelinux.org/alpine/v3.12/main: temporary error (try again later)
WARNING: Ignoring APKINDEX.2c4ac24e.tar.gz: No such file or directory问题