mysql优化配置参数

mysql安装好需要优化配置一下,打开c:\windows\my.ini文件

第一种
代码如下:
#This File was made using the WinMySQLAdmin 1.4 Tool
#2004-2-23 16:28:14
#Uncomment or Add only the keys that you know how works.
#Read the MySQL Manual for instructions
[mysqld]
basedir=D:/mysql
#bind-address=210.5.*.*
datadir=D:/mysql/data
#language=D:/mysql/share/your language directory
#slow query log#=
#tmpdir#=
#port=3306
set-variable = max_connections=1500
skip-locking
#skip-networking
set-variable = key_buffer=384M
set-variable = max_allowed_packet=1M
set-variable = table_cache=512
set-variable = sort_buffer=2M
set-variable = record_buffer=2M
set-variable = thread_cache=8
# Try number of CPU’s*2 for thread_concurrency
set-variable = thread_concurrency=8
set-variable = myisam_sort_buffer_size=64M
#set-variable = connect_timeout=5
#set-variable = wait_timeout=5
server-id = 1
[isamchk]
set-variable = key_buffer=128M
set-variable = sort_buffer=128M
set-variable = read_buffer=2M
set-variable = write_buffer=2M
[myisamchk]
set-variable = key_buffer=128M
set-variable = sort_buffer=128M
set-variable = read_buffer=2M
set-variable = write_buffer=2M
[WinMySQLadmin]
Server=D:/mysql/bin/mysqld-nt.exe

这个方案,整体够用了,但是在pconnect和最大连接数上,需要研究max_connections没必要那么大,我个人认为几百就够,否则给服务器加大了不少负担,经常会当机连接超时的设置也要根据实际情况调整,大家可以自由调整,然后观察效果如何。
第二种
  7、MYSQL 的优化(/etc/my.cnf)
1)确认在“[mysqld]”部分加入了“skip-innodb”和“skip-bdb”参数;
2)确认在“[mysqld]”部分加入了“skip-name-resolve”和“skip-locking”参数;
3)如果不需要的话,可以将二进制日志(binlog)停掉,方法是将“log-bin”注释掉;
4)在内存允许的情况下,对一些参数进行重新配置,目标在于将大部分操作集中于内存中,尽量不进行磁盘操作,对于我的 MYSQL 服务器我是如下修改的,基于 2G 内存情况:
代码如下:
[mysqld]
set-variable = key_buffer=512M
set-variable = max_allowed_packet=4M
set-variable = table_cache=1024
set-variable = thread_cache=64
set-variable = join_buffer_size=32M
set-variable = sort_buffer=32M
set-variable = record_buffer=32M
set-variable = max_connections=512
set-variable = wait_timeout=120
set-variable = interactive_timeout=120
set-variable = max_connect_errors=30000
set-variable = long_query_time=1
set-variable = max_heap_table_size=256M
set-variable = tmp_table_size=128M
set-variable = thread_concurrency=8
set-variable = myisam_sort_buffer_size=128M

