TABLE 生成器是个糟糕的选择
现在,在我开始解释如何配置 pooled 或 pooled-lo 优化器之前,您应该知道 TABLE 生成器是一个糟糕的选择,因为它不仅速度慢了 10 倍,而且会阻塞您的数据库连接池,因为它需要额外的连接来获取标识符。
更多,因为它使用行级锁来分配下一个标识符,这可能会导致您的应用程序出现瓶颈。有关TABLE 生成器的危险的更多详细信息。
基于序列的优化器
从 Hibernate 5 开始,只要将 JPA @SequenceGenerator 注释的 allocationSize 属性设置为大于 1 的值,就会使用 pooled 优化器。
对于 Hibernate 4 或 3,要使用 pooled 或 pooled-lo 优化器,您必须启用以下 Hibernate 属性:
<property name="hibernate.id.new_generator_mappings" value="true"/>
值得注意的是,pooled 和 pooled-lo 优化器仅适用于 SEQUENCE 和 TABLE 生成器,因为这些优化器的目标是减少获取下一个实体标识符所需的数据库往返次数。
池化优化器
pooled 优化器非常容易设置。您需要做的就是设置JPA @SequenceGenerator 注释的allocationSize,Hibernate 将切换到使用pooled 优化器:
@Id
@GeneratedValue(
strategy = GenerationType.SEQUENCE,
generator = "post_sequence"
)
@SequenceGenerator(
name = "post_sequence",
sequenceName = "post_sequence",
allocationSize = 3
)
private Long id;
由于此映射更直接,如果您还提供此 Hibernate 配置属性,则可以切换到 pooled-lo 而不是 pooled:
<property name="hibernate.id.optimizer.pooled.preferred" value="pooled-lo" />
Pooled-lo 优化器
要使用 pooled-lo 优化器,实体标识符映射如下所示:
@Id
@GeneratedValue(
strategy = GenerationType.SEQUENCE,
generator = "pooled-lo"
)
@GenericGenerator(
name = "pooled-lo",
strategy = "sequence",
parameters = {
@Parameter(
name = "sequence_name",
value = "post_sequence"
),
@Parameter(
name = "initial_value",
value = "1"
),
@Parameter(
name = "increment_size",
value = "3"
),
@Parameter(
name = "optimizer",
value = "pooled-lo"
)
}
)
要了解 pooled-lo 的工作原理,请查看此图:
如果您一直在使用旧版 hilo 优化器,您可能希望改用 pooled 或 pooled-lo,因为 hilo 无法与可能不知道 hilo 的其他客户端互操作标识符分配策略。