- GreatSQL社区原创内容未经受权不得随便应用,转载请分割小编并注明起源。
- GreatSQL是MySQL的国产分支版本,应用上与MySQL统一。
- 作者: 叶金荣
- 文章起源:GreatSQL社区原创
1. MySQL 8.0数据字典有什么变动
从MySQL 8.0开始,采纳独立表空间模式的每个InnoDB表只有一个 .ibd 表空间文件,而不再有 .frm 文件了。为了实现DDL的原子性,InnoDB间接把元数据存储在表空间文件中,需要的话,可是应用 ibd2sdi
工具从中读取,例如:
$ ibd2sdi test/t1.sdi["ibd2sdi",{ "type": 1, "id": 1268, "object": { "mysqld_version_id": 80031, "dd_version": 80023, "sdi_version": 80019, "dd_object_type": "Table",...{ "type": 2, "id": 29, "object": { "mysqld_version_id": 80031, "dd_version": 80023, "sdi_version": 80019, "dd_object_type": "Tablespace", "dd_object": { "name": "test/t1", "comment": "", "options": "autoextend_size=0;encryption=N;", "se_private_data": "flags=16417;id=24;server_version=80031;space_version=1;state=normal;", "engine": "InnoDB", "engine_attribute": "", "files": [ { "ordinal_position": 1, "filename": "./test/t1.ibd", "se_private_data": "id=24;" } ] }}}]
如果是MyISAM引擎表,也不再有 .frm文件,而是采纳 .sdi 文件来记录元数据信息。
在 .sdi 文件中,采纳JSON格局存储元数据信息。
对于MyISAM表,不能再像以前那样,间接把 .frm.MYD.MYI 文件拷贝到指标数据库后就能间接用。办法改成了相似上面这样的:
# 首先拷贝数据及索引文件到指标数据库$ cp -p ./db1/t1.MYD ./db1/t1.MYI ./db2# 拷贝 .sdi 文件到 secure_file_priv 指定的门路下$ cp -p ./db1/t1_1274.sdi $secure_file_priv/# 批改 .sdi 文件中的 schema 值,将 db1 改成 db2# MySQL文档中没提到这点,但实测过程中发现须要加这步操作$ vim $secure_file_priv/t1_1274.sdi..."schema_ref":"db1" #此处批改成 "schema_ref":"db2"...# 执行导入操作mysql> IMPORT TABLE FROM '$secure_file_priv/t1_1274.sdi';
上文中的 $secure_file_priv 须要自行替换成理论门路。
另外,.sdi 文件名后面的数字,是该表的暗藏ID,每次新建一个表,这个值都会程序减少,相似 InnoDB 表的 TABLE_ID 值(这里说的是相似,二者不等价)。
2. 怎么查看每个/某个session里设置的variables
查看 performance_schema.variables_by_thread
即可
select * from variables_by_thread where VARIABLE_NAME = 'sort_buffer_size';+-----------+------------------+----------------+| THREAD_ID | VARIABLE_NAME | VARIABLE_VALUE |+-----------+------------------+----------------+| 29310 | sort_buffer_size | 4194304 || 29375 | sort_buffer_size | 4194304 || 29378 | sort_buffer_size | 32768 | -- 在这个session里批改成其余非默认设置值| 29209 | sort_buffer_size | 4194304 |+-----------+------------------+----------------+
再依据 THREAD_ID
列和 performance_schema.threads
关联查问,即可晓得每个/某个session里的variables是否有自定义设置了。
3. mysqlpump备份并不好用
用mysqlpump备份时,默认是不会备份用户受权信息的,须要相似这样 mysqlpump --exclude-databases=% --users
独自指定选项能力额定备份用户受权信息。
Enjoy GreatSQL :)
## 对于 GreatSQL
GreatSQL是由万里数据库保护的MySQL分支,专一于晋升MGR可靠性及性能,反对InnoDB并行查问个性,是实用于金融级利用的MySQL分支版本。
相干链接: GreatSQL社区 Gitee GitHub Bilibili
GreatSQL社区:
社区博客有奖征稿详情:https://greatsql.cn/thread-100-1-1.html
技术交换群:
微信:扫码增加GreatSQL社区助手
微信好友,发送验证信息加群
。