利用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 拖拉缩放效果
Dec 10 Javascript
比较搞笑的js陷阱题
Feb 07 Javascript
IE6,IE7下js动态加载图片不显示错误
Jul 17 Javascript
JavaScript中setAttribute用法介绍
Jul 20 Javascript
js代码实现的加入收藏效果并兼容主流浏览器
Jun 23 Javascript
Javascript前端UI框架Kit使用指南之kitjs的对话框组件
Nov 28 Javascript
jquery+json实现数据二级联动的方法
Nov 28 Javascript
简单实现轮播图效果的实例
Jul 15 Javascript
js中遍历对象的属性和值的方法
Jul 27 Javascript
JS实现的简单图片切换功能示例【测试可用】
Feb 14 Javascript
ES6中的rest参数与扩展运算符详解
Jul 18 Javascript
微信小程序js文件改变参数并在视图上及时更新【推荐】
Jun 11 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生成HTML静态页面实例代码
2008/08/31 PHP
实战mysql导出中文乱码及phpmyadmin导入中文乱码的解决方法
2010/06/11 PHP
利用php抓取蜘蛛爬虫痕迹的示例代码
2016/09/30 PHP
PHP实现Redis单据锁以及防止并发重复写入
2018/04/10 PHP
PHP中Static(静态)关键字功能与用法实例分析
2019/04/05 PHP
Nigma vs Liquid BO3 第二场2.13
2021/03/10 DOTA
javascript call和apply方法
2008/11/24 Javascript
两个比较有用的Javascript工具函数代码
2010/02/17 Javascript
Javascript中的相等与不等运算
2010/04/25 Javascript
基于JQuery实现的Select级联
2014/01/27 Javascript
javascript中使用正则计算中文长度的例子
2014/04/29 Javascript
js比较日期大小的方法
2015/05/12 Javascript
javascript实现判断鼠标的状态
2015/07/10 Javascript
基于BootStrap Metronic开发框架经验小结【九】实现Web页面内容的打印预览和保存操作
2016/05/12 Javascript
详解nodejs 配置文件处理方案
2019/01/02 NodeJs
JS实现数组去重及数组内对象去重功能示例
2019/02/02 Javascript
JavaScript使用小插件实现倒计时的方法讲解
2019/03/11 Javascript
前端路由&webpack基础配置详解
2019/06/10 Javascript
JavaScript array常用方法代码实例详解
2020/09/02 Javascript
python执行使用shell命令方法分享
2017/11/08 Python
python绘制多个曲线的折线图
2020/03/23 Python
Python的几种主动结束程序方式
2019/11/22 Python
Python创建空列表的字典2种方法详解
2020/02/13 Python
简单了解pytest测试框架setup和tearDown
2020/04/14 Python
Pandas中DataFrame基本函数整理(小结)
2020/07/20 Python
Scrapy基于scrapy_redis实现分布式爬虫部署的示例
2020/09/29 Python
CSS实现聊天气泡效果
2020/04/26 HTML / CSS
CSS3 box-shadow属性实例详解
2020/06/19 HTML / CSS
洲际酒店集团大中华区:IHG中国
2016/08/17 全球购物
建筑经济管理专业求职信分享
2014/01/06 职场文书
幼儿园英语教学反思
2014/01/30 职场文书
学生安全责任书范本
2014/07/24 职场文书
考试作弊检讨书
2015/01/27 职场文书
聘任合同书
2015/09/21 职场文书
初中语文教学反思范文
2016/03/03 职场文书
Vue2.0搭建脚手架
2022/03/13 Vue.js