利用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 相关文章推荐
JS中==与===操作符的比较
Mar 21 Javascript
javascript 随机展示头像实现代码
Dec 06 Javascript
artdialog的图片/标题以及关闭按钮不显示的解决方法
Jun 27 Javascript
jQuery+easyui中的combobox实现下拉框特效
Feb 27 Javascript
js简单的点击返回顶部效果实现方法
Apr 10 Javascript
jQuery实现分隔条左右拖动功能
Nov 21 Javascript
JavaScript程序开发之JS代码放置的位置
Jan 15 Javascript
Html5+jQuery+CSS制作相册小记录
Dec 30 Javascript
树结构之JavaScript
Jan 24 Javascript
详解原生js实现offset方法
Jun 15 Javascript
js中时间格式化的几种方法
Jul 22 Javascript
JS实现数组去重及数组内对象去重功能示例
Feb 02 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执行速率优化技巧小结
2008/03/15 PHP
PHP pathinfo()获得文件的路径、名称等信息说明
2011/09/13 PHP
php cc攻击代码与防范方法
2012/10/18 PHP
探讨php中header的用法详解
2013/06/07 PHP
php数组查找函数in_array()、array_search()、array_key_exists()使用实例
2014/04/29 PHP
PHP中的命名空间详细介绍
2015/07/02 PHP
PHP基于openssl实现的非对称加密操作示例
2019/01/11 PHP
php使用json-schema模块实现json校验示例
2019/09/28 PHP
laravel框架实现后台登录、退出功能示例
2019/10/31 PHP
JavaScript 高级篇之函数 (四)
2012/04/07 Javascript
JavaScript类型系统之基本数据类型与包装类型
2016/01/06 Javascript
基于jQuery实现点击最后一行实现行自增效果的表格
2016/01/12 Javascript
JS使用正则表达式过滤多个词语并替换为相同长度星号的方法
2016/08/03 Javascript
vue在使用ECharts时的异步更新和数据加载详解
2017/11/22 Javascript
JS排序算法之冒泡排序,选择排序与插入排序实例分析
2017/12/13 Javascript
mui框架 页面无法滚动的解决方法(推荐)
2018/01/25 Javascript
vue页面切换到滚动页面显示顶部的实例
2018/03/13 Javascript
如何使用puppet替换文件中的string
2018/12/06 Javascript
vue实现form表单与table表格的数据关联功能示例
2019/01/29 Javascript
elementUI select组件默认选中效果实现的方法
2019/03/25 Javascript
Electron + vue 打包桌面操作流程详解
2019/06/24 Javascript
npm ci命令的基本使用方法
2020/09/20 Javascript
在react-antd中弹出层form内容传递给父组件的操作
2020/10/24 Javascript
Python中的引用和拷贝浅析
2014/11/22 Python
Python学习笔记之视频人脸检测识别实例教程
2019/03/06 Python
Python 剪绳子的多种思路实现(动态规划和贪心)
2020/02/24 Python
Python使用pyyaml模块处理yaml数据
2020/04/14 Python
python exit出错原因整理
2020/08/31 Python
Python爬取微信小程序通用方法代码实例详解
2020/09/29 Python
共产党员承诺书
2014/03/25 职场文书
给校长的建议书500字
2014/05/15 职场文书
安全责任书怎么写
2014/07/28 职场文书
领导班子党的群众路线教育实践活动对照检查材料
2014/09/25 职场文书
2015年度高中教师工作总结
2015/05/26 职场文书
学校少先队工作总结
2015/08/12 职场文书
2019公司借款合同范本2篇!
2019/07/24 职场文书