利用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 相关文章推荐
ExtJs 表单提交登陆实现代码
Aug 19 Javascript
jqGrid jQuery 表格插件测试代码
Aug 23 Javascript
通过Javascript将数据导出到外部Excel文档的函数代码
Jun 15 Javascript
GridView中获取被点击行中的DropDownList和TextBox中的值
Jul 18 Javascript
jQuery中的$.ajax()方法应用
May 06 Javascript
一款由jquery实现的整屏切换特效
Sep 15 Javascript
JQuery给网页更换皮肤的方法
May 30 Javascript
jquery弹出遮掩层效果【附实例代码】
Apr 28 Javascript
jQuery Validate插件实现表单验证
Aug 19 Javascript
JS数组排序方法实例分析
Dec 16 Javascript
JavaScript文本特效实例小结【3个示例】
Dec 22 Javascript
vue.js基于v-for实现批量渲染 Json数组对象列表数据示例
Aug 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
简洁短小的 JavaScript IE 浏览器判定代码
2010/03/21 Javascript
js离开或刷新页面检测(且兼容FF,IE,Chrome)
2014/03/05 Javascript
chrome下img加载对height()的影响示例探讨
2014/05/26 Javascript
Javascript+CSS实现影像卷帘效果思路及代码
2014/10/20 Javascript
javascript实现禁止复制网页内容
2014/12/16 Javascript
45个JavaScript编程注意事项、技巧大全
2015/02/11 Javascript
jQuery实现contains方法不区分大小写的方法
2015/02/13 Javascript
【JS+CSS3】实现带预览图幻灯片效果的示例代码
2016/03/17 Javascript
javaScript 事件绑定、事件冒泡、事件捕获和事件执行顺序整理总结
2016/10/10 Javascript
js编写的treeview使用方法
2016/11/11 Javascript
利用CSS、JavaScript及Ajax实现图片预加载的方法
2016/11/29 Javascript
AngularJS路由实现页面跳转实例
2017/03/03 Javascript
微信小程序报错:this.setData is not a function的解决办法
2017/09/27 Javascript
JavaScript定义及输出螺旋矩阵的方法详解
2017/12/01 Javascript
将jquery.qqFace.js表情转换成微信的字符码
2017/12/01 jQuery
vue router 配置路由的方法
2018/07/26 Javascript
使用 electron 实现类似新版 QQ 的登录界面效果(阴影、背景动画、窗体3D翻转)
2018/10/23 Javascript
vue+vuex+json-seiver实现数据展示+分页功能
2019/04/11 Javascript
vue+eslint+vscode配置教程
2019/08/09 Javascript
js实现GIF图片的分解和合成
2019/10/24 Javascript
vue中@change兼容问题详解
2019/10/25 Javascript
[03:58]2014DOTA2国际邀请赛 龙宝赛后解密DK获胜之道
2014/07/14 DOTA
横向对比分析Python解析XML的四种方式
2016/03/30 Python
python使用电子邮件模块smtplib的方法
2016/08/28 Python
python3实现基于用户的协同过滤
2018/05/31 Python
详解python异步编程之asyncio(百万并发)
2018/07/07 Python
python自带tkinter库实现棋盘覆盖图形界面
2019/07/17 Python
Stefania Mode美国:奢华设计师和时尚服装
2018/01/07 全球购物
感恩的演讲稿
2014/05/06 职场文书
2015年预防青少年违法犯罪工作总结
2015/05/22 职场文书
2015年高二班主任工作总结
2015/05/25 职场文书
element多个表单校验的实现
2021/05/27 Javascript
python cv2图像质量压缩的算法示例
2021/06/04 Python
分享7个 Python 实战项目练习
2022/03/03 Python
Python编写冷笑话生成器
2022/04/20 Python
MyBatis在注解上使用动态SQL方式(@select使用if)
2022/07/07 Java/Android