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 / 问题 / 42789
Accepted
holiveira
holiveira
Asked: 2009-07-20 17:46:44 +0800 CST2009-07-20 17:46:44 +0800 CST 2009-07-20 17:46:44 +0800 CST

如何增加 MySQL Server 中的内存使用量以提高速度?

  • 772

我有一个运行 IIS7 和 MySQL 的 8GB RAM 的 Windows 2008 服务器。我一直在跟踪服务器上的内存、cpu 和磁盘使用情况,我发现 MySQL 只使用了 250MB 的 RAM,使磁盘非常繁忙,尽管我周围有很多空闲的 ram。

在 SQL Server 中,我可以轻松设置我希望它使用的内存量,我正在 MySQL 中寻找相同的设置。

如何配置 MySQL 以使用更多内存并减少 cpu 和磁盘使用量?

windows-server-2008 mysql iis-7
  • 2 2 个回答
  • 135090 Views

2 个回答

  • Voted
  1. Best Answer
    James
    2009-07-20T18:12:27+08:002009-07-20T18:12:27+08:00

    table_cache是要更改的最有用的配置指令。MySQL 每次访问表时,都会将该表加载到缓存中。如果您有大量表,则将它们缓存起来会更快。

    通过运行查看您的服务器变量:

    show status;
    

    并查看变量open_tables。如果这与您的table_cache值相同,并且opened_tables一直在上升,那么您需要增加table_cache配置文件中的值。通过在高峰时段尝试这些变量,您会找到平衡点。opened_tables您希望对其进行配置,以便在高峰时间,即使在服务器已经运行很长时间之后,也有少量的。

    key_buffer_size也是一个很好的试验变量。这个变量会影响索引缓冲区的大小,使这个变量变大会提高 MySQL 的索引处理速度。show variables;您可以再次使用命令查看变量,并key_read_requests与key_reads. 理想情况下,您希望这两个变量之间的比率尽可能低,您可以通过增加key_buffer_size. 如果您将此变量设置得更高,您将减少直接对磁盘的写入和读取,这是您主要关心的问题。

    • 24
  2. staticsan
    2009-07-20T17:58:46+08:002009-07-20T17:58:46+08:00

    您需要更改my.cnf文件中的值并重新启动 MySQL,尽管您也可以在 MySQL 运行时更改其中的许多值('SET GLOBAL VARIABLE= value ')。

    如果您有任何 InnoDB 表,您可能会想要查看增加key_buffer_size的 、和。其中一些值可以增加很长一段路(甚至两个数量级),尤其是考虑到您的硬件。MySQL 的默认设置非常保守,似乎是针对大约十年前的常见混合用途桌面。哦,请注意,32 位版本在使用超过 2GB 的 RAM 时会遇到问题。sort_bufferread_buffertable_cacheinnodb_buffer_pool_size

    查看MySQL 手册以获取更多信息和指导。

    • 6

相关问题

  • 在 Linux Xen VPS 上优化 Apache 和 MySQL

  • 如何选择 MySQL 数据库引擎

  • 从 2003 年迁移到 2008 年 Microsoft 群集技术

  • 有什么理由使用 Windows Server 2003 而不是 Server 2008?

  • 是否可以在单个 W2008 服务器上安装 Exchange Server?

Sidebar

Stats

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

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

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

    • 9 个回答
  • Marko Smith

    Windows 中执行反向 DNS 查找的命令行实用程序是什么?

    • 14 个回答
  • Marko Smith

    如何检查 Windows 机器上的端口是否被阻塞?

    • 4 个回答
  • Marko Smith

    我应该打开哪个端口以允许远程桌面?

    • 9 个回答
  • Marko Smith

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

    • 3 个回答
  • Marko Smith

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

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    kch 如何更改我的私钥密码? 2009-08-06 21:37:57 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +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