NodeJs Mysql Cant't create more than max_prepared_stmt_count statements

这阵子碰到一个数据库上的问题,一个刚上线不到一周的 NodeJs 接口服务里所有的查询全部都挂掉了,接口一直处于 pending 状态,看了下 pm2 的日志发现了报错:Cant‘t create more than max_prepared_stmt_count statements,重启 Node 服务后接口查询恢复正常。

网上查了查资料基本上都是让修改 max_prepared_stmt_count 的,当时觉得这个方案治标不治本就没有采纳,后来优化了一下MySQL的部分代码就让服务继续跑着,后来又一周左右的时间服务又挂掉了。

CTO 也没碰到过这个问题然后几经搜索,最后发现了一个非常靠谱的解决方案。

语句问题,举例:

query(`SELECT nickname FROM users WHERE id = ${id} AND age = ?`, [age])

是因为语句中引入了变量导致的,我一般只有把需要转义的部分用问号填充,不需要转移的都是放到变量里的。

统一改成下面这种方式以后

query(`SELECT nickname FROM users WHERE id = ? AND age = ?`, [id, age])

截至目前为止服务跑的稳定很多,已经跑了半个月左右了。

NodeJs Mysql Cant't create more than max_prepared_stmt_count statements

原文地址:https://www.cnblogs.com/xwant/p/10096362.html

时间: 2024-11-08 20:43:44

NodeJs Mysql Cant't create more than max_prepared_stmt_count statements的相关文章

MySQL 报 Can't create more than max_prepared_stmt_count statements

前言 最近压测完毕以后, MySQL 报 Can't create more than max_prepared_stmt_count statements. 正常情况下是程序没有关闭 stmt 导致. 也不排除并发量很大, MySQL 没机会去关闭. 这种情况我们系统来说出现概率较少, 并发量还没有那么大. 以下为定位问题的过程. 操作 1.出现此类问题, 如果是线上应立即执行 set global max_prepared_stmt_count = 1048576,先控制住错误.然后进行定位

Can't create more than max_prepared_stmt_count statements

使用mysql connector的时候,如果报这个错误 Can't create more than max_prepared_stmt_count statements (current value: 16382) 是因为下面的写法有一定问题,如果catch了错误,那么stmt就不会释放,最好是把stmt放到外面,在最后的时候delete,但是一般不会出问题,关键是如果写了bug,导致不断运行catch错误,就会导致preparedstatement大量不会释放,超出默认的16382的个数

Phantomjs+Nodejs+Mysql数据抓取(2.抓取图片)

概要 这篇博客是在上一篇博客Phantomjs+Nodejs+Mysql数据抓取(1.抓取数据) http://blog.csdn.net/jokerkon/article/details/50868880 后进行的第二部分,请各位读者在看这篇博客之前先浏览上一篇,因为这里面有部分代码会沿用到上一部分的抓取结果. 好,现在开始正式的抓取图片的讲解 首先,我们先来看看代码: var page =require('webpage').create(); var address='http://pro

nodejs mysql 创建连接池

用Nodejs连接MySQL 从零开始nodejs系列文章,将介绍如何利Javascript做为服务端脚本,通过Nodejs框架web开发.Nodejs框架是基于V8的引擎,是目前速度最快的Javascript引擎.chrome浏览器就基于V8,同时打开20-30个网页都很流畅.Nodejs标准的web开发框架Express,可以帮助我们迅速建立web站点,比起PHP的开发效率更高,而且学习曲线更低.非常适合小型网站,个性化网站,我们自己的Geek网站!! 关于作者 张丹(Conan), 程序员

Nodejs mysql 数据库增、删、改、查 操作

Nodejs mysql的增.删.改.查操作 Nodejs连接mysql的增.删.改.查操作(转载 自:http://blog.sina.com.cn/s/blog_5a6efa330102vctw.html) 一.准备 nodejs的教程,大多以操作mongodb为示例.但是mongodb有一些局限性,具体官网上有说.我打算用MySQL,因为多少还有点使用经验.先以研究为主.node-mysql,是目前最火的node下的mysql驱动.初步了用了一下,因为异步回调的这种方式,果然好多坑. 下面

07 nodejs+mysql向外提供api

本节我们将通过nodejs+mysql为向外提供api,完成07小节中接口的提供. 1.前提约束 完成nodejs,vue-cli,webpack,webpack-dev-server的安装 https://www.jianshu.com/p/eb4d9e132f62 2.操作步骤 创建一个文件夹作为项目文件夹 mkdir nodejsmysql 下载相关包 cd nodejsmysql cnpm install mysql --save-dev cnpm install express --s

mysql can't create threads in threadpool

最近,我们在券商端的mysql运行一段时间后,发生mysql can't create threads in threadpool,如下所示: 据官网一个报告显示,目测是一个bug,内存紧张导致,那天也没及时看,明后天再观察看看,现在是没有问题了. mysql can't create threads in threadpool

nodejs mysql 操作数据库方法一详解

nodejs mysql 数据查询例子 时间 2014-11-11 15:28:01  姜糖水原文  http://www.cnphp6.com/archives/59864 1.安装nodejs 2.安装mysql  npm包 地址:https://github.com/felixge/node-mysql npm install mysql 3.相应API查看及调用: var mysql = require('mysql'); var connection = mysql.createCon

MySQL 自定义函数CREATE FUNCTION实例

分享一个MySQL 自定义函数CREATE FUNCTION的实例.mysql> delimiter $$mysql> CREATE FUNCTION myFunction-> (in_string VARCHAR(255),-> in_find_str VARCHAR(20),-> in_repl_str VARCHAR(20))->-> RETURNS VARCHAR(255)-> BEGIN-> DECLARE l_new_string VARC