广告
返回顶部
首页 > 资讯 > 数据库 >Mysql参数优化的详细步骤
  • 222
分享到

Mysql参数优化的详细步骤

2024-04-02 19:04:59 222人浏览 独家记忆
摘要

本篇文章给大家主要讲的是关于Mysql参数优化的详细步骤的内容,感兴趣的话就一起来看看这篇文章吧,相信看完mysql参数优化的详细步骤对大家多少有点参考价值吧。连接优化back_log=500 (默认50)

本篇文章给大家主要讲的是关于Mysql参数优化的详细步骤的内容,感兴趣的话就一起来看看这篇文章吧,相信看完mysql参数优化的详细步骤对大家多少有点参考价值吧。

连接优化

back_log=500 (默认50)

Mysql的连接达到max_connections时,新来的请求将会被存在堆栈中,以等待某一连接释放资源,该堆栈的数量即back_log,如果等待连接的数量超过back_log,将不被授予连接资源。将会报:unauthenticated user | xxx.xxx.xxx.xxx | NULL | Connect | NULL | login | NULL 的待连接进程时.back_log值不能超过tcp/IP连接的侦听队列的大小。若超过则无效,查看当前系统的TCP/IP连接的侦听队列的大小命令:cat /proc/sys/net/ipv4/tcp_max_syn_backlog目前系统为1024。对于linux系统推荐设置为小于512的整数。

wait_timeout=1800 (默认8小时,单位秒)

MySQL客户端的数据库连接闲置最大时间值;有大量sleep长时间占用内存和连接数,则需要修改此项。

max_connections=3000 (默认151)

MySql的最大连接数,如果云服务器并发连接请求量比较大,建议调高此值,连接数越多占用内存越多

max_connect_errors = 10000000

尽量设大,防止错误链接数过多导致无法写入数据

CPU优化

 thread_concurrency=16 (默认8)

正确设置可以充分利用多核CPU,thread_concurrency应设为CPU核数的2倍

网络优化

skip-name-resolve (默认被注释)

禁止MySQL对外部连接进行DNS解析,使用这一选项可以避免MySQL进行DNS解析的时间。但需要注意,如果开启该选项,则所有远程主机连接授权都要使用IP地址方式,否则MySQL将无法正常处理连接请求!

IO优化

 key_buffer_size=400M (MyISAM)

用于索引块的缓冲区大小,对MyISAM影响较大的参数。key_reads / key_read_requests在0.1之下比较好

key_cache_miss_rate = Key_reads / Key_read_requests * 100%
show status like 'key_read%';
+-------------------+-------+
| Variable_name     | Value |
+-------------------+-------+
| Key_read_requests | 28535 |
| Key_reads         | 269   |
+-------------------+-------+
以上key_cache_miss_rate大于0.1%,则需要增大参数。key_cache_miss_rate在0.1%以下都很好(每1000个请求有一个直接读硬盘),如果key_cache_miss_rate在0.01%以下的话,key_buffer_size分配的过多,可以适当减少。
mysql> show global status like 'key_blocks_u%';
+---------------------------+
| Variable_name     | Value |
+---------------------------+
| Key_blocks_unused | 0     |
| Key_blocks_used   | 413543|
+---------------------------+
Key_blocks_unused表示未使用的缓存簇(blocks)数,Key_blocks_used表示曾经用到的最大的blocks数,比如这台服务器,所有的缓存都用到了,要么增加key_buffer_size,要么就是过渡索引了,把缓存占满了。比较理想的设置:
Key_blocks_used / (Key_blocks_unused + Key_blocks_used) * 100% ≈ 80%

innodb_buffer_pool_size = 2048M  (默认128M,InnoDB)

用于缓存数据块和索引键。对InnoDB表性能影响最大的一个参数,增加这个参数的大小,可以有效的减少 InnoDB 类型的表的磁盘 I/O 。