你可以根据“show status”命令返回的状态进行微调。我主要注意以下变量的数值,越小越好,最好为零:)
Created_tmp_disk_tables
Created_tmp_tables
Created_tmp_files
Slow_queries
另外 mysql wait_timeout 那个值设置大了没用 做10左右就可了 (大C说得)
wait_timeout是使用长久连线时 空闲进程的控制只要数据库在连接状态 他是不进行干预的 不管是否有查询或更新操作把这个设置小一点 再使用pconnect就比较理想了 ;)
timeout的時間﹐我的經驗值是5-20﹐看你的SERVER的訪問量了~~ (梦飞说的)
访问量越大 这个值就应该越小否则留出的空闲进程太多 会占用不必要的内存
在一个15分钟在线3000人的论坛上 设置为3比较合适同时打开pconnect
第三种
数据库连接过多的错误,可能的原因分析及解决办法
分析
系统不能连接数据库,关键要看两个数据:
1、数据库系统允许的最大可连接数max_connections。这个参数是可以设置的。如果不设置,默认是100。最大是16384。
2、数据库当前的连接线程数threads_connected。这是动态变化的。
查看max_connections、max_connections的办法见后。
如果 threads_connected == max_connections 时,数据库系统就不能提供更多的连接数了,这时,如果程序还想新建连接线程,数据库系统就会拒绝,如果程序没做太多的错误处理,就会出现类似强坛的报错信息。
因为创建和销毁数据库的连接,都会消耗系统的资源。而且为了避免在同一时间同时打开过多的连接线程,现在编程一般都使用所谓数据库连接池技术。
但数据库连接池技术,并不能避免程序错误导致连接资源消耗殆尽。
这种情况通常发生在程序未能及时释放数据库连接资源或其他原因造成数据库连接资源不能释放,但强坛系统估计不会发生这种低级的编程错误。
该错误的简便的检查办法是,在刷新强坛页面时,不断监视threads_connected的变化。如果max_connections足够大,而threads_connected值不断增加以至达到max_connections,那么,就应该检查程序了。当然,如果采用数据库连接池技术,threads_connected增长到数据库连接池的最大连接线程数时,就不再增长了。
从强坛出错的情况看,更大的可能性是数据库系统没能进行适当地配置。下面提出一点建议。供参考
让你们的工程师把MySQL的最大允许连接数从默认的100调成32000。这就不会老出现连接过多的问题了。

查看max_connections
进入MySQL,用命令:show variables
查看数据库最大可连接数的变量值:max_connections

查看threads_connected
进入MySQL,用命令:show status
查看当前活动的连接线程变量值:threads_connected

设置max_connections
设置办法是在my.cnf文件中,添加下面的最后红色的一行:
——————————————————————————–
代码如下:
[mysqld]
port=3306
#socket=MySQL
skip-locking
set-variable = key_buffer=16K
set-variable = max_allowed_packet=1M
set-variable = thread_stack=64K
set-variable = table_cache=4
set-variable = sort_buffer=64K
set-variable = net_buffer_length=2K
set-variable = max_connections=32000

——————————————————————————–
修改完毕后,重启MySQL即可。当然,为了确保设置正确,应该查看一下max_connections。
注意:
1、虽然这里写的32000。但实际MySQL服务器允许的最大连接数16384;
2、除max_connections外,上述其他配置应该根据你们系统自身需要进行配置,不必拘泥;
3、添加了最大允许连接数,对系统消耗增加不大。
4、如果你的mysql用的是my.ini作配置文件,设置类似,但设置的格式要稍作变通。
可见,mysql的优化,是多样化,且根据环境不同,必须灵活调整的,大家不可生搬硬套,自己慢慢体会吧

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/445104.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月7日 20:25:40
下一篇 2025年11月7日 20:27:11

