利用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 DOM学习第六章 表单实例
Feb 19 Javascript
JS实现self的resend
Jul 22 Javascript
JavaScript 学习历程和心得分享
Dec 12 Javascript
php跨域调用json的例子
Nov 13 Javascript
JavaScript实现MIPS乘法模拟的方法
Apr 17 Javascript
C#中使用迭代器处理等待任务
Jul 13 Javascript
javascript实现信息增删改查的方法
Jul 25 Javascript
设置点击文本框或图片弹出日历控件的实现代码
May 12 Javascript
JS使用cookie实现只出现一次的广告代码效果
Apr 22 Javascript
Node.js简单入门前传
Aug 21 Javascript
详解关于Angular4 ng-zorro使用过程中遇到的问题
Dec 05 Javascript
jQuery选择器之基本过滤选择器用法实例分析
Feb 19 jQuery
禁止弹窗中蒙层底部页面跟随滚动的几种方法
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 Pear 安装及使用
2009/03/19 PHP
PHP使用GIFEncoder类生成gif动态滚动字幕
2014/07/01 PHP
PHP文件操作详解
2016/12/30 PHP
PHP中如何使用Redis接管文件存储Session详解
2018/11/28 PHP
laravel 实现根据字段不同值做不同查询
2019/10/23 PHP
js获取提交的字符串的字节数
2009/02/09 Javascript
javascript+iframe 实现无刷新载入整页的代码
2010/03/17 Javascript
jcarousellite.js 基于Jquery的图片无缝滚动插件
2010/12/30 Javascript
jquery队列函数用法实例
2014/12/16 Javascript
JavaScript限定图片显示大小的方法
2015/03/11 Javascript
js基于cookie记录来宾姓名的方法
2016/07/19 Javascript
js判断价格,必须为数字且不能为负数的实现方法
2016/10/07 Javascript
jQuery实现联动下拉列表查询框
2017/01/04 Javascript
nodejs中使用HTTP分块响应和定时器示例代码
2017/03/19 NodeJs
vue如何进行动画的封装
2018/09/26 Javascript
layer提示框添加多个按钮选择的实例
2019/09/12 Javascript
js回调函数仿360开机
2019/12/26 Javascript
vue引入静态js文件的方法
2020/06/20 Javascript
Vue优化:常见会导致内存泄漏问题及优化详解
2020/08/04 Javascript
浅谈Python 集合(set)类型的操作——并交差
2016/06/30 Python
Python实现的排列组合、破解密码算法示例
2019/04/12 Python
Python基于BeautifulSoup爬取京东商品信息
2020/06/01 Python
python多线程semaphore实现线程数控制的示例
2020/08/10 Python
纯CSS实现预加载动画效果
2017/09/06 HTML / CSS
CSS实现半透明边框与多重边框的场景分析
2019/11/13 HTML / CSS
后勤园长自我鉴定
2013/10/17 职场文书
父亲追悼会答谢词
2014/01/17 职场文书
刑事辩护授权委托书
2014/09/13 职场文书
杭州黄龙洞导游词
2015/02/10 职场文书
市场部岗位职责
2015/02/12 职场文书
2015年医生个人工作总结
2015/04/25 职场文书
小学运动会加油稿
2015/07/22 职场文书
Redis遍历所有key的两个命令(KEYS 和 SCAN)
2021/04/12 Redis
Python re.sub 反向引用的实现
2021/07/07 Python
星际争霸:毕姥爷vs解冻01
2022/04/01 星际争霸
React四级菜单的实现
2022/04/08 Javascript