利用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 相关文章推荐
Add a Table to a Word Document
Jun 15 Javascript
Javascript Ajax异步读取RSS文档具体实现
Dec 12 Javascript
让table变成exls的示例代码
Mar 24 Javascript
js鼠标点击图片实现随机变换图片的方法
Feb 16 Javascript
JavaScript实现通过select标签跳转网页的方法
Sep 29 Javascript
js格式化时间的简单实例
Nov 27 Javascript
JS中SetTimeout和SetInterval使用初探
Mar 23 Javascript
Restify中接入Socket.io报Error:Can’t set headers的错误解决
Mar 28 Javascript
详解动画插件wow.js的使用方法
Sep 13 Javascript
js+canvas实现五子棋小游戏
Aug 02 Javascript
JavaScript实现原型封装轮播图
Dec 27 Javascript
vue postcss-px2rem 自适应布局
May 15 Vue.js
禁止弹窗中蒙层底部页面跟随滚动的几种方法
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使用simplexml_load_file加载XML文件并显示XML的方法
2015/03/19 PHP
wamp服务器访问php非常缓慢的解决过程
2015/07/01 PHP
PHP连接MYSQL数据库实例代码
2016/01/20 PHP
PHP生成短网址方法汇总
2016/07/12 PHP
phpinfo()中Loaded Configuration File(none)的解决方法
2017/01/16 PHP
php生成0~1随机小数的方法(必看)
2017/04/05 PHP
详细解读php的命名空间(二)
2018/02/21 PHP
ThinkPHP5 的简单搭建和使用详解
2018/11/15 PHP
jQuery 技巧大全(新手入门篇)
2009/05/12 Javascript
Javascript中查找不以XX字符结尾的单词示例代码
2013/10/15 Javascript
jQuery鼠标事件汇总
2015/08/30 Javascript
Angular限制input框输入金额(是小数的话只保留两位小数点)
2017/07/13 Javascript
原生JS实现小小的音乐播放器
2017/10/16 Javascript
详解vue-cli脚手架build目录中的dev-server.js配置文件
2017/11/24 Javascript
react学习笔记之state以及setState的使用
2017/12/07 Javascript
浅谈Koa2框架利用CORS完成跨域ajax请求
2018/03/06 Javascript
vue裁切预览组件功能的实现步骤
2018/05/04 Javascript
react-native滑动吸顶效果的实现过程
2019/06/03 Javascript
JavaScript展开操作符(Spread operator)详解
2019/07/20 Javascript
微信小程序 确认框的实现(附代码)
2019/07/23 Javascript
解决Layui中layer报错的问题
2019/09/03 Javascript
axios实现简单文件上传功能
2019/09/25 Javascript
vant 时间选择器--开始时间和结束时间实例
2020/11/04 Javascript
vant时间控件使用方法详解
2020/12/24 Javascript
[00:32]2016完美“圣”典风云人物:Maybe宣传片
2016/12/05 DOTA
Python 的内置字符串方法小结
2016/03/15 Python
python 接口_从协议到抽象基类详解
2017/08/24 Python
关于Django显示时间你应该知道的一些问题
2017/12/25 Python
Python 新建文件夹与复制文件夹内所有内容的方法
2018/10/27 Python
使用python3构建文件传输的方法
2019/02/13 Python
Django ORM filter() 的运用详解
2020/05/14 Python
ABOUT YOU匈牙利:500个最受欢迎的时尚品牌
2019/07/19 全球购物
编辑个人求职信范文
2013/09/21 职场文书
土木工程专业推荐信
2014/02/19 职场文书
单方投资意向书
2015/05/11 职场文书
分享五个Node.js开发的优秀实践 
2022/04/07 NodeJs