AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 1020811
Accepted
artfulrobot
artfulrobot
Asked: 2020-06-10 23:14:58 +0800 CST2020-06-10 23:14:58 +0800 CST 2020-06-10 23:14:58 +0800 CST

MariaDB 内存使用量超过配置大小

  • 772

我注意到我跟踪到 MariaDB 的系统内存使用百分比(由 sar 报告)稳步增加。这似乎与数据库负载无关:这种增加与查询数量的增加不匹配。

内存使用图

我有以下尺寸配置:

key_buffer_size         =  400000000                                                                                  
innodb_buffer_pool_size = 1210612736 

总共有 1.5GB,但现在在 RSS 内存上已达到 2.3GB。

为什么越来越贪心?我可以让它更好地坚持它的极限吗?或者它可能坚持 InnoDB 的限制,但正在将内存用于其他用途,如果是这样,有没有办法理解这一点,以便我可以调整配置以将总内存使用量保持在一定水平?或者它可能就像 Linux 内核一样,只是在空闲时使用所有空闲内存进行缓存,但在需要时很乐意放弃它?

我在 Debian 10 (Buster) 上使用 MariaDB 10.3.22。工作负载是一个网络服务器(所以我需要为其他进程保留一些内存:nginx+php)。如果需要,很高兴发布更多配置。

mysql memory-usage debian-buster mariadb
  • 4 4 个回答
  • 6078 Views

4 个回答

  • Voted
  1. artfulrobot
    2020-06-11T02:37:48+08:002020-06-11T02:37:48+08:00

    由于 Gordon 的回答和其中的链接,由于论坛的功劳,以下命令将告诉您 MySQL/MariaDB 数据库需要多少:

    SELECT ROUND(
        ( @@GLOBAL.key_buffer_size                     
         + @@GLOBAL.query_cache_size 
         + @@GLOBAL.tmp_table_size 
         + @@GLOBAL.innodb_buffer_pool_size 
         + @@GLOBAL.innodb_log_buffer_size 
         + @@GLOBAL.max_connections * ( 
             @@GLOBAL.sort_buffer_size
           + @@GLOBAL.read_buffer_size 
           + @@GLOBAL.read_rnd_buffer_size 
           + @@GLOBAL.join_buffer_size 
           + @@GLOBAL.thread_stack 
           + @@GLOBAL.binlog_cache_size)
        ) / 1024 / 1024, 1) `total MB`;
    

    (我是 OP,这提供了 2.9GB 作为我的总配置使用量 - 是时候降低一些数字了!)

    • 5
  2. Best Answer
    Gordan Bobić
    2020-06-11T00:46:19+08:002020-06-11T00:46:19+08:00

    您列出的内存设置是共享的。每个线程还分配了各种缓冲区。这是 MySQL 内存计算器的链接:

    https://www.mysqlcalculator.com/

    • 4
  3. iBug
    2020-06-11T09:05:09+08:002020-06-11T09:05:09+08:00

    如果您想限制 MariaDB 的整体内存使用量,假设您使用apt/安装它apt-get,您应该可以使用systemd.resource-control(5)来完成此操作。

    使用 root 调用:

    systemctl edit mariadb.service
    

    在显示的编辑器中输入以下配置,如果需要,可以进行调整:

    [Service]
    MemoryMax=1024M
    MemorySwapMax=128M
    

    保存并退出。它立即生效,并由 cgroup 内存控制器支持。

    • 1
  4. Rick James
    2020-06-11T13:29:12+08:002020-06-11T13:29:12+08:00

    让我们把它分开:

    ( @@GLOBAL.key_buffer_size              40M unless using MyISAM tables 
     + @@GLOBAL.query_cache_size            0 -- it is mostly useless, esp on production
     + @@GLOBAL.innodb_buffer_pool_size     1G if you have only 3G of ram
    
                   No more than 1% of RAM for these:
     + @@GLOBAL.tmp_table_size              -- belongs in the group below
     + @@GLOBAL.innodb_log_buffer_size 
         @@GLOBAL.sort_buffer_size
       + @@GLOBAL.read_buffer_size 
       + @@GLOBAL.read_rnd_buffer_size 
       + @@GLOBAL.join_buffer_size 
       + @@GLOBAL.thread_stack 
       + @@GLOBAL.binlog_cache_size)
    
     + @@GLOBAL.max_connections * (         100 is probably plenty
    

    没有“完美”的公式。mysqlcalculator 网站有很多缺陷。与任何其他声称有公式的网站一样。

    如果您使用的是 MyISAM(或 MyISAM 和 InnoDB 的混合物),请参阅http://mysql.rjweb.org/doc.php/memory

    • 1

相关问题

  • 开源与专有关系 db mgt 系统的优缺点是什么?

  • 在 solaris 10 上为 mysql 设置 max_allowed_pa​​cket

  • 如何移动 MySQL 的数据目录?

  • 通过 VPN 连接什么是远程服务器 IP?

  • mysql崩溃

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve