Sysbench参数中文解释

本文详细介绍了Sysbench这一性能测试工具的使用方法及其各项参数设置。包括如何通过不同测试项目如文件I/O、CPU性能、内存功能速度等来评估系统的性能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近需要对新到的R720服务器进行性能测试,必须用到的是sysbench,由于本人因为不太好,因此转了一下网上搜到的解释,先保留一下。

sysbench
测试用例:
sysbench [general-options]… –test=<test-name> [test-options]… command
通用选项:
--num-threads=N           创建测试线程的数目。默认为1.
--max-requests=N          请求的最大数目。默认为10000,0代表不限制。
--max-time=N              最大执行时间,单位是s。默认是0,不限制。
--forced-shutdown=STRING           超过max-time强制中断。默认是off。
--thread-stack-size=SIZE           每个线程的堆栈大小。默认是32K。
--init-rng=[on|off]       在测试开始时是否初始化随机数发生器。默认是off。
--test=STRING             指定测试项目名称。
--debug=[on|off]          是否显示更多的调试信息。默认是off。
--validate=[on|off]       在可能情况下执行验证检查。默认是off。
测试项目:
fileio – File I/O test
cpu – CPU performance test
memory – Memory functions speed test
threads – Threads subsystem performance test
mutex – Mutex performance test(互斥性能测试)
oltp – OLTP test (联机事务处理系统)
指令: prepare(测试前准备工作) run(正式测试) cleanup(测试后删掉测试数据) help version
See ‘sysbench –test=<name> help’ for a list of options for each test. 查看每个测试项目的更多选项列表。

# ./sysbench –test=fileio help
--file-num=N   创建测试文件的数量。默认是128
--file-block-size=N  测试时文件块的大小。默认是16384(16K)
--file-total-size=SIZE   测试文件的总大小。默认是2G
--file-test-mode=STRING  文件测试模式{seqwr(顺序写), seqrewr(顺序读写), seqrd(顺序读), rndrd(随机读), rndwr(随机写), rndrw(随机读写)}
--file-io-mode=STRING   文件操作模式{sync(同步),async(异步),fastmmap(快速map映射),slowmmap(慢map映射)}。默认是sync
--file-extra-flags=STRING   使用额外的标志来打开文件{sync,dsync,direct} 。默认为空
--file-fsync-freq=N   执行fsync()的频率。(0–不使用fsync())。默认是100
--file-fsync-all=[on|off] 每执行完一次写操作就执行一次fsync。默认是off
--file-fsync-end=[on|off] 在测试结束时才执行fsync。默认是on
--file-fsync-mode=STRING  使用哪种方法进行同步{fsync, fdatasync}。默认是fsync
--file-merged-requests=N   如果可以,合并最多的IO请求数(0–表示不合并)。默认是0
--file-rw-ratio=N     测试时的读写比例。默认是1.5

sysbench --test=cpu help
--cpu-max-prime=N  最大质数发生器数量。默认是10000

sysbench --test=memory help
--memory-block-size=SIZE  测试时内存块大小。默认是1K
--memory-total-size=SIZE    传输数据的总大小。默认是100G
--memory-scope=STRING    内存访问范围{global,local}。默认是global
--memory-hugetlb=[on|off]  从HugeTLB池内存分配。默认是off
--memory-oper=STRING     内存操作类型。{read, write, none} 默认是write
--memory-access-mode=STRING存储器存取方式{seq,rnd} 默认是seq

sysbench --test=threads help
--thread-yields=N   每个请求产生多少个线程。默认是1000
--thread-locks=N    每个线程的锁的数量。默认是8

sysbench --test=mutex help
--mutex-num=N    数组互斥的总大小。默认是4096
--mutex-locks=N    每个线程互斥锁的数量。默认是50000
--mutex-loops=N    内部互斥锁的空循环数量。默认是10000