SHOW GLOBAL STATUS LIKE 'innodb_buffer_pool_pages_%';
+----------------------------------+--------+
| Variable_name                    | Value  |
+----------------------------------+--------+
| Innodb_buffer_pool_pages_data    | 129037 |
| Innodb_buffer_pool_pages_dirty   | 362    |
| Innodb_buffer_pool_pages_flushed | 9998   |
| Innodb_buffer_pool_pages_free    | 0      |  !!!!!!!!
| Innodb_buffer_pool_pages_misc    | 2035   |
| Innodb_buffer_pool_pages_total   | 131072 |
+----------------------------------+--------+
6 rows in set (0.00 sec)

 Innodb_buffer_pool_pages_free 为 0,则说明 buffer pool 已经被用光,需要增大innodb_buffer_pool_size
 建议使用 所有内存的 75% (在剩余内存能够保证系统和其它服务正常运行的情况下)

innodb_additional_mem_pool_size=100M (默认8M)

设置了InnoDB存储引擎用来存放数据字典信息以及一些内部数据结构的内存空间大小,所以当我们一个MySQL Instance中的数据库对象非常多的时候,是需要适当调整该参数的大小以确保所有数据都能存放在内存中提高访问效率的。如果设置太小日志会出现warning

2G内存推荐20M,32G内存推荐100M

innodb_log_buffer_size=20M (默认8M)

InnoDB存储引擎的事务日志所使用的缓冲区。类似于Binlog Buffer,InnoDB在写事务日志的时候,为了提高性能,也是先将信息写入Innofb Log Buffer中。理想8M,不建议超过32MB,将此缓存段增大可以减少数据库写数据文件次数。

innodb_flush_log_trx_commit=0 (默认1)

0  log buffer每秒就会被刷写日志文件到磁盘,提交事务的时候不做任何操作
1  在每次事务提交的时候将log buffer 中的数据都会写入到log file,同时也会触发文件系统到磁盘的同步;

2  事务提交会触发log buffer到log file的刷新,但并不会触发磁盘文件系统到磁盘的同步。此外,每秒会有一次文件系统到磁盘同步操作。

设为1当然是最安全的,但性能页是最差的(相对其他两个参数而言,但不是不能接受)。如果对数据一致性和完整性要求不高,完全可以设为2,如果只最求性能,例如高并发写的日志云服务器,设为0来获得更高性能

innodb_log_file_size = 128M (默认8M)

此配置项作用设定innodb 数据库引擎UNDO日志的大小;从而减少数据库checkpoint操作。 

query_cache_size = 128M (默认32M)

缓存MySQL中的ResultSet,也就是一条SQL语句执行的结果集,所以仅仅只能针对select语句

show status like 'Qcache_%';
| Qcache_hits             | 1892463  |
| Qcache_inserts          | 35627    |
命中率98.17%=1892463/(1892463 +35627 )*100

thread_cache_size = 128 (默认8)

,当断开连接时如果缓存中还有空间,那么客户端的线程将被放到缓存中,如果线程重新被请求,那么请求将从缓存中读取,如果缓存中是空的或者是新的请求,那么这个线程将被重新创建,

 mysql> show status like 'thread%';
+——————-+——-+
| Variable_name     | Value |
+——————-+——-+
| Threads_cached    | 0     |  <—当前被缓存的空闲线程的数量
| Threads_connected | 1     |  <—正在使用(处于连接状态)的线程
| Threads_created   | 1498  |  <—服务启动以来,创建了多少个线程
| Threads_running   | 1     |  <—正在忙的线程(正在查询数据,传输数据等等操作)
+——————-+——-+
查看开机起来数据库被连接了多少次?
mysql> show status like '%connection%';
+———————-+——-+
| Variable_name        | Value |
+———————-+——-+
| Connections          | 1504  |          –>服务启动以来,历史连接数
| Max_used_connections | 2     |
+———————-+——-+
通过连接线程池的命中率来判断设置值是否合适?命中率超过90%以上,设定合理。
 (Connections -  Threads_created) / Connections * 100 %
 物理内存 1G  —> 8;2G  —> 16; 3G  —> 32; >3G  —> 64

 innodb_autoextend_increment=128 (默认8M)

