第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定

萬(wàn)答#7,如何批量刪數(shù)據(jù)和調(diào)整系統(tǒng)表空間

標(biāo)簽:
MySQL

前情提要:

业务需要删除大量数据,如果直接 delete 会造成如下问题:

1.会产生大事务,造成主从延迟,影响数据库高可用切换。
2.系统表空间会不断膨胀。
3.锁定的记录多,更容易可能导致锁等待。
问1:如何优雅的删除大量数据

答:

1.如果表不需要就直接 drop

2.如果只保留表结构用 truncate

3.如果只保留部分数据可以使用 pt-archive 进行分批删除

特别注意,如果表太大的话,直接drop会truncate可能会造成大量IO导致数据库出现短暂响应延迟,可以通过硬链接的方式对表删除处理

问2:系统表空间不断膨胀怎么处理
答:

1.如果是已存在的数据库 无法在线收缩,那就通过mysqldump的方式建立新的从库,然后主从切换

2.新实例如何处理

  • a. 可以设置独立表空间,关键参数
innodb_file_per_table

独立表空间也会产生碎片,但是可以通过 OPTIMIZE TABLE 或 ALTER TABLE xxxx ENGINE=INNODB 进行碎片回收,5.7之后该操作属online ddl,具体可以自行测试

  • b. 设置独立UNDO空间,然后设置自动回收。

5.6 版本就支持独立UNDO空间,但是不支持在线回收,关键参数

innodb_undo_directory
innodb_undo_tablespaces
innodb_undo_logs

5.7 版本增加了在线回收的功能,关键参数

innodb_undo_log_truncate
innodb_max_undo_log_size
innodb_purge_rseg_truncate_frequency

8.0 版本中undo log的管理更加灵活,主要如下改进

  • 1.可以动态创建或删除UNDO表空间
  • 2.可以动态增加或减少UNDO表空间的数量
  • 3.无论是否要进行InnoDB恢复,也可以在启动前更改相关设置

问:ibtmp文件不断增大,怎么处理

答:

5.7 版本可以设置限制ibtmp大小,但是需要重启实例;同时超过设定的最大值会导致SQL执行失败,关键参数

innodb_temp_data_file_path = ibtmp1:12M:autoextend:max:5G

8.0 版本临时表空间有区分全局和session级;垃圾SQL生成的临时表空间随着SQL的结束也会跟着自动释放。

Enjoy GreatSQL :)

點(diǎn)擊查看更多內(nèi)容
1人點(diǎn)贊

若覺(jué)得本文不錯(cuò),就分享一下吧!

評(píng)論

作者其他優(yōu)質(zhì)文章

正在加載中
數(shù)據(jù)庫(kù)工程師
手記
粉絲
6
獲贊與收藏
66

關(guān)注作者,訂閱最新文章

閱讀免費(fèi)教程

感謝您的支持,我會(huì)繼續(xù)努力的~
掃碼打賞,你說(shuō)多少就多少
贊賞金額會(huì)直接到老師賬戶
支付方式
打開(kāi)微信掃一掃,即可進(jìn)行掃碼打賞哦
今天注冊(cè)有機(jī)會(huì)得

100積分直接送

付費(fèi)專欄免費(fèi)學(xué)

大額優(yōu)惠券免費(fèi)領(lǐng)

立即參與 放棄機(jī)會(huì)
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)

舉報(bào)

0/150
提交
取消