立即前往

活动

天翼云最新优惠活动,涵盖免费试用,产品折扣等,助您降本增效!
查看全部活动
热门活动
  • 智算采购季 热销S6云服务器2核4G限时88元/年起,部分主机可加赠对象存储组合包!
  • 免费体验DeepSeek,上天翼云息壤 NEW 新老用户均可免费体验2500万Tokens,限时两周
  • 云上钜惠 HOT 爆款云主机全场特惠,更有万元锦鲤券等你来领!
  • 算力套餐 HOT 让算力触手可及
  • 天翼云脑AOne NEW 连接、保护、办公,All-in-One!
  • 一键部署Llama3大模型学习机 0代码一键部署,预装最新主流大模型Llama3与StableDiffusion
  • 中小企业应用上云专场 产品组合下单即享折上9折起,助力企业快速上云
  • 息壤高校钜惠活动 NEW 天翼云息壤杯高校AI大赛,数款产品享受线上订购超值特惠
  • 天翼云电脑专场 HOT 移动办公新选择,爆款4核8G畅享1年3.5折起,快来抢购!
  • 天翼云奖励推广计划 加入成为云推官,推荐新用户注册下单得现金奖励
免费活动
  • 免费试用中心 HOT 多款云产品免费试用,快来开启云上之旅
  • 天翼云用户体验官 NEW 您的洞察,重塑科技边界

智算服务

打造统一的产品能力,实现算网调度、训练推理、技术架构、资源管理一体化智算服务
智算云(DeepSeek专区)
科研助手
  • 算力商城
  • 应用商城
  • 开发机
  • 并行计算
算力互联调度平台
  • 应用市场
  • 算力市场
  • 算力调度推荐
一站式智算服务平台
  • 模型广场
  • 体验中心
  • 服务接入
智算一体机
  • 智算一体机
大模型
  • DeepSeek-R1-昇腾版(671B)
  • DeepSeek-R1-英伟达版(671B)
  • DeepSeek-V3-昇腾版(671B)
  • DeepSeek-R1-Distill-Llama-70B
  • DeepSeek-R1-Distill-Qwen-32B
  • Qwen2-72B-Instruct
  • StableDiffusion-V2.1
  • TeleChat-12B

应用商城

天翼云精选行业优秀合作伙伴及千余款商品,提供一站式云上应用服务
进入甄选商城进入云市场创新解决方案
办公协同
  • WPS云文档
  • 安全邮箱
  • EMM手机管家
  • 智能商业平台
财务管理
  • 工资条
  • 税务风控云
企业应用
  • 翼信息化运维服务
  • 翼视频云归档解决方案
工业能源
  • 智慧工厂_生产流程管理解决方案
  • 智慧工地
建站工具
  • SSL证书
  • 新域名服务
网络工具
  • 翼云加速
灾备迁移
  • 云管家2.0
  • 翼备份
资源管理
  • 全栈混合云敏捷版(软件)
  • 全栈混合云敏捷版(一体机)
行业应用
  • 翼电子教室
  • 翼智慧显示一体化解决方案

合作伙伴

天翼云携手合作伙伴,共创云上生态,合作共赢
天翼云生态合作中心
  • 天翼云生态合作中心
天翼云渠道合作伙伴
  • 天翼云代理渠道合作伙伴
天翼云服务合作伙伴
  • 天翼云集成商交付能力认证
天翼云应用合作伙伴
  • 天翼云云市场合作伙伴
  • 天翼云甄选商城合作伙伴
天翼云技术合作伙伴
  • 天翼云OpenAPI中心
  • 天翼云EasyCoding平台
天翼云培训认证
  • 天翼云学堂
  • 天翼云市场商学院
天翼云合作计划
  • 云汇计划
天翼云东升计划
  • 适配中心
  • 东升计划
  • 适配互认证

开发者

