V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
WoodenTea
V2EX  ›  程序员

如何配置数据库连接池

  •  
  •   WoodenTea · 2022-11-02 23:06:33 +08:00 · 1267 次点击
    这是一个创建于 750 天前的主题,其中的信息可能已经有所发展或是发生改变。

    根据 HikariCP 文档 最优的数据库连接池的公式为 (core_count * 2) + effective_spindle_count

    我有两个疑问

    1. 这个公式是服务器上运行的数据库连接数量还是单个服务连接数据库的数量?

    2. 现在应用使用微服务方案,在访问量高的时候,服务会自动启动多个实例,那每个实例的连接池数量应该怎么设置?

    假设我的数据库运行在 4 核 2 个 SSD 的服务器上,按照公式最优的连接池数量是 4 * 2 + 2 = 10

    4 条回复    2022-11-03 15:51:53 +08:00
    hefish
        1
    hefish  
       2022-11-02 23:08:24 +08:00   ❤️ 2
    别拘泥于公式,主要看疗效。
    WoodenTea
        2
    WoodenTea  
    OP
       2022-11-02 23:13:27 +08:00
    @hefish 基础知识我还是要补上呀
    7911364440
        3
    7911364440  
       2022-11-03 10:47:18 +08:00   ❤️ 1
    CPU 密集型场景:核心数+1
    IO 密集型场景:核心数 * [1 + (IO 耗时 / CPU 耗时)]
    WoodenTea
        4
    WoodenTea  
    OP
       2022-11-03 15:51:53 +08:00
    @7911364440 是运行数据库服务器的的核心数嘛?不是运行服务的核心数嘛
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   4534 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 38ms · UTC 01:06 · PVG 09:06 · LAX 17:06 · JFK 20:06
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.