相关推荐

  • Linux Helix模式加速,CSS规则HTML一键重构!

    启用Helix性能加速模式,配置LSP支持HTML与CSS智能重构,并通过Shell脚本调用Prettier和postcss-cli实现一键格式化与重构,提升Web开发效率。 如果您在使用Linux系统进行Web开发时,希望提升Helix编辑器的性能并实现CSS规则与HTML结构的一键重构,可以通过…

    2025年12月23日
    000
  • 分析HTTP状态码异常的原因

    HTTP状态码是在进行网络通信时,服务器端返回给客户端的状态信息,用于表示请求的处理情况。常见的HTTP状态码有200、404、500等。在日常的网络访问中,我们有时会遇到一些异常的HTTP状态码,比如400和503等。本文将分析HTTP状态码异常出现的原因。 首先,我们来分析400状态码的异常原因…

    2025年12月22日
    000
  • JS插件开发如何使用ES6语法_ES6在JavaScript插件开发中的应用详解

    使用ES6语法开发JavaScript插件可提升代码可读性与模块化程度,通过import/export实现模块分离,class封装插件主体便于继承,解构赋值与默认参数简化配置传递,箭头函数确保this指向正确,static定义静态工具方法,结合构建工具实现兼容性与维护性双赢。 使用ES6语法开发Ja…

    2025年12月21日
    000
  • WebRTC连接建立的时效性挑战:手动SDP交换与ICE机制深度解析

    webrtc连接的建立对时效性有严格要求,尤其在手动交换sdp(会话描述协议)时。延迟接受offer/answer可能导致ice(交互式连接建立)机制超时,进而连接失败。本文将深入探讨ice的工作原理、手动sdp交换的局限性,并提供优化配置和最佳实践,以确保webrtc连接的稳定与高效。 WebRT…

    2025年12月21日
    000
  • 如何利用JavaScript的Intersection Observer API实现懒加载?

    Intersection Observer API能高效实现懒加载。它异步监听元素与视口的交叉状态,相比scroll事件更流畅,不阻塞主线程。通过观察img元素,当进入视口时将data-src赋值给src,并停止监听,可提升性能。配置rootMargin可提前加载,threshold控制触发比例,需…

    2025年12月20日
    000
  • 如何配置JS代码检查?

    答案:JS代码检查通过工具如ESLint、JSHint、JSLint提前发现代码问题。ESLint因可配置性强、支持TypeScript和JSX、社区活跃成为主流,适合复杂项目;JSHint和JSLint规则固定,适合简单语法检查。集成ESLint需安装Node.js和npm,运行npm insta…

    2025年12月20日
    000
  • 什么是CDN?CDN的加速原理

    cdn的核心作用是通过就近分发和缓存机制显著提升网站访问速度,其原理是将静态内容缓存至全球分布的边缘节点,结合智能dns解析将用户请求路由到最优节点,实现快速响应;若内容未缓存则触发回源机制,并通过连接优化、内容压缩等技术进一步提升传输效率;cdn最适合加速图片、视频、css、js等静态资源,也可部…

    2025年12月20日
    000
  • JavaScript中如何使用Webpack?

    在javascript项目中使用webpack的方法是:1. 安装webpack和cli工具;2. 创建并配置webpack.config.js文件;3. 使用插件和优化配置来提升性能和管理复杂性。通过这些步骤,webpack可以有效地管理和优化项目中的各种资源。 在JavaScript世界中,We…

    2025年12月20日
    000
  • 优化AI工作负载:性能和可伸缩性策略

    在当今的数字化浪潮中,基于云托管服务的AI工作负载已成为各行业创新的基石,从预测性分析到自然语言处理,无处不在。然而,随着企业对AI解决方案的采用日益广泛,优化性能和可扩展性变得至关重要。低效的AI工作负载可能导致成本飙升、洞察延迟以及部署瓶颈。本文将探讨优化AI工作负载的实用策略,并重点介绍如何利…

    2025年12月19日
    000
  • C++如何使用Clang-Tidy进行静态分析_C++代码质量保障与Clang-Tidy使用

    Clang-Tidy可显著提升C++代码质量,通过静态分析检测错误并支持自动修复;需生成compile_commands.json供上下文解析,使用-checks启用或禁用规则,推荐用.clan-tidy文件配置,可集成至CI和编辑器(如VS Code)实现保存时自动修复,支持NOLINT注释处理误…

    2025年12月19日
    000
  • 持续集成:GitLab Runner中容器化构建的最佳实践

    gitlab runner容器化构建可通过优化配置提升性能与稳定性。首先,选择轻量级镜像如alpine linux并使用多阶段构建以减小体积;其次,合理利用cache关键字缓存依赖和构建产物,加快后续构建速度;第三,通过parallel关键字并行执行独立任务,提高效率;第四,为job设置资源限制,避…

    2025年12月18日 好文分享
    000
  • C# .NET中的AOT(Ahead-of-Time)编译是什么 – 提升启动性能和减小体积

    AOT编译是.NET 7起支持的发布时将C#编译为原生机器码的技术,提升启动速度、减小体积(配合Trimming),适用于Serverless、桌面工具等场景,但受限于反射emit等动态特性。 AOT(Ahead-of-Time)编译是 .NET 中一种将 C# 代码在发布时直接编译为原生机器码的技…

    2025年12月17日
    000
  • 提升C# XML解析性能的7个技巧 避免不必要的性能瓶颈与错误

    使用 XmlReader 处理大文件可降低内存占用;2. 避免循环中频繁创建 XML 对象以减少 GC 压力;3. 通过 XmlReaderSettings 禁用 DTD 和命名空间等提升解析速度;4. 采用只进模式按需读取节点提高效率;5. 预编译并缓存 XPath 表达式避免重复解析;6. 按需…

    2025年12月17日
    000
  • web服务器怎么设置xm!

    web服务器设置xml的方法包括配置apache和nginx。1) 在apache中,使用mod_xml模块并在配置文件中启用xml处理。2) 在nginx中,使用ngx_http_xml_module模块并设置xml处理选项。通过这些步骤,可以高效处理xml文件。 引言 在现代网络开发中,配置一个…

    2025年12月17日
    000
  • 如何用Golang优化云原生应用启动时间_Golang 应用启动性能优化实践

    优化Golang云原生应用启动速度需从减少初始化开销、减小二进制体积、并行化任务、优化配置注入和性能分析入手,重点避免init()中耗时操作,使用延迟初始化、编译优化、多阶段构建、并发启动、静态依赖注入及pprof/trace工具定位瓶颈,提升冷启动效率。 云原生环境中,应用的启动速度直接影响部署效…

    2025年12月16日
    000
  • 如何在Golang中配置代理以加速模块下载_Golang环境配置与依赖下载优化

    配置Go模块代理可显著提升国内下载速度。启用GO111MODULE=on,设置GOPROXY=https://goproxy.cn,direct使用国内镜像,通过GOPRIVATE指定私有模块跳过代理,配合GOSUMDB校验和本地缓存优化,完整配置后依赖拉取更高效。 在使用Golang开发时,模块下…

    2025年12月16日
    000
  • Golang HTTP客户端Cookie管理与请求重用

    使用 CookieJar 并复用 http.Client 可提升性能与会话一致性。1. 配置 cookiejar.New(nil) 实现自动 Cookie 管理,客户端在后续请求中自动携带对应 Cookie;2. 复用 Client 实例避免频繁创建,结合自定义 Transport 设置连接池、超时…

    2025年12月16日
    000
  • 如何在Goland IDE中优化Golang 配置远程调试与热加载

    配置远程调试需先准备环境并设置goland连接;2.热加载通过工具如air实现并优化配置。首先确保远程服务器安装go和delve,用go install命令部署dlv,并开放防火墙端口。在goland中配置ssh或docker连接,设置路径映射后启动delve监听。热加载方面,使用air工具,创建.…

    2025年12月15日 好文分享
    000
  • 如何优化Golang中的数据库连接池配置

    确定合适的 golang 数据库连接池配置需根据应用负载、数据库性能及资源限制进行调整。1. 了解数据库最大连接数及硬件资源,避免过载;2. 分析应用并发模式,i/o 密集型可适当增加连接数,cpu 密集型则效果有限;3. 初始连接池大小建议设为 cpu 核心数的 2-3 倍,并通过性能测试验证;4…

    2025年12月15日 好文分享
    000
  • 如何提高Debian OpenSSL安全性

    增强Debian系统中OpenSSL安全性的措施如下: 升级OpenSSL组件: 首先更新系统软件包列表并完成全量升级:“`sudo apt update && sudo apt full-upgrade 接着安装最新的OpenSSL运行环境:“`sudo a…

    2025年12月15日
    000

发表回复

登录后才能评论
关注微信