利用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编程起步(第六课)
Jan 10 Javascript
jquery操作select option 的代码小结
Jun 21 Javascript
js实现网页倒计时、网站已运行时间功能的代码3例
Apr 14 Javascript
js数组依据下标删除元素
Apr 14 Javascript
详解JavaScript中|单竖杠运算符的使用方法
May 23 Javascript
jquery的ajax提交form表单的两种方法小结(推荐)
May 25 Javascript
javascript 动态样式添加的简单实现
Oct 11 Javascript
详解Vue监听数据变化原理
Mar 08 Javascript
js实现文字列表无缝滚动效果
Jun 23 Javascript
js实现一个简单的MVVM框架示例
Jan 15 Javascript
详解ES6系列之私有变量的实现
Nov 21 Javascript
vue封装自定义指令之动态显示title操作(溢出显示,不溢出不显示)
Nov 12 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
兼容各大浏览器带关闭按钮的漂浮多组图片广告代码
2014/06/05 PHP
Symfony2安装第三方Bundles实例详解
2016/02/04 PHP
CI框架表单验证实例详解
2016/11/21 PHP
PHP实现求解最长公共子串问题的方法
2017/11/17 PHP
Thinkphp5.0框架使用模型Model的获取器、修改器、软删除数据操作示例
2019/10/11 PHP
Jquery cookie操作代码
2010/03/14 Javascript
javascript textContent与innerText的异同分析
2010/10/22 Javascript
Javascript无阻塞加载具体方式
2013/06/28 Javascript
让javascript加载速度倍增的方法(解决JS加载速度慢的问题)
2014/12/12 Javascript
jquery插件tytabs.jquery.min.js实现渐变TAB选项卡效果
2015/08/25 Javascript
jQuery给元素添加样式的方法详解
2015/12/30 Javascript
如何在Linux上安装Node.js
2016/04/01 Javascript
jQuery简单实现点击文本框复制内容到剪贴板上的方法
2016/08/01 Javascript
利用js编写响应式侧边栏
2016/09/17 Javascript
HTML中setCapture、releaseCapture 使用方法浅析
2016/09/25 Javascript
jQuery手指滑动轮播效果
2016/12/22 Javascript
Webpack+Vue如何导入Jquery和Jquery的第三方插件
2017/02/20 Javascript
Angular 向组件传递模板的两种方法
2018/02/23 Javascript
Node.js+ELK日志规范的实现
2019/05/23 Javascript
Javascript模拟实现new原理解析
2020/03/03 Javascript
[02:08]2018年度CS GO枪械皮肤设计大赛优秀作者-完美盛典
2018/12/16 DOTA
Django框架中方法的访问和查找
2015/07/15 Python
PyCharm使用教程之搭建Python开发环境
2016/06/07 Python
Python实现进程同步和通信的方法
2018/01/02 Python
Linux下python3.7.0安装教程
2018/07/30 Python
Django的用户模块与权限系统的示例代码
2019/07/24 Python
Python2和3字符编码的区别知识点整理
2019/08/08 Python
python Socket网络编程实现C/S模式和P2P
2020/06/22 Python
HTML5的文档结构和新增标签完全解析
2017/04/21 HTML / CSS
自动化工程专业个人应聘自荐信
2013/09/26 职场文书
施工班组长岗位职责
2014/01/05 职场文书
2014年重阳节敬老活动方案
2014/09/16 职场文书
工作证明书
2015/06/15 职场文书
维护民族团结心得体会2016
2016/01/15 职场文书
Mysql事务索引知识汇总
2022/03/17 MySQL
Win11局域网共享权限在哪里设置? Win11高级共享的设置技巧
2022/04/05 数码科技