性能工具之 MySQL OLTP Sysbench BenchMark 测试示例

2024-06-22 11:12

本文主要是介绍性能工具之 MySQL OLTP Sysbench BenchMark 测试示例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 一、前言
  • 二、测试环境
    • 1、服务器配置
    • 2、测试拓扑
  • 三、测试工具安装
  • 四、测试步骤
    • 1、导入数据
    • 2、压测数据
    • 3、清理数据
  • 五、结果解析
  • 六、最后

一、前言

做为一名性能工程师掌握对 MySQL 的性能测试是非常必要的,本文基于 Sysbench 对MySQL OLTP(联机事务处理) 的 BenchMark 测试案例详细介绍具体方法。

二、测试环境

1、服务器配置

数据库服务器:

  • 操作系统:CentOS 7.6 64位
  • CPU:8核
  • 内存:16GB
  • 磁盘:500GB,最大吞吐量150 MB/s
  • 数据库版本:MySQL Community Server 8.0.37
  • 网络:局域网

测试服务器:

  • 操作系统:CentOS 7.6 64位
  • CPU:8核
  • 内存:16GB
  • 磁盘:500GB,最大吞吐量150 MB/s
  • 测试软件:sysbench-1.0.12
  • 网络:局域网

2、测试拓扑

在这里插入图片描述
📢注意:

  • 尽量不要在 MySQL 本服务器上进行测试,一方面可能无法体现网络(哪怕是局域网)的影响,另一方面,sysbench 的运行(并发数较高时)会影响挤压 MySQL 服务器性能。
  • 在开始 MySQL 测试之前,应针对数据库服务器做好 BenchMark 测试。

三、测试工具安装

Sysbench是一款基于LuaJIT的,模块化多线程基准测试工具,常用于数据库基准测试。通过内置的数据库测试模型,采用多线程并发操作来评估数据库的性能。了解Sysbench更多详情,请访问:https://github.com/akopytov/sysbench。

本次测试使用的Sysbench版本为1.0.12,具体的安装命令如下:

# wget -c https://github.com/akopytov/sysbench/archive/1.0.12.zip
# yum install autoconf libtool mysql mysql-devel vim unzip
# unzip 1.0.12.zip
# cd sysbench-1.0.12
# ./autogen.sh
# ./configure
# make
# make install
#sysbench --version

显示以下内容说明已安装成功。
在这里插入图片描述

四、测试步骤

请根据实际信息,替换数据库、连接IP与用户密码。

1、导入数据

(1)使用 MySQL 命令或第三方工具登录数据库,并创建测试数据库 “loadtest” 。

mysql -u root -P 3306 -h -p -e "create database loadtest"

(2)使用 sysbench 命令导入测试背景数据到 “loadtest” 数据库。

sysbench
--test=/usr/local/share/sysbench/tests/include/oltp_legacy/oltp.lua
--db-driver=mysql --mysql-db=loadtest --mysql-user=root
--mysql-password= --mysql-port=3306 --mysql-host= --oltp-tables-count=64 --oltp-table-size=10000000 --num-threads=20 prepare

脚本参数及其含义:

  • –test:指定要运行的测试脚本,这里选择的是一个OLTP(在线事务处理)负载测试脚本。oltp.lua是一个预定义的脚本,用于模拟常见的数据库操作。
  • –db-driver:指定数据库驱动程序,这里选择的是 MySQL。
  • –mysql-db:指定要测试的 MySQL 数据库名称,这里是loadtest数据库。
  • –mysql-user:指定用于连接 MySQL 数据库的用户名,这里是 root 用户。
  • mysql-password:指定用于连接 MySQL 数据库的密码,这里为空,意味着没有设置密码(不推荐在生产环境中使用空密码)。
  • –mysql-port:指定 MySQL 服务器监听的端口,这里是默认的 3306 端口。
  • –mysql-host:指定 MySQL 服务器的主机地址,这里为空,表示连接本地数据库。
  • –oltp-tables-count:指定用于测试的表的数量,这里是 64 个表。
  • –oltp-table-size:指定每个表中的行数,这里是 10,000,000 行。表示每个表有一千万条记录。
  • –num-threads:指定测试时使用的线程数,这里是 20 个线程。表示并发 20 个线程进行测试。
  • prepare:测试提前准备数据

本文是生成 64 张表,每张表有1千万数据,合计导入6亿4千万条数据。

显示下面信息说明已经成功完成测试数据生成:

WARNING: the --test option is deprecated. You can pass a script name or path on the command line without any options.
WARNING: --num-threads is deprecated, use --threads instead
sysbench 1.0.12 (using bundled LuaJIT 2.1.0-beta2)......
Inserting 10000000 records into 'sbtest63'
Creating secondary indexes on 'sbtest63'...
Creating table 'sbtest64'...
Inserting 10000000 records into 'sbtest64'
Creating secondary indexes on 'sbtest64'...
[root@ecs-825d-1113052 ~]#

生产的表结构如下:

CREATE TABLE sbtest (
id INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
k INTEGER UNSIGNED DEFAULT '0' NOT NULL,
c CHAR(120) DEFAULT '' NOT NULL,
pad CHAR(60) DEFAULT '' NOT NULL,
PRIMARY KEY (id)
) ENGINE=InnoDB

生产数据样例如下:
在这里插入图片描述

这里用到 oltp.lua 这个关键脚本,我们单独拿出分析下,源码如下:

[root@ecs-825d-1113052 ~]# cat /usr/local/share/sysbench/tests/include/oltp_legacy/oltp.lua
-- 匹配test路径并检查
pathtest = string.match(test, "(.*/)")
if pathtest thendofile(pathtest .. "common.lua")
elserequire("common")
end-- 线程初始化函数
function thread_init()-- 设置变量set_vars()-- 检查数据库驱动和表引擎类型if (((db_driver == "mysql") or (db_driver == "attachsql")) and mysql_table_engine == "myisam") thenlocal ilocal tables = {}-- 为每个表构建锁定语句for i=1, oltp_tables_count dotables[i] = string.format("sbtest%i WRITE", i)end-- 设置锁定和解锁查询begin_query = "LOCK TABLES " .. table.concat(tables, " ,")commit_query = "UNLOCK TABLES"else-- 默认使用事务的开始和提交语句begin_query = "BEGIN"commit_query = "COMMIT"end
end-- 获取范围查询的条件字符串
function get_range_str()local start = sb_rand(1, oltp_table_size)return string.format(" WHERE id BETWEEN %u AND %u",start, start + oltp_range_size - 1)
end-- 定义事件函数
function event()local rslocal ilocal table_namelocal c_vallocal pad_vallocal query-- 随机选择一个表table_name = "sbtest".. sb_rand_uniform(1, oltp_tables_count)-- 如果没有跳过事务,则开始事务if not oltp_skip_trx thendb_query(begin_query)end-- 如果不是仅写操作if not oltp_write_only then-- 执行点查询for i=1, oltp_point_selects dors = db_query("SELECT c FROM ".. table_name .." WHERE id=" .. sb_rand(1, oltp_table_size))end-- 如果需要执行范围查询if oltp_range_selects then-- 简单范围查询for i=1, oltp_simple_ranges dors = db_query("SELECT c FROM ".. table_name .. get_range_str())end-- 范围求和查询for i=1, oltp_sum_ranges dors = db_query("SELECT SUM(K) FROM ".. table_name .. get_range_str())end-- 范围排序查询for i=1, oltp_order_ranges dors = db_query("SELECT c FROM ".. table_name .. get_range_str() .. " ORDER BY c")end-- 范围去重查询for i=1, oltp_distinct_ranges dors = db_query("SELECT DISTINCT c FROM ".. table_name .. get_range_str() .. " ORDER BY c")endendend-- 如果不是只读操作if not oltp_read_only then-- 执行索引更新for i=1, oltp_index_updates dors = db_query("UPDATE " .. table_name .. " SET k=k+1 WHERE id=" .. sb_rand(1, oltp_table_size))end-- 执行非索引更新for i=1, oltp_non_index_updates doc_val = sb_rand_str("###########-###########-###########-###########-###########-###########-###########-###########-###########-###########")query = "UPDATE " .. table_name .. " SET c='" .. c_val .. "' WHERE id=" .. sb_rand(1, oltp_table_size)rs = db_query(query)if rs thenprint(query)endend-- 执行删除和插入操作for i=1, oltp_delete_inserts doi = sb_rand(1, oltp_table_size)rs = db_query("DELETE FROM " .. table_name .. " WHERE id=" .. i)c_val = sb_rand_str("###########-###########-###########-###########-###########-###########-###########-###########-###########-###########")pad_val = sb_rand_str("###########-###########-###########-###########-###########")rs = db_query("INSERT INTO " .. table_name ..  " (id, k, c, pad) VALUES " .. string.format("(%d, %d, '%s', '%s')",i, sb_rand(1, oltp_table_size) , c_val, pad_val))endend-- 如果没有跳过事务,则提交事务if not oltp_skip_trx thendb_query(commit_query)end
end

这段 oltp.lua 代码的主要步骤如下:

  • 路径匹配与加载配置:
    • 检查并获取脚本的路径。
    • 如果路径存在,加载 common.lua 文件;否则使用 require 函数加载模块。
  • 线程初始化 (thread_init):
    • 初始化变量。
    • 根据数据库驱动和表引擎类型,决定是否使用锁表操作。
    • 如果数据库驱动是 mysql 或 attachsql 且表引擎为 myisam,则构建锁定和解锁查询语句。
    • 否则,使用默认的事务控制语句(BEGIN 和 COMMIT)。
  • 获取范围查询字符串 (get_range_str):
    • 随机生成一个起始ID。
    • 返回一个用于范围查询的条件字符串,指定查询范围为从起始ID到起始ID加上范围大小减去1。
  • 事件处理 (event):
    • 定义事件函数,该函数是 Sysbench 测试的核心部分
    • 事件函数包括以下操作:
      • 随机选择一个表。
      • 如果没有跳过事务,则开始事务。
      • 根据配置执行不同类型的查询和更新操作,包括点查询、范围查询、索引更新、非索引更新、删除和插入操作。
      • 范围查询包括简单范围查询、求和范围查询、排序范围查询和去重范围查询。
      • 如果没有跳过事务,则提交事务。

这段代码是典型的OLTP(联机事务处理)负载测试脚本,通过模拟多种数据库操作(查询、更新、删除、插入),来评估数据库在高并发访问场景下的性能表现。

2、压测数据

sysbench
--test=/usr/local/share/sysbench/tests/include/oltp_legacy/oltp.lua
--db-driver=mysql --mysql-db=loadtest --mysql-user=root
--mysql-password= --mysql-port=3306 --mysql-host=--oltp-tables-count=64
--oltp-table-size=10000000 --max-time=3600 --max-requests=0
--num-threads=200 --report-interval=3 --forced-shutdown=1 run

脚本参数及其含义:

  • –test:指定要运行的测试脚本,这里选择的是一个OLTP(在线事务处理)负载测试脚本。oltp.lua是一个预定义的脚本,用于模拟常见的数据库操作。
  • –db-driver:指定数据库驱动程序,这里选择的是 MySQL。
  • –mysql-db:指定要测试的 MySQL 数据库名称,这里是 loadtest 数据库。
  • –mysql-user:指定用于连接 MySQL 数据库的用户名,这里是 root 用户。
  • mysql-password:指定用于连接 MySQL 数据库的密码,这里为空,意味着没有设置密码(不推荐在生产环境中使用空密码)。
  • –mysql-port:指定 MySQL 服务器监听的端口,这里是默认的 3306 端口。
  • –mysql-host:指定 MySQL 服务器的主机地址,这里为空,表示连接本地数据库。
  • –oltp-tables-count:指定用于测试的表的数量,这里是 64 个表。
  • –oltp-table-size:指定每个表中的行数,这里是 10,000,000 行。表示每个表有一千万条记录。
  • –max-time:指定测试的最大持续时间为3600秒(1小时)。
  • –max-requests:指定要执行的最大请求数。值为0表示请求数不受限制,直到达到最大时间。
  • –num-threads:指定测试时使用的线程数,这里是 200 个线程。表示并发 200 个线程进行测试。
  • –report-interval:指定报告中间结果的时间间隔(每3秒报告一次)。
  • –forced-shutdown:指定如果达到最大时间,Sysbench应该强制关闭测试(1表示启用)。
  • run:开始运行测试的命令。

简要说明就是并发200线程,压测1小时,每3秒打印一次结果等。

3、清理数据

测试完成后,可以运行以下脚本清理测试数据:

sysbench
--test=/usr/local/share/sysbench/tests/include/oltp_legacy/oltp.lua
--db-driver=mysql --mysql-db=loadtest --mysql-user=root
--mysql-password= --mysql-port=3306 --mysql-host= --oltp-tables-count=64 --oltp-table-size=10000000--max-time=3600 --max-requests=0 --num-threads=200 cleanup

脚本参数及其含义:

  • –test:指定要运行的测试脚本,这里选择的是一个OLTP(在线事务处理)负载测试脚本。oltp.lua是一个预定义的脚本,用于模拟常见的数据库操作。
  • –db-driver:指定数据库驱动程序,这里选择的是 MySQL。
  • –mysql-db:指定要测试的 MySQL 数据库名称,这里是 loadtest 数据库。
  • –mysql-user:指定用于连接 MySQL 数据库的用户名,这里是 root 用户。
  • mysql-password:指定用于连接 MySQL 数据库的密码,这里为空,意味着没有设置密码(不推荐在生产环境中使用空密码)。
  • –mysql-port:指定 MySQL 服务器监听的端口,这里是默认的 3306 端口。
  • –mysql-host:指定 MySQL 服务器的主机地址,这里为空,表示连接本地数据库。
  • –oltp-tables-count:指定用于测试的表的数量,这里是 64 个表。
  • –oltp-table-size:指定每个表中的行数,这里是 10,000,000 行。表示每个表有一千万条记录。
  • –max-time:指定测试的最大持续时间为3600秒(1小时)。
  • –max-requests:指定要执行的最大请求数。值为0表示请求数不受限制,直到达到最大时间。
  • –num-threads:指定测试时使用的线程数,这里是 200 个线程。表示并发 200 个线程进行测试。
  • cleanup:测试完成后对数据库进行清理。

五、结果解析

以下为压测过程中打印的结果:

[ 3522s ] thds: 200 tps: 153.98 qps: 3119.87 (r/w/o: 2155.68/656.24/307.95) lat (ms,95%): 1235.62 err/s: 0.00 reconn/s: 0.00
[ 3525s ] thds: 200 tps: 157.36 qps: 2992.89 (r/w/o: 1997.37/680.79/314.72) lat (ms,95%): 4358.09 err/s: 0.00 reconn/s: 0.00
[ 3528s ] thds: 200 tps: 85.33 qps: 1852.86 (r/w/o: 1400.23/281.98/170.65) lat (ms,95%): 1258.08 err/s: 0.00 reconn/s: 0.00

测试结束后,查看输出文件,如下所示:

FATAL: The --max-time limit has expired, forcing shutdown...
SQL statistics:queries performed:read:                            5358024write:                           1530377other:                           765297total:                           7653698transactions:                        382581 (106.24 per sec.)queries:                             7653698 (2125.42 per sec.)ignored errors:                      0      (0.00 per sec.)reconnects:                          0      (0.00 per sec.)Number of unfinished transactions on forced shutdown: 200General statistics:total time:                          3601.0196stotal number of events:              382581Latency (ms):min:                                  4.72avg:                               1881.83max:                              10972.9295th percentile:                   4128.91sum:                            719951371.94Threads fairness:events (avg/stddev):           1913.9050/24.88execution time (avg/stddev):   3599.7569/1.81

是不是有点晕,那我们稍微翻译下,如下所示:

FATAL: The --max-time limit has expired, forcing shutdown...
#SQL统计部分表明了总查询量以及每秒执行的查询和事务数量。这些数据有助于了解数据库的处理能力和性能表现。
SQL statistics(SQL统计信息):queries performed(查询执行情况):read(读查询):                          5358024write(写查询):                         1530377other(其它查询):                        765297total(总查询):                         7653698transactionss(事务):                        382581 (106.24 per sec.) (每秒106.24次)queries(查询):                             7653698 (2125.42 per sec.) (每秒2125.42次)ignored errors(忽略的错误):                      0      (0.00 per sec.) (每秒0次)reconnect(重连)s:                          0      (0.00 per sec.) (每秒0次)# 强制关闭时未完成的事务数量为200,表明在测试过程中有200个事务未能完成,这可能与测试环境或配置有关。
Number of unfinished transactions on forced shutdown: 200General statistics(一般统计信息):total time(总时间):                          3601.0196stotal number of events(事件总数):              382581#延迟数据展示了不同百分位的延迟情况,这些数据对分析数据库响应时间和性能瓶颈很有用。
Latency(延迟) (ms):min(最小延迟):                                  4.72avg(平均延迟):                               1881.83max(最大延迟):                              10972.9295th percentile(95%分位延迟):                4128.91sum(延迟总和):                          719951371.94#线程公平性数据表明,每个线程处理的事件数的平均值和标准差,以及每个线程的执行时间的平均值和标准差。
Threads fairness(线程公平性):events (avg/stddev)(事件(平均值/标准差)):           1913.9050/24.88execution time (avg/stddev)(执行时间(平均值/标准差)):   3599.7569/1.81

这些数据展示了MySQL在高并发负载下的性能情况,主要关注点包括:

  • 查询和事务的执行率:每秒查询和事务数量表明了数据库的吞吐量。
  • 延迟:延迟数据(平均、最大和95%分位)显示了数据库的响应时间和性能瓶颈。
  • 未完成事务:强制关闭时未完成的事务数提示了潜在的事务处理问题。
  • 线程公平性:线程间的负载均衡情况,标准差较低表示负载分配较为均衡。

主要关注的性能指标有:

  • TPS :Transaction Per Second,数据库每秒执行的事务数,每个事务中包含18条SQL语句。
  • QPS :Query Per Second,数据库每秒执行的SQL数,包含insert、select、update、delete等。
  • 延迟:Latency,数据库执行的事务耗时。

Sysbench默认提交的事务中包含18条SQL语句,具体执行语句和条数如下:

主键SELECT语句,10条:
SELECT c FROM ​{rand_table_name} where id={rand_id};范围SELECT语句,4条:
SELECT c FROM ​{rand_table_name} WHERE id BETWEEN {rand_id_start} AND ${rand_id_end};
SELECT SUM(K) FROM ​{rand_table_name} WHERE id BETWEEN {rand_id_start} AND ${rand_id_end};
SELECT c FROM ​{rand_table_name} WHERE id BETWEEN {rand_id_start} AND ${rand_id_end} ORDER BY c;
SELECT DISTINCT c FROM ​{rand_table_name} WHERE id BETWEEN {rand_id_start} AND ${rand_id_end} ORDER BY c;UPDATE语句,2条:
UPDATE ​{rand_table_name} SET k=k+1 WHERE id={rand_id}
UPDATE ​{rand_table_name} SET c={rand_str} WHERE id=${rand_id}DELETE语句,1条:
DELETE FROM ​{rand_table_name} WHERE id={rand_id}INSERT语句,1条:
INSERT INTO ​{rand_table_name} (id, k, c, pad) VALUES ({rand_id},​{rand_k},{rand_str_c},${rand_str_pad})

这些结果可以用于性能调优和瓶颈分析,从而提升 MySQL 数据库在实际应用中的表现。

从Sysbench测试结果来看,这台MySQL服务器在高并发负载下的性能表现有以下几个关键点:

  • 事务处理能力:
    • 每秒事务数(TPS)为106.24次。
    • 总事务数为 382581。
  • 查询处理能力:
    • 每秒查询数(QPS)为 2125.42次。
    • 总查询数为 7653698。
  • 延迟:
    • 平均延迟为 1881.83 毫秒,较高,说明在负载压力下,响应时间比较长
    • 最大延迟为 10972.92 毫秒,非常高,表明在高负载下可能存在严重的性能瓶颈
    • 95% 分位延迟为 4128.91 毫秒,表示大多数请求的响应时间在 4 秒以上,体验较差
  • 未完成事务:
    • 强制关闭时未完成的事务数为 200,表明在高负载下有一部分事务未能及时处理完成。
  • 线程公平性:
    • 每个线程处理的事件数的标准差为 24.88,表明线程间的负载分配较为均衡。
    • 每个线程的执行时间的标准差为 1.81,表明线程执行时间也较为一致。

这里我们可以对比下某云的测试结果:
在这里插入图片描述

数据服务器资源监控数据:
在这里插入图片描述
我们可以看到CPU峰值到75%左右,磁盘峰值写入速率达50MB/s,峰值读取速率达 100MB/s。

六、最后

我们可以看到从测试结果的结果来看,MySQL数据库的性能表现并不好,那么我们接下来应对MySQL数据库进行性能调优并再次验证,希望本文能对你的工作带来一点点帮助,如果有用别忘了点个赞,多谢。

这篇关于性能工具之 MySQL OLTP Sysbench BenchMark 测试示例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1084131

相关文章

Vue3 的 shallowRef 和 shallowReactive:优化性能

大家对 Vue3 的 ref 和 reactive 都很熟悉,那么对 shallowRef 和 shallowReactive 是否了解呢? 在编程和数据结构中,“shallow”(浅层)通常指对数据结构的最外层进行操作,而不递归地处理其内部或嵌套的数据。这种处理方式关注的是数据结构的第一层属性或元素,而忽略更深层次的嵌套内容。 1. 浅层与深层的对比 1.1 浅层(Shallow) 定义

SQL中的外键约束

外键约束用于表示两张表中的指标连接关系。外键约束的作用主要有以下三点: 1.确保子表中的某个字段(外键)只能引用父表中的有效记录2.主表中的列被删除时,子表中的关联列也会被删除3.主表中的列更新时,子表中的关联元素也会被更新 子表中的元素指向主表 以下是一个外键约束的实例展示

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

如何去写一手好SQL

MySQL性能 最大数据量 抛开数据量和并发数,谈性能都是耍流氓。MySQL没有限制单表最大记录数,它取决于操作系统对文件大小的限制。 《阿里巴巴Java开发手册》提出单表行数超过500万行或者单表容量超过2GB,才推荐分库分表。性能由综合因素决定,抛开业务复杂度,影响程度依次是硬件配置、MySQL配置、数据表设计、索引优化。500万这个值仅供参考,并非铁律。 博主曾经操作过超过4亿行数据

性能测试介绍

性能测试是一种测试方法,旨在评估系统、应用程序或组件在现实场景中的性能表现和可靠性。它通常用于衡量系统在不同负载条件下的响应时间、吞吐量、资源利用率、稳定性和可扩展性等关键指标。 为什么要进行性能测试 通过性能测试,可以确定系统是否能够满足预期的性能要求,找出性能瓶颈和潜在的问题,并进行优化和调整。 发现性能瓶颈:性能测试可以帮助发现系统的性能瓶颈,即系统在高负载或高并发情况下可能出现的问题

字节面试 | 如何测试RocketMQ、RocketMQ?

字节面试:RocketMQ是怎么测试的呢? 答: 首先保证消息的消费正确、设计逆向用例,在验证消息内容为空等情况时的消费正确性; 推送大批量MQ,通过Admin控制台查看MQ消费的情况,是否出现消费假死、TPS是否正常等等问题。(上述都是临场发挥,但是RocketMQ真正的测试点,还真的需要探讨) 01 先了解RocketMQ 作为测试也是要简单了解RocketMQ。简单来说,就是一个分

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

MySQL数据库宕机,启动不起来,教你一招搞定!

作者介绍:老苏,10余年DBA工作运维经验,擅长Oracle、MySQL、PG、Mongodb数据库运维(如安装迁移,性能优化、故障应急处理等)公众号:老苏畅谈运维欢迎关注本人公众号,更多精彩与您分享。 MySQL数据库宕机,数据页损坏问题,启动不起来,该如何排查和解决,本文将为你说明具体的排查过程。 查看MySQL error日志 查看 MySQL error日志,排查哪个表(表空间

高效录音转文字:2024年四大工具精选!

在快节奏的工作生活中,能够快速将录音转换成文字是一项非常实用的能力。特别是在需要记录会议纪要、讲座内容或者是采访素材的时候,一款优秀的在线录音转文字工具能派上大用场。以下推荐几个好用的录音转文字工具! 365在线转文字 直达链接:https://www.pdf365.cn/ 365在线转文字是一款提供在线录音转文字服务的工具,它以其高效、便捷的特点受到用户的青睐。用户无需下载安装任何软件,只

MySQL高性能优化规范

前言:      笔者最近上班途中突然想丰富下自己的数据库优化技能。于是在查阅了多篇文章后,总结出了这篇! 数据库命令规范 所有数据库对象名称必须使用小写字母并用下划线分割 所有数据库对象名称禁止使用mysql保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来) 数据库对象的命名要能做到见名识意,并且最后不要超过32个字符 临时库表必须以tmp_为前缀并以日期为后缀,备份