如果多个客户端调用webservice,都更新服务器同一个表,同时就会出现死锁吧?怎么处理呢?

如果多个客户端调用webservice,都更新服务器同一个表,同时就会出现死锁吧?怎么处理呢?,第1张

这个说实话从根本上说是和你的后台数据库连接管理有关系的。和webservice本身没任何关系。如果你的后台数据库存取部分设计没问题,是连接池并统一提交修改的话这种情况根本不会出现。(比如使用hibernate等)

可直接在mysql命令行执行:show engine innodb status\G;

查看造成死锁的sql语句,分析索引情况,然后优化sql然后show processlist;

show status like ‘%lock%’

show OPEN TABLES where In_use > 0; 这个语句记录当前锁表状态

另外可以打开慢查询日志,linux下打开需在mycnf的[mysqld]里面加上以下内容:

slow_query_log=TRUE(有些mysql版本是ON)

slow_query_log_file=/usr/local/mysql/slow_query_logtxt

long_query_time=3

扩展资料:

MySQL锁定状态查看命令

Checking table:正在检查数据表(这是自动的)。 

Closing tables:正在将表中修改的数据刷新到磁盘中,同时正在关闭已经用完的表。这是一个很快的 *** 作,如果不是这样的话,就应该确认磁盘空间是否已经满了或者磁盘是否正处于重负中。

Connect Out:复制从服务器正在连接主服务器。 

Copying to tmp table on disk:由于临时结果集大于tmp_table_size,正在将临时表从内存存储转为磁盘存储以此节省内存。

Creating tmp table:正在创建临时表以存放部分查询结果。

deleting from main table:服务器正在执行多表删除中的第一部分,刚删除第一个表。


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

原文地址: http://outofmemory.cn/zz/10809781.html

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

发表评论

登录后才能评论

评论列表(0条)

保存