- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
出于测试目的,我设置了这个小脚本:
Client = require('mysql').Client, client = new Client();
client.user = 'root'; client.password = 'root'; client.port = 8889;
counter = 0; data = '';
setInterval(update, 10);
function update(){
counter++; request();
}
var sys = require('sys'), fs = require('fs'), http = require('http'),
url = require('url'),port = 8001;
http.createServer(function(request, response) {
response.writeHead(200, {
'Content-Type': 'text/html'
}); response.end('Hello world');
}).listen(port);
function request(){
client.connect();
client.query('USE db');
client.query(
'SELECT * FROM table', function selectCb(err, results, fields) {
if (err) { throw err; }
if(results.length > 0)
{
var firstResult = results[0];
data = firstResult['data'];
}
client.end();
}
);
}
它工作正常,但是,大约一个小时后,服务器崩溃并输出以下错误:
node.js:180
throw e; // process.nextTick error, or 'error' event on first tick
^
Error: EADDRINUSE, Address already in use
更新
我更新了代码。它现在包括一些mysql。 这肯定是导致问题的原因,尽管我不知道确切原因。 将这部分排除在外可以稳定循环。另外,我将时间间隔更新为每 10 毫秒一次。 (服务器在几分钟后崩溃,其中有 mysql 部分,但没有继续运行)
最佳答案
您真的应该尊重 pimvb 关于每秒不连接到数据库 100 次的评论。如果 node-mysql 没有正确或立即清理连接,这很可能会在大约一个小时内用完可用的连接端口(实际上更像是 10 分钟左右,使用 netstat | grep WAIT | wc -l
以查看您有多少个已关闭的挂起连接)。
此外,您应该了解 JavaScript/node.js 的异步特性。您可能不希望在其他查询仍在挂起时在如此紧密的循环中运行新查询。这只会堆积起来,SQL 服务器会窒息。
更新
像下面这样的东西应该可以防止你阻塞你的服务器。它将发出尽可能多的请求,但每 10 毫秒不超过 1 个。 免责声明:在 so 文本框中被黑,未经测试!
Client = require('mysql').Client, client = new Client();
client.user = 'root'; client.password = 'root'; client.port = 8889;
counter = 0; data = '';
client.connect(function {
setInterval(update, 10);
var queryPending = false, queryReIssue = false;
function update(){
if (queryPending) {
queryReIssue = true;
} else {
request();
}
counter++;
}
var sys = require('sys'), fs = require('fs'), http = require('http'),
url = require('url'),port = 8001;
http.createServer(function(request, response) {
response.writeHead(200, {
'Content-Type': 'text/html'
}); response.end('Hello world');
}).listen(port);
function request(){
requestPending = true;
client.query('USE db');
client.query('SELECT * FROM table', function selectCb(err, results, fields) {
requestPending = false;
if (err) { console.log('ERROR: ' + err.message) }
if(results.length > 0) {
var firstResult = results[0];
data = firstResult['data'];
}
if (queryReIssue) {
queryReIssue = false;
request();
}
});
}
});
关于javascript - Node.js 错误 : EADDRINUSE, 地址已被使用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6759079/
我试图挽救在bind语句中两次尝试使用相同地址时ruby引发的异常。 documentation不是很有帮助。 这就是我想要的: require 'socket' s = UDPSocket.new(
假设您有 2 个 ASP.NET 核心项目;一个 API 和一个网站。我想使用以下 url 在本地(同时,因为该网站使用 api)处理这些问题:devapi.website.com 和 dev.web
我在 Android 上遇到 TCP 服务器问题。服务器必须管理多个传入连接,目前来自同一用户。我收到以下错误: 02-06 17:37:44.800: W/System.err(9859): jav
我已经在Ubuntu 10.04上配置并安装了ouchdb 1.6.1。在配置和安装时说成功完成了。但是,当我启动沙发床时,它给了我错误。 首次启动时。 Apache CouchDB 1.6.1 (L
IOLib 允许创建一个被动套接字来监听客户端的连接,在调用 listen 之前,我们需要调用 (bind-address) 将套接字绑定(bind)到指定的地址/端口。 嗯,问题是我第一次把sock
我正在做套接字编程。我引用了以下链接: http://examples.javacodegeeks.com/android/core/socket-core/android-socket-exampl
我开始使用 [cloud9][1] 并尝试托管我的 nodejs 应用程序。当我尝试运行我的应用程序时,它抛出以下错误: 重要:使用 process.env.PORT 作为端口,使用 process.
尝试构建实验性 CRUD 应用程序,但连接到数据库时出现问题。 使用 mLab 免费数据库。无论指定哪个端口,错误都是 EADDRINUSE::: 如何关闭可能使用这些端口的所有 Node 实例? 最
我有一个简单的 gulpfile.js: var gulp = require('gulp'); var sass = require('gulp-sass'); var connect
我有来自 CSgo roullete 的脚本。当我尝试运行它时显示此错误 errno: 'ECONNREFUSED', syscall: 'connect', address: '
这是我的 Gruntfile: module.exports = function(grunt) { grunt.initConfig({ pkg: grunt.file.readJSON
在我的 C++ 应用程序中,我将::bind() 用于 UDP 套接字,但在极少数情况下,由于连接丢失而重新连接后,即使重试多次,我也会收到错误号 EADDRINUSE。将接收数据的 UDP 连接的另
这个问题在这里已经有了答案: 关闭 11 年前。 Possible Duplicates: Releasing bound ports on process exit difference betw
下面是我的test fixture的精华—— SetUp() { g_listen_sock = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
我使用 Ubuntu 20.04、Nodemon 2.0.4、Node 14.9.0 和 Express 4.17.1。每次保存我的代码时,我都会收到此错误: events.js:291
我正在开发一个 google glass/android 应用程序。它是一个视频流应用程序,具有服务器/客户端设置,其中电话/眼镜是服务器,并将 pc 与播放视频的 session 描述 Hook 。
我有一个系统,其中在后台运行的服务器进程由控制程序控制。 控制程序是一个简单的脚本,它执行一个命令然后退出。对于 Run 命令,它会创建一个新的服务器进程;对于其他(包括关机),它通过保留的控制端口将
好吧,这真的很奇怪,我在实现一个简单的服务器时得到了 EADDRINUSE, 我已经更改了端口 寻找已经运行的node js进程 尝试使用 killall -9 node 和 root 通过sudo
我有一个使用express的测试应用程序,它在server.listen(80)上崩溃:错误:监听EADDRINUSE。我尝试使用 killall -9 node 终止所有 Node 进程,但没有进程
如果我使用端口 80 运行服务器,并且我尝试使用 XMLHttpRequest我收到此错误:错误:监听 EADDRINUSE 如果我想在端口 80 上运行服务器时发出请求,为什么 NodeJS 会出现
我是一名优秀的程序员,十分优秀!