此配置项作用主要是当tablespace 空间已经满了后,需要MySQL系统需要自动扩展多少空间,每次tablespace 扩展都会让各个SQL 处于等待状态。增加自动扩展Size可以减少tablespace自动扩展次数

表结构优化

innodb_file_per_table = on (5.6之前默认off)

这项设置告知InnoDB是否需要将所有表的数据和索引存放在共享表空间里(innodb_file_per_table = OFF) 或者为每张表的数据单独放在一个.ibd文件(innodb_file_per_table = ON)。每张表一个文件允许你在drop、truncate或者rebuild表时回收磁盘空间。这对于一些高级特性也是有必要的,比如数据压缩。但是它不会带来任何性能收益。你不想让每张表一个文件的主要场景是:有非常多的表(比如10k+)。

MySQL 5.6中,这个属性默认值是ON,因此大部分情况下你什么都不需要做。对于之前的版本你必需在加载数据之前将这个属性设置为ON,因为它只对新创建的表有影响。

以上关于Mysql参数优化的详细步骤详细内容,对大家有帮助吗?如果想要了解更多相关,可以继续关注我们的数据库板块。 

您可能感兴趣的文档:

--结束END--

本文标题: Mysql参数优化的详细步骤

本文链接: https://www.lsjlt.com/news/36070.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Mysql参数优化的详细步骤
    本篇文章给大家主要讲的是关于Mysql参数优化的详细步骤的内容,感兴趣的话就一起来看看这篇文章吧,相信看完Mysql参数优化的详细步骤对大家多少有点参考价值吧。连接优化back_log=500 (默认50)...
    99+
    2022-10-18
  • MySQL性能优化及分区、分表的详细步骤
    本文主要给大家简单讲讲MySQL性能优化及分区、分表的详细步骤,相关专业术语大家可以上网查查或者找一些相关书籍补充一下,这里就不涉猎了,我们就直奔主题吧,希望MySQL性能优化及分区、分表的详细步骤这篇文章...
    99+
    2022-10-18
  • mysql建表的详细步骤
    本文主要给大家简单讲讲mysql建表的详细步骤,相关专业术语大家可以上网查查或者找一些相关书籍补充一下,这里就不涉猎了,我们就直奔主题吧,希望mysql建表的详细步骤这篇文章可以给大家带来一些实际帮助。1....
    99+
    2022-10-18
  • 部署MySQL的详细步骤
    本篇内容主要讲解“部署MySQL的详细步骤”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“部署MySQL的详细步骤”吧! 1.新建配...
    99+
    2022-10-18
  • 设置阿里云数据库参数的详细步骤
    阿里云数据库是阿里云推出的一种云数据库服务,提供了多种数据库类型,包括MySQL、PostgreSQL、Oracle等。为了更好地管理和使用阿里云数据库,我们需要设置一些数据库参数。本文将详细介绍如何设置阿里云数据库参数。 登录阿里云数据库...
    99+
    2023-10-30
    阿里 步骤 参数
  • Mysql数据库详细安装步骤
    本篇内容介绍了“Mysql数据库详细安装步骤”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Mysql安装步...
    99+
    2022-10-18
  • 配置MySQL Replication的详细步骤
    不知道大家之前对类似配置MySQL Replication的详细步骤的文章有无了解,今天我在这里给大家再简单的讲讲。感兴趣的话就一起来看看正文部分吧,相信看完配置MySQL Replication的详细步骤...
    99+
    2022-10-18
  • QT连接MYSQL数据库的详细步骤
     第一步要加入对应的数据库模块(sql)在工程文件(.pro)介绍几个类(也是对应的头文件)  QSqlError提供SQL数据库错误信息的类 ...
    99+
    2022-11-12
  • PowerDesigner 连接MySQL数据库详细步骤
    新建一个 Physical Data ,选择自己要连接的数据库 在PowerDesigner菜单栏中,依次点击“File ->New Model->Physical Data” 点击OK 2、连接数...
    99+
    2023-09-03
    powerdesigner 数据库
  • MySQL的主从复制==>详细步骤
    目录 前言 一、准备工作 1、提前准备好两台服务器,分别安装Mysql 2、使用克隆弄出另一台服务器的注意事项 二、配置==>主库Master  1、修改Mysql数据库的配置文件/etc/my.cnf 2、 重启Mysql服务 3、登录M...
    99+
    2023-09-08
    mysql 数据库 java
  • DBeaver连接MySQL的超详细步骤
    目录一、DBeaver连接mysql二、Kettle连接DBeaver总结一、DBeaver连接MySQL 打开DBeaver软件,点击MySQL创建数据库连接 点击下一步 把需要连接的数据库名、用户名及密码填进去 ...
    99+
    2023-05-12
    dbeaver连接mysql dbeaver连接数据库 dbeaver连接数据库
  • Mysql双主配置的详细步骤
    目录前言一、mysql配置文件(1)节点A配置(2)节点B配置二、配置节点A为节点B的master(主从模式)三、完成双主配置四、测试五、控制同步的库或表六、一个账号多个IP总结前言 特点:在双主配置中,两台mysql互...
    99+
    2022-06-23
    mysql双主双从怎么配置 mysql双主特色 Mysql双主
  • MySQL创建视图的详细步骤
    下面讲讲关于MySQL创建视图的详细步骤,文字的奥妙在于贴近主题相关。所以,闲话就不谈了,我们直接看下文吧,相信看完MySQL创建视图的详细步骤这篇文章你一定会有所受益。1.视图概述:视图是从一个或多个表导...
    99+
    2022-10-18
  • 编译安装MySQL的详细步骤
    下文我给大家简单讲讲关于编译安装MySQL的详细步骤,大家之前了解过相关类似主题内容吗?感兴趣的话就一起来看看这篇文章吧,相信看完编译安装MySQL的详细步骤对大家多少有点帮助吧。编译安装mysql:1、准...
    99+
    2022-10-18
  • 彻底卸载mysql的详细步骤
    目录 一、前言 二、操作步骤  (一) 停止mysql的服务 (二)控制面板卸载 (三)清除残留的文件 (四)删除注册表内容 (五)删除MySQL环境变量 一、前言 卸载mysql的原因有挺多,有些是mysql文件里面没有data包和m...
    99+
    2023-09-02
    mysql 数据库 彻底卸载 重新安装 data和ini文件
  • 多机配置mysql数据库的详细步骤
    下面讲讲关于多机配置mysql数据库的详细步骤,文字的奥妙在于贴近主题相关。所以,闲话就不谈了,我们直接看下文吧,相信看完多机配置mysql数据库的详细步骤这篇文章你一定会有所受益。一主多从配置环境:&nb...
    99+
    2022-10-18
  • 本地安装MySQL数据库详细步骤
    文章目录 【确认本地是否安装mysql】【下载mysql安装包】【添加配置文件并安装mysql】【修改mysql密码】【配置环境变量】【总结】 前期在windows电脑尝试安装mysql,经历诸多...
    99+
    2023-09-05
    mysql 数据库 java
  • MYSQL配置参数优化详解
    MySQL参数优化对于不同的网站,及其在线量,访问量,帖子数量,网络情况,以及机器硬件配置都有关系,优化不可能一次性完成,需要不断的观察以及调试,才有可能得到最佳的效果。 1)连接请求的变量 1、max_...
    99+
    2022-10-18
  • mysql 8.0.30 降级到 8.0.27的详细步骤
    经过探索方法如下:第一步: 备份原来的数据使用:mytsqldump mysqldump -uroot -p -E -R rourDB>dbbak.sql -E -R 导出所...
    99+
    2022-11-13
  • MySQL主从切换的超详细步骤
    目录版本:前言:主从环境:切换步骤:总结版本: mysql-5.7.32+GTID 前言: 本文讲述MySQL主从切换流程,切换步骤主要针对主备正常切换以及主库宕机备库切换两个场景,掌握正确的切换流程,可以有效避免切换过...
    99+
    2022-06-28
    mysql主从切换原理 mysql主从切换步骤 数据库主从切换
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作