mysql数据库最大能支持多少并发量

mysql数据库最大能支持多少并发量,第1张

MySQL服务器的最大并发连接数是16384。

受服务器配置,及网络环境等制约,实际服务器支持的并发连接数会小一些。主要决定因素有:

1、服务器CPU及内存的配置。

2、网络的带宽。互联网连接中上行带宽的影响尤为明显。

扩展资料:

优化数据库结构:

组织数据库的schema、表和字段以降低I/O的开销,将相关项保存在一起,并提前规划,以便随着数据量的增长,性能可以保持较高的水平。

设计数据表应尽量使其占用的空间最小化,表的主键应尽可能短。·对于InnoDB表,主键所在的列在每个辅助索引条目中都是可复制的,因此如果有很多辅助索引,那么一个短的主键可以节省大量空间。

仅创建需要改进查询性能的索引。索引有助于检索,但是会增加插入和更新 *** 作的执行时间。

InnoDB的ChangeBuffering特性:

InnoDB提供了changebuffering的配置,可减少维护辅助索引所需的磁盘I/O。大规模的数据库可能会遇到大量的表 *** 作和大量的I/O,以保证辅助索引保持最新。当相关页面不在缓冲池里面时,InnoDB的changebuffer将会更改缓存到辅助索引条目。

从而避免因不能立即从磁盘读取页面而导致耗时的I/O *** 作。当页面被加载到缓冲池时,缓冲的更改将被合并,更新的页面之后会刷新到磁盘。这样做可提高性能,适用于MySQL5.5及更高版本。

参考资料来源:百度百科-MySQL数据库

mysql

默认的最大并发连接为100,默认的连接数无法满足大量client

连接的请求.

但是可以通过以下方式改变,使用root用户登录mysql

系统引用mysql

>

show

variables

like

’max_connections‘

+-----------------+-------+

|

Variable_name

|

Value

|

+-----------------+-------+

|

max_connections

|

100

|

+-----------------+-------+

在不需要重启的情况下.通过以下命令更改为300引用set

global

max_connections

=

300为了保证mysql

重启能够生效,还需要编译

/my.ini

(默认)

把max_connections

=

300以上完成之后,下次重启就会使用新的参数。

我理解的是:读表的锁表是指在读的过程中上锁,不允许中途还insert其他记录,当读表完毕,获得select结果后,表就解锁了,可以继续新的select或insert等 *** 作。

例子里:2人同时借钱,没有业务锁的话,两个请求发到后端后可能同时去select,此时2次借款 *** 作select余额都是1000(在另一人借200后回写余额800之前),于是2个请求 *** 作各自开始借钱,算出借钱后都剩下800,再分别update进表中,表里余额就是800

如果加业务锁:2个请求到后端后,select余额和借钱后Update按一个事务进行,那第1人select 1000元并借款后剩下800更新进表中,完成第1人借钱事务后,再进行第2人借钱select 剩下的800元并借款后剩下600更新进表中,就可以避免


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/8637353.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-19
下一篇 2023-04-19

发表评论

登录后才能评论

评论列表(0条)

保存