在 Node.js 版本 10+
假设我们有一个服务器正在侦听路径(unix 域套接字):
const server = net.createServer(socket => {
});
const p = path.resolve(process.env.HOME + '/unix.sock');
server.listen(p);
在运行上述代码之前,有没有办法确定其他服务器是否已经在侦听路径 p?
在 Node.js 版本 10+
假设我们有一个服务器正在侦听路径(unix 域套接字):
const server = net.createServer(socket => {
});
const p = path.resolve(process.env.HOME + '/unix.sock');
server.listen(p);
在运行上述代码之前,有没有办法确定其他服务器是否已经在侦听路径 p?
我现有答案的替代方法是创建客户端并尝试连接到服务器。根据结果,您可以确定 unix 套接字是否被占用。
function isPortTaken(port, fn) {
var net = require('net');
var client = new net.Socket();
client.connect(port, function(err) {
if(err)
return fn(false)
client.destroy();
fn(true);
});
}
警告:如果服务器在新连接上触发某些操作,这将触发它。
简单但有点脏的方法是尝试使用端口,看看它是否会引发EADDRINUSE
错误。
function isPortTaken(port, fn) {
var net = require('net')
var tester = net.createServer()
.once('error', function (err) {
if (err.code != 'EADDRINUSE')
fn(true)
})
.once('listening', function () {
tester.once('close', function () {
fn(false)
})
.close()
})
.listen(port)
}
回调将给出一个布尔值。
我本来打算自己写这个脚本,但后来在某个地方找到了它并对其进行了一些小改动。您可以在此处找到原始脚本: https ://gist.github.com/timoxley/1689041