登录
首页 >  数据库 >  MySQL

踩坑node.js + mysql

来源:SegmentFault

时间:2023-01-19 19:40:12 383浏览 收藏

编程并不是一个机械性的工作,而是需要有思考,有创新的工作,语法是固定的,但解决问题的思路则是依靠人的思维,这就需要我们坚持学习和更新自己的知识。今天golang学习网就整理分享《踩坑node.js + mysql》,文章讲解的知识点主要包括MySQL、Node.js,如果你对数据库方面的知识点感兴趣,就不要错过golang学习网,在这可以对大家的知识积累有所帮助,助力开发能力的提升。

前几天空闲时间利用node + express + mysql 写了一套订单管理系统。项目跑在本地测试均未发现问题,部署到服务器上也没啥问题;奇怪的是比如我晚上部署上去,部署完测试没问题,一切访问都正常,但是睡一觉起来,查询就502了;重启服务以后又好了,放着过段时间,又挂了.....

后来通过查看日志发现了如下错误


原来是数据库的错误,但是这是为什么?

我们先来看看mysql模块的使用方法,官方推荐我们这样建立连接


问题就是出在这!!!因为知识的盲区,我原本以为建立一次连接以后将该实例保存下来,以后每次查询都使用这个实例,能够为系统节省开销

但后来经过多方的资料收集,发现mysql在空闲一定的时间(大概是8小时)会断开连接,后经验证也确实如此,只不过时间好像不是八小时

当时的验证方法是在出现错误的时候将connection对象中的state状态记录到日志文件,果然,出现错误的时候connection对象还存在,但是此时的连接状态已经变为了断开连接,难怪会发生上面的错误!

找到了问题那么成功解决问题的几率就有了90%;看到网上有说写一个定时任务,每隔一小时,对数据库进行一次查询(此查询实际上是无用的查询,目的只是为了不让数据库连接断开,有点类似于心跳包的感觉)这不失为一个解决的办法,但是个人总感觉这不是处理的最佳方案,于是乎又从头到尾读了一遍mysql的文档,在这上面找到了答案


使用连接池,当查询完成后将该连接返回到连接池,以便于其他连接继续使用
接下来改造代码,改为池连接

目前项目部署在阿里云已经有快一星期了问题没有再复现;写下这篇文章记录一下这个坑,文笔不好,多多包涵!

文中关于mysql的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《踩坑node.js + mysql》文章吧,也可关注golang学习网公众号了解相关技术文章。

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>
评论列表