- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我有一个基于 InnoDB 的模式,其中包含大约 100 个表,大多数使用 GUID/UUID 作为主键。我开始这个的时候我并没有真正理解 UUID PK 在磁盘 IO 和碎片方面的含义,但希望在处理服务器集群时避免使用单个 key 分配器的好处。我们目前没有处理大量的行,但我们会(数以亿计)并且我想为此做好准备。
现在我更好地理解了 InnoDB 中的索引,特别是主键的集群性质,我可以看到我的 UUID 从磁盘 IO 的角度来看是一个糟糕的可伸缩性选择,但我不想停止使用它们,因为满足服务器集群需求。
接受/推荐的解决方案似乎是自动增量 PK (INT|BIGINT) 与唯一索引 UUID 键的混合。我的目的是向每个表添加一个新的第一列 ai_col
并将其分配为新的 PK,我从以下位置获取队列:
http://dev.mysql.com/doc/refman/5.1/en/innodb-auto-increment-handling.html
然后我会在我的 UUID 键上更新/重新创建一个新的“UNIQUE”索引,并继续在我们的应用程序层中使用它们。
我的期望是,一旦完成,我基本上可以忽略 ai_col
,其他一切照常运行。 InnoDB 将有一个相对较小的基于 int 的 PK,从中聚集并附加到其他唯一索引。
问题 1:我假设在这个新场景中,我可以吃蛋糕,也可以吃蛋糕,这是否正确?
后续问题是关于较小的“关联”表,即只有两列,都是隐式连接它们的其他表的外键。在这些情况下,我通常有两个索引,一个是 UNIQUE 双列索引,首先是使用频率较高的列,然后是另一个列上的第二个单一索引。我知道这实际上是实际行数据的 2.5 倍,但它似乎确实有助于我们在优化期间进行更复杂的查询,并且在较小的表上因此相对可以接受。
这些关联表中的大多数只会是主表中记录数的一小部分,因为它们通常更具体,但是,在少数情况下,这些关联表的记录数是其外国父表的许多倍,即可能有数十亿。
问题 2:将数字 PK 也添加到这些表中是否是个好主意?我猜答案会类似于“Benchtest it”,但我只是在寻找有用的智慧。
如果我明显误解了任何内容,或者您可以提供我可能没有考虑的见解,我也将不胜感激!
非常感谢!
编辑:正如答案中所 promise 的,我只是想跟进任何感兴趣的人......这个解决方案非常有效:)读写性能全面提高,到目前为止它是经测试高达约 60 亿次输入/输出/月,毫不费力。
最佳答案
在没有任何其他建议、确认或其他方式的情况下,我已经开始在我们的开发服务器上测试一些较少使用的表,但如果新的基于 AI 的 id 将影响我们的应用程序,这些表仍然会受到影响层。
到目前为止它看起来不错,索引按预期执行并且新表字段不需要对我们的应用程序层进行任何更改,我们基本上可以忽略它们。
虽然我没有运行任何彻底的基准测试来测试重负载下的实际磁盘 IO,但从关于该主题的大量信息来看,我可以推测我们在扩展方面处于良好状态。
一旦这已经到位了一段时间,我将进行跟进,以防有人和我们在同一条船上。
关于mysql - 使用 GUID/UUID 键优化 Innodb 表索引,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13752799/
我试图再次将反射的 UUID 转换回实际的 UUID 对象,但找不到方法,当我打印反射值时它看起来是正确的,但在尝试转换时我找不到方法。 package main import ( "fmt"
我想知道 UUID 是否是唯一的,即使它们是在不同的系统上生成的,这些系统可能采用不同的算法。例如,如果您在 MySQL 和 .Net 中生成了一堆 UUID,碰撞的可能性会更高,还是所有系统都使用完
是否可以一个接一个地创建两个重复的 UUID?我不熟悉 UUID 是如何生成的,但我猜想如果您在同一毫秒内从同一 MAC 地址创建了两个单独的 UUID,那么它们将完全相同。这是真的吗? 我想我是在问
当我使用 python uuid 模块中的 UUID() 函数检查我们的测试 uuid 之一时,我遇到了这种奇怪的行为。 从 uuid 导入 UUID uuid1 = UUID('00000000-0
开始使用 java.util.UUID。我的问题是如果我有两个 UUID 变量,比如 u1 和 u2,并且我想检查它们是否相等,我可以安全地使用表达式 u1 == u2 还是必须编写 u1 .equa
我浏览了 python UUID 模块的文档。 >>> uuid.uuid4() UUID('82fe5629-6680-4b13-a4e3-7a082f10e038') >>> uuid.uuid4
我正在创建一个程序,我在其中大量使用 UUID 来识别用户和组等内容。鉴于 UUID 已经被占用的可能性极低,我是否应该担心发生碰撞的可能性? 最佳答案 这在很大程度上取决于 A)您的要求 B)底层实
您应该使用哪个版本的 UUID?我看到很多帖子解释了每个版本的含义,但我很难弄清楚什么最适合哪些应用程序。 最佳答案 有两种不同的方式生成 UUID。 如果您只需要一个唯一 ID,则需要版本 1 或版
我知道我们可以轻松提取 uuid 版本号。有没有可靠的方法来提取时间戳、MAC 地址等信息? 谢谢! 最佳答案 符合标准的 UUID 可能是多种变体之一,它看起来像这样: AAAAAAAA-BBBB-
我可以干净地使用私有(private) UUID 变体/版本吗? 我使用我基本上认为是大整数的随机 UUID。现在,我想生成一个“私有(private)”UUID,它不基于众所周知的 5 个变体/版本
我已阅读 man 页面,但我不明白 name 和 namespace 的用途。 For version 3 and version 5 UUIDs the additional command lin
我目前正在项目中使用 boost::uuids::uuid,并且我想序列化包含 boost::uuids::uuid 的对象。我尝试了下面的简单示例,但出现错误: /usr/include/boost
我正在使用 Datastax Java 驱动程序在 Cassandra 数据库中执行基本的插入语句。我的主键列是uuid类型。从我在官方文档中看到的,在 Cassandra 中调用 uuid() 函数
会抛出异常吗? UUID() 是否会悄无声息地失败?是否有任何情况下“myStatus”来自 myStatus = True myUUID = uuid.UUID( someWeirdValue )
在我的 Android 应用程序中,我有这种采用 UUID 的方法。不幸的是,当我这样做时: OverviewEvent overviewevent = eventAdapter.getOvervie
我有一个简单的 mongo 迁移框架,它正在执行一些传递给它的脚本。 现在我想将我的 LUUID 迁移到 UUID。我写了以下内容: function fixIds(collectionName) {
我有一个非常奇怪的问题是我得到一个有效的 UUID 不是一个有效的 UUID,例如: 'fd31b6b5-325d-4b65-b496-d7e4d16c8a93' is not a valid UUI
我正在测试 Goa对于一个 API。我想使用 uuid 作为 ID 数据类型。我在 controller.go 中修改了以下函数: // Show runs the show action. func
我有一个包含 uuid 和系统列的表。我需要一个查询来仅返回具有 system=1 的 uuid,而不返回具有 system= 1 和 2 的 uuid 最佳答案 SELECT * FROM
我很想了解在 Avro 中编码一种非常特定类型的数据的最佳实践:UUID。 最佳答案 到目前为止,我发现的唯一方法是定义自定义 UUID: { "namespace" : "your.namesp
我是一名优秀的程序员,十分优秀!