利用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 相关文章推荐
JavaScript效率调优经验
Jun 04 Javascript
如何确保JavaScript的执行顺序 之实战篇
Mar 03 Javascript
同域jQuery(跨)iframe操作DOM(实例讲解)
Dec 19 Javascript
js获取url中"?"后面的字串方法
May 15 Javascript
Jquery中find与each方法用法实例
Feb 04 Javascript
jQuery支持添加事件的日历特效代码分享(3种样式)
Aug 24 Javascript
javascript断点调试心得分享
Apr 23 Javascript
Bootstrap CSS布局之表格
Dec 17 Javascript
jQuery Collapse1.1.0折叠插件简单使用
Aug 28 jQuery
基于node.js实现微信支付退款功能
Dec 19 Javascript
详解easyui基于 layui.laydate日期扩展组件
Jul 18 Javascript
JS+HTML实现的圆形可点击区域示例【3种方法】
Aug 01 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面向对象分析设计的61条军规小结
2010/07/17 PHP
PHP通过正则表达式下载图片到本地的实现代码
2011/09/19 PHP
php curl常见错误:SSL错误、bool(false)
2011/12/28 PHP
ThinkPHP实现非标准名称数据表快速创建模型的方法
2014/11/29 PHP
PHP生成word文档的三种实现方式
2016/11/14 PHP
浅谈php中的访问修饰符private、protected、public的作用范围
2016/11/20 PHP
HTML中Select不用Disabled实现ReadOnly的效果
2008/04/07 Javascript
window.onload 加载完毕的问题及解决方案(下)
2009/07/09 Javascript
js弹出层包含flash 不能关闭隐藏的2种处理方法
2013/06/17 Javascript
js控制容器隐藏出现防止样式变化的两种方法
2014/04/25 Javascript
javascript实现时间格式输出FormatDate函数
2015/01/13 Javascript
javascript中if和switch,==和===详解
2015/07/30 Javascript
jQuery插件Flexslider实现图片轮播、图文结合滑动切换效果
2020/04/16 Javascript
vue.js声明式渲染和条件与循环基础知识
2017/07/31 Javascript
javaScript字符串工具类StringUtils详解
2017/12/08 Javascript
大转盘抽奖小程序版 转盘抽奖网页版
2020/04/16 Javascript
微信小程序点击图片实现长按预览、保存、识别带参数二维码、转发等功能
2019/07/20 Javascript
使用Vue.js中的过滤器实现幂方求值的方法
2019/08/27 Javascript
如何正确理解vue中的key详解
2019/11/02 Javascript
[01:02:09]Liquid vs TNC 2019国际邀请赛淘汰赛 胜者组 BO3 第二场 8.21
2020/07/19 DOTA
Python+Django搭建自己的blog网站
2018/03/13 Python
Python实现基于KNN算法的笔迹识别功能详解
2018/07/09 Python
详解Python中的测试工具
2019/06/09 Python
在pycharm下设置自己的个性模版方法
2019/07/15 Python
Pytorch之Variable的用法
2019/12/31 Python
Python中用xlwt制作表格实例讲解
2020/11/05 Python
python tqdm实现进度条的示例代码
2020/11/10 Python
办公室前台岗位职责范本
2013/12/10 职场文书
市场营销大学生职业规划书
2014/02/25 职场文书
防邪知识进家庭活动方案
2014/08/26 职场文书
2014年社区重阳节活动策划方案
2014/09/16 职场文书
试用期转正工作总结2015
2015/05/28 职场文书
MySQL8.0.18配置多主一从
2021/06/21 MySQL
MySQL千万级数据表的优化实战记录
2021/08/04 MySQL
CSS font-variation 可变字体的魅力(实例详解)
2022/03/03 HTML / CSS
「魔导具师妲莉亚永不妥协~从今天开始的自由职人生活~」1、2卷发售宣传CM公开
2022/03/21 日漫