开发者相关功能入口汇聚
技术社区
  • 专栏文章
  • 互动问答
  • 技术视频
资源与工具
  • OpenAPI中心
开放能力
  • EasyCoding敏捷开发平台
培训与认证
  • 天翼云学堂
  • 天翼云认证
魔乐社区
  • 魔乐社区

支持与服务

为您提供全方位支持与服务,全流程技术保障,助您轻松上云,安全无忧
文档与工具
  • 文档中心
  • 新手上云
  • 自助服务
  • OpenAPI中心
定价
  • 价格计算器
  • 定价策略
基础服务
  • 售前咨询
  • 在线支持
  • 在线支持
  • 工单服务
  • 建议与反馈
  • 用户体验官
  • 服务保障
  • 客户公告
  • 会员中心
增值服务
  • 红心服务
  • 客户支持计划
  • 专家技术服务
  • 备案管家

了解天翼云

天翼云秉承央企使命,致力于成为数字经济主力军,投身科技强国伟大事业,为用户提供安全、普惠云服务
品牌介绍
  • 关于天翼云
  • 智算云
  • 天翼云4.0
  • 新闻资讯
  • 天翼云APP
基础设施
  • 全球基础设施
  • 产品能力
  • 信任中心
最佳实践
  • 精选案例
  • 超级探访
  • 云杂志
  • 分析师和白皮书
  • 天翼云·创新直播间
市场活动
  • 2025智能云生态大会
  • 2024智算云生态大会
  • 2023云生态大会
  • 2022云生态大会
  • 天翼云中国行
