mysql参数配置

数据库连接池本质上是一种缓存,它是一种抗高并发的手段。数据库连接池优化主要是对参数进行优化,DBCP连接池的具体参数如下(其他各种连接池的配置参数大同小异,需要区别对待):

initialSize:初始连接数,第一次getConnection的,而不是应用启动时。初始值可以设置为并发量的历史平均值;
minIdle:最小保留的空闲连接数。DBCP会在后台开启一个回收空闲连接的线程,当该线程进行空闲连接回收的时候,会保留minIdle个连接数。一般设置为5,并发量实在很小可以设置为1.
maxIdle:最大保留的空闲连接数,按照业务并发高峰设置。比如并发高峰为20,那么当高峰过去后,这些连接不会马上被回收,如果过一小段时间又来一个高峰,那么连接池就可以复用这些空闲连接而不需要频繁创建和关闭连接。
maxActive:最大活跃连接数,按照可以接受的并发极值设置。比如单机并发量可接受的极值是100,那么这个maxActive设置成100后,就只能同时为100个请求服务,多余的请求会在最大等待时间之后被抛弃。这个值必须设置,可以防止恶意的并发攻击,保护数据库。
maxWait:获取连接的最大等待时间,建议设置的短一点,比如3s,这样可以让请求快速失败,因为一个请求在等待获取连接的时候,线程是不可以被释放的,而单机的线程并发量是有限的,如果这个时间设置的过长,比如网上建议的60s,那么这个线程在这60s内是无法被释放的,只要这种请求一多,应用的可用线程就少了,服务就变得不可用了。
minEvictableIdleTimeMillis:连接保持空闲而不被回收的时间,默认30分钟。
validationQuery:检测连接是否有效的sql语句,建议设置;
testOnBorrow:申请连接的时候对连接进行检测,不建议开启,严重影响性能;
testOnReturn:归还连接的时候对连接进行检测,不建议开启,严重影响性能;
testWhileIdle:开启以后,后台清理连接的线程会没隔一段时间对空闲连接进行validateObject,如果连接失效则会进行清除,不影响性能,建议开启;
numTestsPerEvictionRun:代表每次检查链接的数量,建议设置和maxActive一样大,这样每次可以有效检查所有的链接;
预热连接池:对于连接池,建议在启动应用的时候进行预热,在还未对外提供访问之前进行简单的sql查询,让连接池充满必要的连接数。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL是目前最常用的关系型数据库管理系统之一,配置合适的参数对于提升MySQL的性能至关重要。以下是一些关于MySQL参数配置的说明: 1. 缓冲区参数MySQL使用缓冲区来提高读写性能。其中,key_buffer用于缓存索引数据,为了提高查询速度,这个参数应该设置为适当的大小。innodb_buffer_pool_size用于缓存InnoDB数据和索引,这个参数应该根据系统的可用内存进行调整。 2. 连接参数MySQL有一个最大连接数限制,可以通过max_connections参数进行配置。该参数取决于应用程序的并发连接数和服务器的硬件规格。如果连接数过多,可能会导致服务器负载过重。 3. 查询缓存参数MySQL可以将查询结果缓存起来以提高查询性能。query_cache_size参数配置了查询缓存的大小。然而,并不是所有类型的查询都适合使用查询缓存,因此在使用查询缓存时需要评估查询的频率和复杂度来确定是否启用缓存。 4. 日志参数MySQL的日志可以用于数据恢复和查询审计。这些日志包括二进制日志、事务日志和错误日志等。log_bin参数用于启用二进制日志,根据需要进行配置。 5. 硬件参数MySQL的性能也受到服务器硬件的影响。例如,如果服务器的磁盘速度较慢,InnoDB的写入性能可能会受到影响。可以通过配置innodb_io_capacity参数来优化InnoDB的磁盘写入性能。 总之,合理配置MySQL参数对于提高数据库性能至关重要。为了确定最佳的参数配置,需要根据应用程序的需求、服务器的硬件规格以及数据库的负载情况进行评估和测试。同时,需要监控和调整参数配置以适应数据库性能的变化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值