sysbench --test=oltp help
oltp options:
--oltp-test-mode=STRING    执行模式{simple,complex(advanced transactional),nontrx(non-transactional),sp}。默认是complex
--oltp-reconnect-mode=STRING 重新连接模式{session(不使用重新连接。每个线程断开只在测试结束),transaction(在每次事务结束后重新连接),query(在每个 SQL语句执行完重新连接),random(对于每个事务随机选择以上重新连接模式)}。默认是session
--oltp-sp-name=STRING   存储过程的名称。默认为空
--oltp-read-only=[on|off]  只读模式。Update,delete,insert语句不可执行。默认是off
--oltp-skip-trx=[on|off]   省略begin/commit语句。默认是off
--oltp-range-size=N      查询范围。默认是100
--oltp-point-selects=N          number of point selects [10]
--oltp-simple-ranges=N          number of simple ranges [1]
--oltp-sum-ranges=N             number of sum ranges [1]
--oltp-order-ranges=N           number of ordered ranges [1]
--oltp-distinct-ranges=N        number of distinct ranges [1]
--oltp-index-updates=N          number of index update [1]
--oltp-non-index-updates=N      number of non-index updates [1]
--oltp-nontrx-mode=STRING   查询类型对于非事务执行模式{select, update_key, update_nokey, insert, delete} [select]
--oltp-auto-inc=[on|off]      AUTO_INCREMENT是否开启。默认是on
--oltp-connect-delay=N     在多少微秒后连接数据库。默认是10000
--oltp-user-delay-min=N    每个请求最短等待时间。单位是ms。默认是0
--oltp-user-delay-max=N    每个请求最长等待时间。单位是ms。默认是0
--oltp-table-name=STRING  测试时使用到的表名。默认是sbtest
--oltp-table-size=N         测试表的记录数。默认是10000
--oltp-dist-type=STRING    分布的随机数{uniform(均匀分布),Gaussian(高斯分布),special(空间分布)}。默认是special
--oltp-dist-iter=N    产生数的迭代次数。默认是12
--oltp-dist-pct=N    值的百分比被视为’special’ (for special distribution)。默认是1
--oltp-dist-res=N    ‘special’的百分比值。默认是75
General database options:
--db-driver=STRING  指定数据库驱动程序(‘help’ to get list of available drivers)
--db-ps-mode=STRING编制报表使用模式{auto, disable} [auto]
Compiled-in database drivers:
--mysql – MySQL driver
mysql options:
--mysql-host=[LIST,...]       MySQL server host [localhost]
--mysql-port=N                MySQL server port [3306]
--mysql-socket=STRING         MySQL socket
--mysql-user=STRING           MySQL user [sbtest]
--mysql-password=STRING       MySQL password []
--mysql-db=STRING             MySQL database name [sbtest]
--mysql-table-engine=STRING   storage engine to use for the test table {myisam,innodb,bdb,heap,ndbcluster,federated} [innodb]
--mysql-engine-trx=STRING     whether storage engine used is transactional or not {yes,no,auto} [auto]
--mysql-ssl=[on|off]          use SSL connections, if available in the client library [off]
--myisam-max-rows=N           max-rows parameter for MyISAM tables [1000000]
--mysql-create-options=STRING additional options passed to CREATE TABLE []
<think>嗯,用户想了解如何正确配置MySQL参数的最佳实践。我需要先整理一下现有的引用内容,看看有什么相关的信息。引用[3]提到设置参数的三种方式:会话级、全局级和配置文件。用户可能需要知道这些不同的配置方法以及它们的优先级。另外,引用[1]和[2]都强调了根据具体业务需求调整参数,没有一刀切的方案。这说明在回答时要强调结合实际应用场景。 然后,引用[4]提到了HikariCP和JDBC配置,可能涉及到连接池的优化,这部分也需要考虑进去。用户可能关心连接数、缓存大小、日志设置等关键参数。比如max_connections、innodb_buffer_pool_size这些参数对性能影响很大,需要详细解释。 接下来,我得按照用户提供的系统级指令来组织回答。必须使用中文,正确使用LaTeX格式,行内公式用$...$,独立公式用$$...$$。同时要生成相关问题,并在引用处添加标识。 首先,回答的结构要清晰,分步骤或分部分讲解最佳实践。可能需要分为配置方法、关键参数、优化步骤、注意事项等部分。每个部分引用对应的引用内容。例如,配置方法部分引用[3]中的三种设置方式,关键参数部分引用[3]中的max_connections和引用[4]的连接池配置。 需要注意避免技术错误,比如正确解释每个参数的作用和调整建议。例如,innodb_buffer_pool_size通常设置为物理内存的70-80%,但如果有其他应用运行,可能需要调整。同时,要提到测试和监控的重要性,引用[1]中提到的测试和验证步骤。 最后,生成相关问题时要围绕MySQL参数配置,比如如何监控参数调整后的效果,不同存储引擎的参数差异,连接池参数优化等。确保问题与主题相关,帮助用户进一步探索。 现在需要检查是否符合所有格式要求,比如LaTeX是否正确,引用标识是否在正确的位置。例如,在提到配置方法时,引用[3];提到性能优化时引用[1]和[4]等。确保每个引用只在末尾出现一次,并且自然融入内容中。 总结一下,回答应该包括配置方式、关键参数、优化步骤、注意事项,然后生成相关问题。每个部分引用相应的资料,确保信息准确可靠。同时保持语言口语化,避免使用专业术语过多,让用户容易理解。</think>### MySQL参数配置最佳实践分步指南 #### 一、配置方式选择 1. **会话级配置** `SET [SESSION] 参数名=参数值`,仅影响当前连接[^3] *适用场景*:临时调试特定SQL性能 *示例*:`SET SESSION sort_buffer_size = 2*1024*1024` 2. **全局级配置** `SET GLOBAL 参数名=参数值`,立即生效但重启失效 *适用场景*:生产环境紧急调整 *示例*:`SET GLOBAL max_connections=2000` 3. **持久化配置** 修改`my.cnf`/`my.ini`文件,需重启生效 *适用场景*:长期稳定的参数配置 *示例配置*: ```ini [mysqld] max_connections = 2000 innodb_buffer_pool_size = 16G ``` #### 二、核心性能参数配置 $$ \text{内存分配} = \text{物理内存} \times 0.7 \quad (\text{建议起始值}) $$ 1. **连接相关** - `max_connections`:根据应用并发量设置,公式参考: $$ \text{建议值} = \frac{\text{可用内存}}{\text{单个连接内存消耗}} \times 0.8 $$ 可通过`SHOW STATUS LIKE 'Max_used_connections'`查看历史峰值 2. **InnoDB引擎** - `innodb_buffer_pool_size`:设置物理内存的70-80%[^4] - `innodb_log_file_size`:建议1-2GB(需停机修改) - `innodb_flush_log_at_trx_commit`: - 1:完全ACID(默认) - 2:折中方案 - 0:高性能模式 3. **查询缓存** - `query_cache_type=OFF`(MySQL 8.0已移除该功能) - 建议改用Redis等外部缓存[^2] #### 三、优化实施步骤 1. **基准测试** ```sql SHOW GLOBAL STATUS LIKE 'Innodb_buffer_pool_read%s'; SHOW ENGINE INNODB STATUS; ``` 计算缓冲池命中率: $$ \text{命中率} = 1 - \frac{\text{Innodb_buffer_pool_reads}}{\text{Innodb_buffer_pool_read_requests}} $$ 建议保持>98%[^1] 2. **渐进式调整** - 每次只修改1-2个参数 - 使用`sysbench`进行压力测试 - 监控`SHOW GLOBAL STATUS`变化 3. **连接池配置** ```properties # HikariCP推荐配置[^4] minimumIdle=10 maximumPoolSize=100 connectionTimeout=30000 idleTimeout=600000 ``` #### 四、注意事项 1. 避免直接复制生产环境的配置到开发环境[^1] 2. 修改`key_buffer_size`等MyISAM参数前需确认存储引擎类型[^2] 3. 使用`mysqltuner.pl`等工具获取优化建议 4. 重要参数变更前必须备份`my.cnf`文件
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值