MySQL 学习笔记 (一)
1.InnoDB and Online DDL
ALTER TABLE tbl_name ADD PRIMARY KEY (column), ALGORITHM=INPLACE, LOCK=NONE;
https://dev.mysql.com/doc/refman/8.0/en/innodb-online-ddl.html
2.TRUNCATE TABLE后可用空间的使用
在innodb_file_per_table=on的条件下,可用空间释放给了操作系统。而在innodb_file_per_table=OFF(system tablespace)或( general tablespaces)情况下,空间可以从新利用,没有物理释放。
https://dev.mysql.com/doc/refman/8.0/en/innodb-truncate-table-reclaim-space.html
3.复制状态查看
* 从库查看slave_master_info表:select * from mysql.slave_master_info;
* 从库查看slave_relay_log_info表:select * from mysql.slave_relay_log_info;
* 从库查看slave_worker_info表:select * from mysql.slave_worker_info;
* 从库查看replication_applier_status_by_worker表:select * from performance_schema.replication_applier_status_by_worker;
* 从库查看replication_connection_status表:select * from performance_schema.replication_connection_status;
4.GTID Sets
来源于同一个Master Server的的GTID,可以构成一个集合:
3E11FA47-71CA-11E1-9E33-C80AA9429562:-
The above example represents the first through fifth transactions originating on the MySQL server whose server_uuid
is 3E11FA47-71CA-11E1-9E33-C80AA9429562
. Multiple single GTIDs or ranges of GTIDs originating from the same server can also be included in a single expression, with the GTIDs or ranges separated by colons, as in the following example:
3E11FA47-71CA-11E1-9E33-C80AA9429562:-::-
A GTID set can include any combination of single GTIDs and ranges of GTIDs, and it can include GTIDs originating from different servers. This example shows the GTID set stored in the gtid_executed
system variable (@@GLOBAL.gtid_executed
) of a slave that has applied transactions from more than one master:
2174B383--11E8-B90A-C80AA9429562:-, 24DA167-0C0C-11E8--00059A3C7B00:-
5.gtid_executed
table
GTIDs are stored in the mysql.gtid_executed
table only when gtid_mode
is ON
or ON_PERMISSIVE
. Note that the mysql.gtid_executed
table is cleared if you issue RESET MASTER
.
Compression of the mysql.gtid_executed
table is performed by a dedicated foreground thread namedthread/sql/compress_gtid_table
.
SELECT * FROM performance_schema.threads WHERE NAME LIKE '%gtid%'\G
6.关于GTID复制模式的关联报错
If any of the transactions that should be sent by the master have been purged from the master's binary log, or added to the set of GTIDs in the gtid_purged
system variable by another method, the master sends the errorER_MASTER_HAS_PURGED_REQUIRED_GTIDS to the slave, and replication does not start. The GTIDs of the missing purged transactions are identified and listed in the master's error log in the warning message ER_FOUND_MISSING_GTIDS.
Attempting to reconnect without the MASTER_AUTO_POSITION
option enabled only results in the loss of the purged transactions on the slave. The correct approach to recover from this situation is for the slave to replicate the missing transactions listed in the ER_FOUND_MISSING_GTIDS message from another source, or for the slave to be replaced by a new slave created from a more recent backup. Consider revising the binary log expiration period (binlog_expire_logs_seconds
) on the master to ensure that the situation does not occur again.
If during the exchange of transactions it is found that the slave has received or committed transactions with the master's UUID in the GTID, but the master itself does not have a record of them, the master sends the errorER_SLAVE_HAS_MORE_GTIDS_THAN_MASTER to the slave and replication does not start. This situation can occur if a master that does not have sync_binlog=1
set experiences a power failure or operating system crash, and loses committed transactions that have not yet been synchronized to the binary log file, but have been received by the slave.
https://dev.mysql.com/doc/refman/8.0/en/replication-gtids-auto-positioning.html
7.复制的权限设置
Most of the steps that follow require the use of the MySQL root
account or another MySQL user account that has theSUPER
privilege. mysqladmin shutdown
requires either the SUPER
privilege or the SHUTDOWN
privilege.
8.将MySQL 设置为read_only
Make the servers read-only by setting the read_only
system variable to ON
on each server by issuing the following:
mysql> SET @@GLOBAL.read_only = ON;
这个命令的重要作用是:
Wait for all ongoing transactions to commit or roll back. Then, allow the slave to catch up with the master. It is extremely important that you make sure the slave has processed all updates before continuing.
9.shut down the MySQL
shell> mysqladmin -uusername -p shutdown
Then supply this user's password at the prompt.
https://dev.mysql.com/doc/refman/8.0/en/replication-gtids-howto.html
https://www.cnblogs.com/dadonggg/p/8625500.html
10.如何跳过一个GTID
基于GTID的复制,跳过一个事务,需要利用一个空事务来完成。
stop slave; SET GTID_NEXT='aaa-bbb-ccc-ddd:N'; BEGIN;
COMMIT; SET GTID_NEXT='AUTOMATIC'; start slave;
https://dev.mysql.com/doc/refman/8.0/en/replication-gtids-failover.html
11.多源复制
In a multi-source replication topology, a slave creates a replication channel for each master that it should receive transactions from.
The error codes and messages that are issued when multi-source replication is enabled specify the channel that generated the error.
https://dev.mysql.com/doc/refman/8.0/en/replication-multi-source.html
12.显示创建表的scripts
show create table student;
13 shell 操作mysql
关于salve节点的重新执行SQL的线程
mysql -e 'STOP SLAVE SQL_THREAD;'
14.mysqldump
Run mysqldump to dump your databases. You may either dump all databases or select databases to be dumped. For example, to dump all databases:
mysqldump --all-databases > fulldb.dump
备份数据库结构,不备份数据
格式:mysqldump -h主机名 -P端口 -u用户名 -p密码 --no-data 数据库名1 数据库名2 数据库名3 > 文件名.sql
mysqldump --no-data –databases db1 db2 cmdb > /data/backup/structure.sql
https://dev.mysql.com/doc/refman/8.0/en/replication-solutions-backups-mysqldump.html
https://baijiahao.baidu.com/s?id=1612955427840289665&wfr=spider&for=pc
15.基于既有表创建一个新表
- create table as 只是复制原数据,其实就是把查询的结果建一个表
- create table like 产生与源表相同的表结构,包括索引和主键,数据需要用insert into 语句复制进去。例如:
create table newtest like test;
insert into newtest select * from test;
16.MHA FailOver
MHA 在线切换过程
https://blog.csdn.net/leshami/article/details/45189825
MHA 手动故障转移
https://blog.csdn.net/leshami/article/details/45219821
17.GTID模式下配置主从
change master to master_host='172.XXX.XXX.XXX',master_port=????,master_user='XXXX',master_password='XXXXXX',master_auto_position=1;
start slave;
18.手动启动MHA Manager
nohup /usr/local/bin/masterha_manager --conf=/etc/mha/app1.cnf --remove_dead_master_conf --ignore_last_failover < /dev/null > /data/log/mha/manager.log >& &
19.查看某数据库下所有表的具体信息(information_schema.TABLES)
SELECT * FROM information_schema.TABLES WHERE TABLE_SCHEMA = 'XXXXdb';
例如查看数据库中以winxin开头的各表的数据量
SELECT table_name,table_rows FROM information_schema.tables WHERE TABLE_name like 'winxin%' ORDER BY table_rows DESC;
20.生成批量修改表的SQL语句
例如:生成清空分库分表中的ABC开头某类表
SELECT CONCAT( 'truncate table ', table_name, ';' )
FROM information_schema.tables
WHERE table_name LIKE 'ABC_%' and table_name not LIKE 'terminal_user_%' ;
如果还要加上库名,例如删除某类表
SELECT CONCAT('drop table QQ_weixin_co.', table_name, ';')
FROM information_schema.tables
WHERE table_schema = 'QQ_weixin_co' AND table_name LIKE 'ABC_%'
21 Truncate 命令在 binlog中的记录形式
TRUNCATE TABLE
is treated for purposes of binary logging and replication as DROP TABLE
followed by CREATE TABLE
—that is, as DDL rather than DML. This is due to the fact that, when using InnoDB
and other transactional storage engines where the transaction isolation level does not permit statement-based logging (READ COMMITTED
or READ UNCOMMITTED
), the statement was not logged and replicated when using STATEMENT
or MIXED
logging mode. (Bug #36763) However, it is still applied on replication slaves using InnoDB
in the manner described previously.
--https://dev.mysql.com/doc/refman/8.0/en/truncate-table.html
--个人学习笔记系列,可能比较粗糙,观者见谅。
MySQL 学习笔记 (一)的更多相关文章
- Mysql学习笔记(三)对表数据的增删改查。
正文内容. 这一部分是最简单的,也是最麻烦的.简单是因为其实只包括增删该插四个部分.大体上看,增加数据.删除数据.修改数据.查询数据都不麻烦啊,我们日常都是常用的.这个谁不会呢?以前在培训机构学mys ...
- MySQL学习笔记一
MySQL 学习笔记 一 一.数据库简单介绍 1. 按照数据库的发展时间顺序,主要出现了以下类型数据库系统: Ø 网状型数据库 Ø 层次型数据库 Ø 关系型数据库 Ø 面向对象数据库 上面4中数据库系 ...
- Mysql学习笔记(二)数据类型 补充
原文:Mysql学习笔记(二)数据类型 补充 PS:简单的补充一下数据类型里的String类型以及列类型... 学习内容: 1.String类型 2.列类型存储需求 String类型: i.char与 ...
- Mysql学习笔记(一)数据类型
原文:Mysql学习笔记(一)数据类型 学习内容: Mysql基本数据类型. 1.数字类型.. i.整型 Mysql数据类型 含义(有符号) tinyint(m ...
- 初识mysql学习笔记
使用VMVirtualBox导入Ubuntu后,可以通过sudo apt-get install mysql-server命令下载mysql. 在学习过程中,我遇到了连接不上Xshell的问题.最终在 ...
- MySQL学习笔记-锁相关话题
在事务相关话题中,已经提到事务隔离性依靠锁机制实现的.在本篇中围绕着InnoDB与MyISAM锁机制的不同展开,进而描述锁的实现方式,多种锁的概念,以及死锁产生的原因. Mysql常用存储引擎的锁 ...
- MySQL学习笔记-事务相关话题
事务机制 事务(Transaction)是数据库区别于文件系统的重要特性之一.事务会把数据库从一种一致状态转换为另一个种一致状态.在数据库提交工作时,可以确保其要么所有修改都已经保存了,要么所有修改都 ...
- MySQL学习笔记-数据库文件
数据库文件 MySQL主要文件类型有如下几种 参数文件:my.cnf--MySQL实例启动的时候在哪里可以找到数据库文件,并且指定某些初始化参数,这些参数定义了某种内存结构的大小等设置,还介绍了参数类 ...
- MySQL学习笔记-数据库内存
数据库内存 InnoDB存储引擎内存由以下几个部分组成:缓冲池(buffer pool).重做日志缓冲池(redo log buffer)以及额外的内存池(additional memory pool ...
- MySQL学习笔记-数据库后台线程
数据库后台线程 默认情况下讲述的InnoDB存储引擎,以后不再重复声明.后台线程有7个--4个IO thread,1个master thread,1个锁监控线程,1个错误监控线程.IO thread的 ...
随机推荐
- 对于在Dao层,一个DML操作一个事务,升级到Service层,一个用户,一个事务
原先的连接Connection,只能是来一次,新创建一个连接connection.这样如果事务在Dao层已经默认提交,在service层出错时,对于俩张关联会有俩种不同的结果.为了解决这样的问题,我们 ...
- (全国多校重现赛一)F-Senior Pan
Senior Pan fails in his discrete math exam again. So he asks Master ZKC to give him graph theory pro ...
- ARTS-S 获取子线程返回值注意事项
#include <stdio.h> #include <stdlib.h> #include <pthread.h> #include <unistd.h& ...
- NETCore Bootstrap Admin 通用后台管理权限 [3]: 精简版任务调度模块
前言 NETCore 里说到任务调度,大家首先想到的应该是大名鼎鼎的 QuartzNET 与 Hangfire,然而本篇介绍的却都不是,而是 Bootstrap Admin(以下简称 BA)通用后台权 ...
- 记录一次VMware与xshell远程链接的总结
VMware 与xshell链接 说在前面 用了一年多的virtualbox,虚拟机环境的配置算是理清了,可最近参加红帽培训,大家用的都是VMware,想想我也试试吧,刚好再熟悉一下,于是就捣鼓了很久 ...
- python学习-logging
"""#设置输出的日志内容格式fmt = '%(asctime)s %(filename)s %(funcName)s [line:%(lineno)d] %(level ...
- Python 分析电影《南方车站的聚会》
<南方车站的聚会>由刁亦男执导,主要演员包括:胡歌.桂纶镁.廖凡.万茜等,该片于 2019 年 5 月 18 在戛纳电影节首映,2019 年 12 月 6 日在中国正式上映.故事灵感来自真 ...
- Java语法进阶10-泛型
泛型 泛型:参数化的类型,即把数据类型当做参数来传递 有的地方又称为泛化的类型,用一个单个大写字母,例如<T>来代表任意类型,这个T就是泛化的类型. 泛型的好处: (1)表示某个变量的类型 ...
- python 正则表达式re使用模块(match()、search()和compile())
摘录 python核心编程 python的re模块允许多线程共享一个已编译的正则表达式对象,也支持命名子组.下表是常见的正则表达式属性: 函数/方法 描述 仅仅是re模块函数 compile(patt ...
- Python面向对象-@property装饰器
python中,我们可以直接添加和修改属性的值: >>> class Student(object): ... pass ... >>> s = Student() ...