Atomic
数据库引擎是新版本支持的默认库引擎,支持非阻塞DROP TABLE
和RENAME TABLE
查询以及原子的EXCHANGE TABLES t1 AND t2
。这几种操作官网描述的很清晰,详见:Atomic。下面主要介绍一下该引擎的一些细节步骤。
创建表步骤
- 为新表生成UUID
- 将创建表的SQL中的CREATE改写为ATTACH,并存入
/metadata/database/table.sql
,table.sql中不再存储表名而是用UUID代替,例如:ATTACH TABLE _ UUID 'xxxyyyyy-yyyy-yyyy-yyyy-yyyyyyyyyyyy' (......)
- 为表创建目录(
/store/xxx/xxxyyyyy-yyyy-yyyy-yyyy-yyyyyyyyyyyy/
)用于数据存储,其中xxx
是UUID的前三位,该目录将不再存在数据库名和表名 - 创建符号链接(
/data/database/table
)指向实际表目录(/store/xxx/xxxyyyyy-yyyy-yyyy-yyyy-yyyyyyyyyyyy/
); - 在内存中增加db的引用计数,即表明该db下实时存在那些表
删除表步骤
- 直接删除符号链接(
/data/database/table
) - 将
/metadata/table.sql
文件移至/metadata_dropped/
下,并改名为default.table.xxxyyyyy-yyyy-yyyy-yyyy-yyyyyyyyyyyy.sql
- 在内存中减掉该表的引用计数
重命名表步骤
- 重命名符号链接(
/data/database/table
)和元数据文件(/metadata/table.sql
) - 在内存中修改该表的表名,并在修改的过程中有锁保证原子性
补充
- 由于
table.sql
中不再存在表名,表名由.sql文件的名字决定 - 表数据可以延迟删除
- 不同数据库的表数据都存在store目录下,便于跨库的表移动