天翼云
  • 活动
  • 智算服务
  • 产品
  • 解决方案
  • 应用商城
  • 合作伙伴
  • 开发者
  • 支持与服务
  • 了解天翼云
    • 关系数据库SQL Server版
    • 企业主机安全
    • 云防火墙
    • CDN加速
    • 物理机
    • GPU云主机
    • 天翼云电脑(政企版)
    • 天翼云电脑(公众版)
    • 云主机备份
    • 弹性云主机
      搜索发现
      关系数据库SQL Server版企业主机安全云防火墙CDN加速物理机GPU云主机天翼云电脑(政企版)天翼云电脑(公众版)云主机备份弹性云主机
    • 文档
    • 控制中心
    • 备案
    • 管理中心
    • 登录
    • 免费注册

    mysql/stonedb-物理存储层-数据间的关系

    首页 知识中心 存储 文章详情页

    mysql/stonedb-物理存储层-数据间的关系

    2023-04-23 09:38:11 阅读次数:134

    mysql,stonedb

    摘要:

    从物理层开始,解读引擎是如何封装列数据, 如何使用列数据, 以及与其他模块的关系

    数据目录:

    以lineitem表为例:

    [root@htap lineitem.tianmu]# tree
    .
    ├── columns
    │   ├── 0 -> /stonedb57/install/data/tianmu_data/16.0
    │   ├── 1 -> /stonedb57/install/data/tianmu_data/16.1
    │   ├── 10 -> /stonedb57/install/data/tianmu_data/16.10
    │   ├── 11 -> /stonedb57/install/data/tianmu_data/16.11
    │   ├── 12 -> /stonedb57/install/data/tianmu_data/16.12
    │   ├── 13 -> /stonedb57/install/data/tianmu_data/16.13
    │   ├── 14 -> /stonedb57/install/data/tianmu_data/16.14
    │   ├── 15 -> /stonedb57/install/data/tianmu_data/16.15
    │   ├── 2 -> /stonedb57/install/data/tianmu_data/16.2
    │   ├── 3 -> /stonedb57/install/data/tianmu_data/16.3
    │   ├── 4 -> /stonedb57/install/data/tianmu_data/16.4
    │   ├── 5 -> /stonedb57/install/data/tianmu_data/16.5
    │   ├── 6 -> /stonedb57/install/data/tianmu_data/16.6
    │   ├── 7 -> /stonedb57/install/data/tianmu_data/16.7
    │   ├── 8 -> /stonedb57/install/data/tianmu_data/16.8
    │   └── 9 -> /stonedb57/install/data/tianmu_data/16.9
    ├── TABLE_DESC
    ├── V.630c75a90000274c
    └── VERSION -> V.630c75a90000274c
    
    17 directories, 3 files

    说明:

    1. columns目录: 内部的文件夹名字为列的序号, 每一个列都是一个单独的存储
    2. TABLE_DESC文件: 表的描述信息, 主要包含表的存储引擎,及编码等相关属性
    3. VERSION: 表的最后一次的事务号, 指向V.xid

    columns目录:

    [root@htap columns]# ll
    total 0
    lrwxrwxrwx. 1 mysql mysql 40 Aug 29 16:16 0 -> /stonedb57/install/data/tianmu_data/16.0
    lrwxrwxrwx. 1 mysql mysql 40 Aug 29 16:16 1 -> /stonedb57/install/data/tianmu_data/16.1
    lrwxrwxrwx. 1 mysql mysql 41 Aug 29 16:16 10 -> /stonedb57/install/data/tianmu_data/16.10
    lrwxrwxrwx. 1 mysql mysql 41 Aug 29 16:16 11 -> /stonedb57/install/data/tianmu_data/16.11
    lrwxrwxrwx. 1 mysql mysql 41 Aug 29 16:16 12 -> /stonedb57/install/data/tianmu_data/16.12
    lrwxrwxrwx. 1 mysql mysql 41 Aug 29 16:16 13 -> /stonedb57/install/data/tianmu_data/16.13
    lrwxrwxrwx. 1 mysql mysql 41 Aug 29 16:16 14 -> /stonedb57/install/data/tianmu_data/16.14
    lrwxrwxrwx. 1 mysql mysql 41 Aug 29 16:16 15 -> /stonedb57/install/data/tianmu_data/16.15
    lrwxrwxrwx. 1 mysql mysql 40 Aug 29 16:16 2 -> /stonedb57/install/data/tianmu_data/16.2
    lrwxrwxrwx. 1 mysql mysql 40 Aug 29 16:16 3 -> /stonedb57/install/data/tianmu_data/16.3
    lrwxrwxrwx. 1 mysql mysql 40 Aug 29 16:16 4 -> /stonedb57/install/data/tianmu_data/16.4
    lrwxrwxrwx. 1 mysql mysql 40 Aug 29 16:16 5 -> /stonedb57/install/data/tianmu_data/16.5
    lrwxrwxrwx. 1 mysql mysql 40 Aug 29 16:16 6 -> /stonedb57/install/data/tianmu_data/16.6
    lrwxrwxrwx. 1 mysql mysql 40 Aug 29 16:16 7 -> /stonedb57/install/data/tianmu_data/16.7
    lrwxrwxrwx. 1 mysql mysql 40 Aug 29 16:16 8 -> /stonedb57/install/data/tianmu_data/16.8
    lrwxrwxrwx. 1 mysql mysql 40 Aug 29 16:16 9 -> /stonedb57/install/data/tianmu_data/16.9

    说明:

    1. 内部的软连接名字为列的序号
    2. 软连接文件指向该列真实的目录

    可以对比表结构中的列字段:

    mysql> desc lineitem;
    +-----------------+---------------+------+-----+---------+-------+
    | Field           | Type          | Null | Key | Default | Extra |
    +-----------------+---------------+------+-----+---------+-------+
    | l_orderkey      | int(11)       | NO   | PRI | NULL    |       |
    | l_partkey       | int(11)       | NO   |     | NULL    |       |
    | l_suppkey       | int(11)       | NO   |     | NULL    |       |
    | l_linenumber    | int(11)       | NO   | PRI | NULL    |       |
    | l_quantity      | decimal(15,2) | NO   |     | NULL    |       |
    | l_extendedprice | decimal(15,2) | NO   |     | NULL    |       |
    | l_discount      | decimal(15,2) | NO   |     | NULL    |       |
    | l_tax           | decimal(15,2) | NO   |     | NULL    |       |
    | l_returnflag    | char(1)       | NO   |     | NULL    |       |
    | l_linestatus    | char(1)       | NO   |     | NULL    |       |
    | l_shipdate      | date          | NO   |     | NULL    |       |
    | l_commitdate    | date          | NO   |     | NULL    |       |
    | l_receiptdate   | date          | NO   |     | NULL    |       |
    | l_shipinstruct  | char(25)      | NO   |     | NULL    |       |
    | l_shipmode      | char(10)      | NO   |     | NULL    |       |
    | l_comment       | varchar(44)   | NO   |     | NULL    |       |
    +-----------------+---------------+------+-----+---------+-------+
    16 rows in set (0.05 sec)

    具体列目录:

    以第0列为例:

    2022-09-05 mysql/stonedb-物理存储层-数据间的关系

    [root@htap 0]# tree
    .
    ├── DATA
    ├── DN
    ├── filters
    │   ├── bloom
    │   ├── cmap
    │   └── hist
    ├── META
    └── v
        └── 630c75a90000274c
    
    5 directories, 4 files

    说明:

     

    MVCC多版本控制:

    2022-09-05 mysql/stonedb-物理存储层-数据间的关系

    2022-09-05 mysql/stonedb-物理存储层-数据间的关系

     

    2022-09-05 mysql/stonedb-物理存储层-数据间的关系

     

    读取列的逻辑:

    类结构关系:

    2022-09-05 mysql/stonedb-物理存储层-数据间的关系

    创建列数据时的时序关系:

    2022-09-05 mysql/stonedb-物理存储层-数据间的关系

    数据关系-DPN与PACK:

    2022-09-05 mysql/stonedb-物理存储层-数据间的关系

    数据关系-VER事务版本与DPN的关系:

    2022-09-05 mysql/stonedb-物理存储层-数据间的关系

    核心数据结构:

    DPN

    // Data Pack Node. Same layout on disk and in memory
    struct DPN final {
     public:
      uint8_t used : 1;    // occupied or not
      uint8_t local : 1;   // owned by a write transaction, thus to-be-commit
      uint8_t synced : 1;  // if the pack data in memory is up to date with the
                           // version on disk
      uint8_t null_compressed : 1;
      uint8_t data_compressed : 1;
      uint8_t no_compress : 1;
      uint8_t padding[3];
      uint32_t base;       // index of the DPN from which we copied, used by local pack
      uint64_t addr;       // data start address
      uint64_t len;        // data length
      uint32_t nr;         // number of records
      uint32_t nn;         // number of nulls
      common::TX_ID xmin;  // creation trx id
      common::TX_ID xmax;  // delete trx id
      union {
        int64_t min_i;
        double min_d;
        char min_s[8];
      };
      union {
        int64_t max_i;
        double max_d;
        char max_s[8];
      };
      union {
        int64_t sum_i;
        double sum_d;
        uint64_t maxlen;
      };
    
     private:
      // a tagged pointer, 16 bits as ref count.
      // Only read-only dpn uses it for ref counting; local dpn is managed only by
      // one write session
      std::atomic_ulong tagged_ptr;

    COL_META

    struct COL_META {
      uint32_t magic;
      uint32_t ver;         // file version
      uint8_t pss;          // pack size shift
      common::CT type;      // type
      common::PackFmt fmt;  // data format: LZ4, snappy, lookup, raw, etc
      uint8_t flag;
      uint32_t precision;
      uint32_t scale;
    };

    COL_VER_HDR_V3

    struct alignas(128) COL_VER_HDR_V3 {
      uint64_t nr;  // no. of records
      uint64_t nn;  // no. of nulls
      uint64_t np;  // no. of packs
      uint64_t auto_inc_next;
      int64_t min;
      int64_t max;
      uint32_t dict_ver;  // dict file version name. 0 means n/a
      uint32_t unique : 1;
      uint32_t unique_updated : 1;
      uint64_t natural_size;
      uint64_t compressed_size;
    };

     

    版权声明:本文内容来自第三方投稿或授权转载,原文地址:https://blog.51cto.com/adofsauron/5668067,作者:帝尊悟世,版权归原作者所有。本网站转在其作品的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如因作品内容、版权等问题需要同本网站联系,请发邮件至ctyunbbs@chinatelecom.cn沟通。

    上一篇:2022-09-09 mysql列存储引擎-POC-需求分析-第二版-有问题的SQL

    下一篇:恢复误删除的ESXi服务器存储VMFS卷

    相关文章

    2025-04-11 07:15:54

    java使用JDBC方式操作mysql数据库示例

    java使用JDBC方式操作mysql数据库示例

    2025-04-11 07:15:54
    java , JDBC , mysql , 数据库 , 示例
    2025-04-09 09:17:07

    mysql Commands out of sync; you can‘t run this command now

    mysql Commands out of sync; you can‘t run this command now

    2025-04-09 09:17:07
    mysql , query , 执行
    2025-03-31 08:57:16

    PDO ping 的实例 ,解决mysql has gone的问题

    PDO ping 的实例 ,解决mysql has gone的问题

    2025-03-31 08:57:16
    mysql
    2025-03-27 09:41:58

    写在前面【mysql高级】【java提高】

    写在前面【mysql高级】【java提高】

    2025-03-27 09:41:58
    mysql , MySQL , 备份 , 数据库 , 日志 , 索引
    2025-03-26 09:08:50

    navicat导入excel文件的步骤以及可能碰到的问题

    navicat导入excel文件的步骤以及可能碰到的问题

    2025-03-26 09:08:50
    excel , mysql , navicat , 导入 , 数据
    2025-03-24 08:52:40

    解决 MySQL 服务无法启动:failed to restart mysql.service: unit not found

    解决 MySQL 服务无法启动:failed to restart mysql.service: unit not found

    2025-03-24 08:52:40
    mysql , MySQL , service , 文件 , 服务
    2025-03-18 08:27:03

    简单按日期查询mysql某张表中的记录数

    简单按日期查询mysql某张表中的记录数

    2025-03-18 08:27:03
    count , mysql
    2025-03-17 08:48:47

    【判断数据库在线】shell 判断数据库在线

    【判断数据库在线】shell 判断数据库在线

    2025-03-17 08:48:47
    client , localhost , mysql , MySQL , root
    2025-03-17 07:58:55

    MySQL之delete 忘加where条件误删除恢复方法二

    MySQL之delete 忘加where条件误删除恢复方法二

    2025-03-17 07:58:55
    delete , mysql , 恢复 , 语句
    2025-03-17 07:50:46

    mysql模拟生成10万条数据存储过程sql

    mysql模拟生成10万条数据存储过程sql

    2025-03-17 07:50:46
    mysql , sql , 创建 , 存储
    查看更多
    推荐标签

    作者介绍

    天翼云小翼
    天翼云用户

    文章

    32777

    阅读量

    4865433

    查看更多

    最新文章

    【mySQL】提升mysql性能的关键参数之innodb_buffer_pool_size、innodb_buffer_pool_instances

    2025-02-21 08:57:32

    MySQL——基础

    2025-02-10 08:56:25

    Redis7 数据双写一致性

    2024-10-23 08:55:37

    mysql列存储引擎-tianmu_ini_allowmysqlquerypath参数开启后的异常记录

    2024-09-25 10:15:01

    mysql列存储引擎-去除TempTableForSubquery引发的memcopy的策略

    2024-09-25 10:14:48

    mysql列存储引擎-POC-调用自定义函数-参数赋值

    2024-09-25 10:13:57

    查看更多

    热门文章

    mysql列存储引擎-POC-需求分析

    2023-05-09 06:03:25

    mysql存储引擎、数据导入导出、多表查询

    2023-04-23 09:34:48

    MySQL技术内幕 InnoDB存储引擎:B+树索引

    2023-05-10 06:03:26

    mysql表类型和存储引擎和视图

    2023-06-06 05:57:53

    mysql列存储引擎-POC-问题定位-索引相关

    2023-06-13 08:35:51

    2022-09-09 mysql列存储引擎-POC-需求分析-第二版-有问题的SQL

    2023-04-23 09:35:19

    查看更多

    热门标签

    存储 缓存 内存 数据库 数据 redis mysql 服务器 数据恢复 Redis linux java sql MySQL 数据结构
    查看更多

    相关产品

    弹性云主机

    随时自助获取、弹性伸缩的云服务器资源

    天翼云电脑(公众版)

    便捷、安全、高效的云电脑服务

    对象存储

    高品质、低成本的云上存储服务

    云硬盘

    为云上计算资源提供持久性块存储

    查看更多

    随机文章

    mysql列存储引擎-exists结果错误-问题分析

    NIFI综合应用场景-将mysql查询出的json数据转换成txt后存储至HDFS中

    mysql列存储引擎-去除TempTableForSubquery引发的memcopy的策略

    2022-09-09 mysql列存储引擎-POC-需求分析-第二版-有问题的SQL

    MySql 学习笔记三:常用SQL优化

    【mySQL】提升mysql性能的关键参数之innodb_buffer_pool_size、innodb_buffer_pool_instances

    • 7*24小时售后
    • 无忧退款
    • 免费备案
    • 专家服务
    售前咨询热线
    400-810-9889转1
    关注天翼云
    • 权益商城
    • 天翼云APP
    • 天翼云微信公众号
    服务与支持
    • 备案中心
    • 售前咨询
    • 智能客服
    • 自助服务
    • 工单管理
    • 客户公告
    • 涉诈举报
    账户管理
    • 管理中心
    • 订单管理
    • 余额管理
    • 发票管理
    • 充值汇款
    • 续费管理
    快速入口
    • 权益商城
    • 文档中心
    • 最新活动
    • 免费试用
    • 信任中心
    • 天翼云学堂
    云网生态
    • 甄选商城
    • 渠道合作
    • 云市场合作
    了解天翼云
    • 关于天翼云
    • 天翼云APP
    • 服务案例
    • 新闻资讯
    • 联系我们
    热门产品
    • 云电脑
    • 弹性云主机
    • 云电脑政企版
    • 天翼云手机
    • 云数据库
    • 对象存储
    • 云硬盘
    • Web应用防火墙
    • 服务器安全卫士
    • CDN加速
    热门推荐
    • 云服务备份
    • 边缘安全加速平台
    • 全站加速
    • 安全加速
    • 云服务器
    • 云主机
    • 智能边缘云
    • 应用编排服务
    • 微服务引擎
    • 共享流量包
    更多推荐
    • web应用防火墙
    • 密钥管理
    • 等保咨询
    • 安全专区
    • 应用运维管理
    • 云日志服务
    • 文档数据库服务
    • 云搜索服务
    • 数据湖探索
    • 数据仓库服务
    友情链接
    • 中国电信集团
    • 189邮箱
    • 天翼企业云盘
    • 天翼云盘
    ©2025 天翼云科技有限公司版权所有 增值电信业务经营许可证A2.B1.B2-20090001
    公司地址:北京市东城区青龙胡同甲1号、3号2幢2层205-32室
    • 用户协议
    • 隐私政策
    • 个人信息保护
    • 法律声明
    备案 京公网安备11010802043424号 京ICP备 2021034386号