利用Node.js检测端口是否被占用的方法


Posted in Javascript onDecember 07, 2017

前言

在学习tcp/ip的时候,经常遇到一些关于跟端口有关的东西,在写网络上的一些东西,有时用的一些端口被提示:端口已被占用,啊啊啊,挺郁闷的,然后就想着将它搞明白,下面话不多说了,来一起看看详细的介绍吧。

Nodejs检测端口是否被占用

开启本地服务时,有这么一种情况:当前端口已经被另一个项目使用了,导致服务开启失败。

那么接下来,我们通过简简单单的十行代码来检测端口是否已经被占用。

思路

想要知道端口是否被占用,我们可以开启一个新的服务并监听该端口,若开启成功则说明端口未被占用,反之该端口已经被其他程序使用了。

基本思路有了,下面我们开始编写代码。

基础代码

portIsOccupied.js

var net = require('net')

// 检测端口是否被占用
function portIsOccupied (port) {
 // 创建服务并监听该端口
 var server = net.createServer().listen(port)

 server.on('listening', function () { // 执行这块代码说明端口未被占用
 server.close() // 关闭服务
 console.log('The port【' + port + '】 is available.') // 控制台输出信息
 })

 server.on('error', function (err) {
 if (err.code === 'EADDRINUSE') { // 端口已经被使用
  console.log('The port【' + port + '】 is occupied, please change other port.')
 }
 })
}

// 执行
portIsOccupied(1987)

测试

执行 node portIsOccupied.js,正常情况下会输出 The port【1987】 is available.

使用ssr将当前目录设置成静态服务器,关于ssr的使用可以在这里找到 https://github.com/jaywcjlove/ssr,
ssr默认会开启 1987 端口。

这时,再次执行 node portIsOccupied.js,输出 The port【1987】 is occupied, please change other port.

让程序更加完美

到这里为止,我们已经能够检测端口是否被占用。

但是,假如我要检测另外一个端口,每次都得更改文件的端口号,相当的麻烦。

那么有没有更加完美的实现方法呢?当然有!

Nodejs中,有这么一个好玩的东西 process.argv,它是一个数组,前两个值分别是node程序所在位置和当前运行的文件所在位置。

神奇的是,我们运行程序时,所传的参数可以通过 process.argv 得到。

比如这样子 node portIsOccupied.js -p 1987,那么会将 -p 和 1987 添加到 process.argv 数组的末尾。

知道了原理,下面我们来编写更加完美的程序吧。

控制台给程序传参

修改 portIsOccupied(1987) 为:

var port = 80 // 默认检测80端口
if (process.argv[2] === '-p') {
 port = parseInt(process.argv[3])
}
portIsOccupied(port)

执行

其中 [port] 是你想要检测的端口。

node portIsOccupied.js -p [port]

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
stream.js 一个很小、完全独立的Javascript类库
Oct 28 Javascript
js写的方法实现上传图片之后查看大图
Mar 05 Javascript
使用JavaScript和C#中获得referer
Nov 14 Javascript
node.js实现BigPipe详解
Dec 05 Javascript
JavaScript中的方法调用详细介绍
Dec 30 Javascript
JavaScript实现经纬度转换成地址功能
Mar 28 Javascript
jQuery中map函数的两种方式
Apr 07 jQuery
axios封装,使用拦截器统一处理接口,超详细的教程(推荐)
May 02 Javascript
微信域名检测接口调用演示步骤(含PHP、Python)
Dec 08 Javascript
JS实现拼图游戏
Jan 29 Javascript
Vue自动构建发布脚本的方法示例
Jul 24 Javascript
JavaScript实现班级抽签小程序
May 19 Javascript
禁止弹窗中蒙层底部页面跟随滚动的几种方法
Dec 07 #Javascript
Vue通过URL传参如何控制全局console.log的开关详解
Dec 07 #Javascript
Vue中添加手机验证码组件功能操作方法
Dec 07 #Javascript
react学习笔记之state以及setState的使用
Dec 07 #Javascript
React Native 截屏组件的示例代码
Dec 06 #Javascript
判断jQuery是否加载完成,没完成继续判断的解决方法
Dec 06 #jQuery
mui back 返回刷新页面的实例
Dec 06 #Javascript
You might like
PHP动态生成javascript文件的2个例子
2014/04/11 PHP
PHP积分兑换接口实例
2015/02/09 PHP
PHP中SESSION的注销与清除
2015/04/16 PHP
精通JavaScript 纠正 cleanWhitespace函数
2010/03/11 Javascript
JQuery UI DatePicker中z-index默认为1的解决办法
2010/09/28 Javascript
jquery判断checkbox(复选框)是否被选中的代码
2010/10/20 Javascript
js变换显示图片的实例
2013/04/16 Javascript
zepto.js中tap事件阻止冒泡的实现方法
2015/02/12 Javascript
jquery插件corner实现圆角边框的方法
2015/03/09 Javascript
JavaScript数据类型学习笔记
2016/01/25 Javascript
Vue2.0使用过程常见的一些问题总结学习
2017/04/10 Javascript
javascript  数组排序与对象排序的实例
2017/07/17 Javascript
jQuery实现简单复制json对象和json对象集合操作示例
2018/07/09 jQuery
在 Angular-cli 中使用 simple-mock 实现前端开发 API Mock 接口数据模拟功能的方法
2018/11/28 Javascript
详解@angular/cli 改变默认启动端口两种方式
2018/11/29 Javascript
Element输入框带历史查询记录的实现示例
2019/01/15 Javascript
js实现的在本地预览图片功能示例
2019/11/09 Javascript
Vue2.4+新增属性.sync、$attrs、$listeners的具体使用
2020/03/08 Javascript
详细分析vue响应式原理
2020/06/22 Javascript
视觉直观感受若干常用排序算法
2017/04/13 Python
python爬取各类文档方法归类汇总
2018/03/22 Python
numpy的文件存储.npy .npz 文件详解
2018/07/09 Python
Python使用Slider组件实现调整曲线参数功能示例
2019/09/06 Python
对Python中 \r, \n, \r\n的彻底理解
2020/03/06 Python
Scrapy模拟登录赶集网的实现代码
2020/07/07 Python
python如何将图片转换素描画
2020/09/08 Python
CSS3教程:新增加的结构伪类
2009/04/02 HTML / CSS
英国快时尚女装购物网站:PrettyLittleThing
2018/08/15 全球购物
找工作最新求职信
2013/12/22 职场文书
服务承诺口号
2014/05/22 职场文书
企业员工集体活动方案
2014/08/17 职场文书
私人委托书格式
2014/09/10 职场文书
机关驾驶员违规检讨书
2014/09/13 职场文书
学生不参加考试检讨书
2015/02/19 职场文书
亮剑观后感300字
2015/06/05 职场文书
bose降噪耳机音能消除人声吗
2022/04/19 数码科技