你对MySQL BlackHole引擎有多少了解?
技术百科
藏色散人
发布时间:2021-09-11
浏览: 次 概念
像myisam、innodb,blackhole是另一种mysql引擎,从字面意思来看,
其表现就像一个黑洞,只进不出,进来就消失。换句话说,任何往其中写的数据都将丢失,有点像linux的/dev/null
比如一个表test的引擎是blackhole,任何对这个表的insert都将丢失,
对它的select永远返回空集,对应的数据目录下只有一个test.frm文件,且没有其他文件与之关联。
使用场景
一个并不保存任何数据的引擎,到底有什么意义?
关键在于,虽然其不保存数据,但对数据库的操作仍旧记录在binlog日志中。
这就带来一个好处
,可以将其作为主从复制的中介,将原来从主库中同步的操作变为从作为中介的BlackHole引擎数据库中同步。
1.作为伪主库分担主库负担
众所周知,当从库比较多的时候,所有从库都从主库load数据将加重主库的负担。但如果是从BlackHole的伪主库中同步就可以减轻主库的负担。原有主从架构大概就像下面这样:
现在,BlackHole伪主库作为中介,变成这样:
特别是,可以在伪主库中配置replicate-do和replicate-ignore规则,过滤不需要同步的表。
2.作为binlog日志收集器
其不保存实际数据,只记录binlog的特性,使得该引擎可用于binlog日志收集,便于数据库分析。
相关知识:binlog日志的format有三种:row,statement,mixed。
row的方式记录每一行被改变的记录,也就说,update将记录所有符合条件被修改的行,alter table更惨,相当于重建整个表,记录所有行的改变。所以这种格式下日志容易过大;
statement的方式只记录改变数据的SQL,没有row方式的问题,但其会记录该SQL执行的上下文信息,有个不好的地方是,该上下文信息在另一端重现的时候,容易因为较复杂的信息负责出错。
mixed的方式综合row和statement的方式。
配置
在伪库中,需要如下配置:
配置默认类型为BlackHole,可以用
default_table_type = BLACKHOLE
或是
default-storage-engine = BLACKHOLE
打开binlog:log-bin = ms-mysql-bin
特别要配置:log-slave-update = 1,只有这样,主库中的操作才会同步到BlackHole的binlog中,否则,只有直接针对BlackHole的操作才会记录到binlog。
忽略InnoDB:skip-innodb,当建表语句带有engine=innodb时,将使用默认的BlackHole引擎。
需要提醒的是,当采用这种架构时,数据同步多了中间一层,需要进一步考虑延迟问题。
推荐学习:《mysql视频教程》
# 的是
# 就像
# 有个
# 才会
# 不需要
# 不出
# 都将
# 库中
# linux
# default
# format
# 数据库
# 架构
# NULL
# select
# mysql
# sql
# table
# 不保存
# 空集
相关栏目:
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
AI推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
SEO优化<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
技术百科<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
谷歌推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
百度推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
网络营销<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
案例网站<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
精选文章<?muma echo $count; ?>
】
相关推荐
- Win11键盘快捷键大全_Windows 11常用
- C#怎么创建控制台应用 C# Console Ap
- Python解释执行模型_字节码流程说明【指导】
- Linux如何安装Golang环境_Linux下G
- Win11怎么关闭系统推荐内容_Windows11
- windows 10专注助手怎么关闭_window
- 如何在Golang中指定模块版本_使用go.mod
- c++怎么设置线程优先级与cpu亲和性_c++ 多
- 如何使用Golang操作指针变量_Golang解引
- Drupal 中 HTML 链接被双重转义导致渲染
- 如何在Golang中实现自定义Benchmark_
- Windows10系统怎么查看显卡型号_Win10
- 如何在 Go 中创建包含 map 的 slice(
- php订单日志怎么记录发货_php记录订单发货操作
- Win11如何设置电源计划_Win11电源计划优化
- C++中的Pimpl idiom是什么,有什么好处
- php订单日志权限怎么设_php订单日志文件权限设
- Windows蓝屏BAD_POOL_HEADER故
- c++ nullptr与NULL区别_c++11空
- 如何在网页无标准表格标签时高效提取结构化数据
- Win11怎么关闭右下角弹窗_Win11拦截系统通
- Python深度学习实战教程_神经网络模型构建与训
- Win11怎么压缩文件 Win11自带压缩解压功能
- Windows10系统怎么查看CPU温度_Win1
- Win11怎么设置按流量计费_Win11限制后台流
- php订单日志怎么导出excel_php导出订单日
- Win11怎么开启剪贴板历史记录_Windows1
- 如何使用Golang sort排序切片_Golan
- Django 测试数据库表缺失与字段未创建问题的完
- 电脑的“网络和共享中心”去哪了_Windows 1
- c++中的可变参数模板(variadic temp
- Windows系统被恶意软件破坏后的恢复策略_错误
- Win11怎样安装网易云音乐_Win11安装网易云
- c# 在高并发场景下,委托和接口调用的性能对比
- Mac怎么查看活动监视器_理解Mac进程和资源占用
- 一文详解网站被黑客入侵挂马解决办法
- Win11怎么设置DNS服务器_Windows11
- mac怎么安装adb_MAC配置Android A
- Mac如何修复应用程序权限问题_Mac磁盘工具修复
- 如何在 Python 测试中动态配置 @backo
- Win11截图快捷键是什么_Win11自带截图工具
- Win11怎么更改鼠标指针_Windows 11自
- 如何使用Golang defer优化性能_减少不必
- Win11如何设置ipv6 Win11开启IPv6
- Win11怎么设置鼠标宏_Win11鼠标按键自定义
- Mac如何设置动态壁纸?(让桌面动起来)
- Win11更新后变慢怎么办_Win11系统更新后卡
- Win10电脑C盘红了怎么清理_Windows10
- Win11怎样安装钉钉客户端_Win11安装钉钉教
- 如何使用Golang优化模块引入路径_Golang

QQ客服