利用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 相关文章推荐
jquery 插件之仿“卓越亚马逊”首页弹出菜单效果
Dec 25 Javascript
js实现点击切换TAB标签实例
Aug 21 Javascript
Bootstrap每天必学之下拉菜单
Nov 25 Javascript
解决JS组件bootstrap table分页实现过程中遇到的问题
Apr 21 Javascript
实例讲解JavaScript中instanceof运算符的用法
Jun 08 Javascript
javascript使用闭包模拟对象的私有属性和方法
Oct 05 Javascript
详解JavaScript树结构
Jan 09 Javascript
微信小程序数据存储与取值详解
Jan 30 Javascript
Vue项目中使用Vux的安装过程
May 01 Javascript
vue使用中的内存泄漏【推荐】
Jul 10 Javascript
利用Vconsole和Fillder进行移动端抓包调试方法
Mar 05 Javascript
JavaScript之数组扁平化详解
Jun 03 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
雄兵连三大错觉:凯莎没了,凉冰阵亡了,华烨觉得自己又行了
2020/04/09 国漫
html中select语句读取mysql表中内容
2006/10/09 PHP
phpMyAdmin出现无法载入 mcrypt 扩展,请检查PHP配置的解决方法
2012/03/26 PHP
thinkphp微信开发(消息加密解密)
2015/12/02 PHP
PHP数组实际占用内存大小原理解析
2020/12/11 PHP
js实现的跟随鼠标移动的时钟效果(中英文日期显示)
2011/01/17 Javascript
基于Jquery+Ajax+Json的高效分页实现代码
2011/10/29 Javascript
浅谈javascript中的instanceof和typeof
2015/02/27 Javascript
JavaScript获取当前网页标题(title)的方法
2015/04/03 Javascript
JavaScript中setMonth()方法的使用详解
2015/06/11 Javascript
使用jQuery在对象中缓存选择器的简单方法
2015/06/30 Javascript
jquery获取多个checkbox的值异步提交给php
2015/07/07 Javascript
jQuery使用deferreds串行多个ajax请求
2016/08/22 Javascript
vue实现导航栏效果(选中状态刷新不消失)
2017/12/13 Javascript
35个最好用的Vue开源库(史上最全)
2019/01/03 Javascript
js实现点击生成随机div
2020/01/16 Javascript
JavaScript 实现轮播图特效的示例
2020/11/05 Javascript
Python多线程学习资料
2012/12/19 Python
Python中用于计算对数的log()方法
2015/05/15 Python
Python 爬虫学习笔记之多线程爬虫
2016/09/21 Python
Python决策树分类算法学习
2017/12/22 Python
python调用Matplotlib绘制分布点并且添加标签
2018/05/31 Python
Python的matplotlib绘图如何修改背景颜色的实现
2019/07/16 Python
html5 拖拽及用 js 实现拖拽功能的示例代码
2020/10/23 HTML / CSS
新西兰最大的在线设计师眼镜店:SmartBuyGlasses新西兰
2017/10/20 全球购物
彪马西班牙官网:PUMA西班牙
2019/06/18 全球购物
三查三看党性分析材料
2014/02/18 职场文书
《骑牛比赛》教后反思
2014/04/22 职场文书
写景作文评语集锦
2014/12/25 职场文书
525心理健康活动总结
2015/05/08 职场文书
小兵张嘎观后感
2015/06/03 职场文书
2019年手机市场的调研报告2篇
2019/10/10 职场文书
导游词之南京夫子庙
2019/12/09 职场文书
SQL Server连接查询的实用教程
2021/04/07 SQL Server
python编程项目中线上问题排查与解决
2021/11/01 Python
Docker安装MySql8并远程访问的实现
2022/07/07 Servers