利用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 相关文章推荐
幻宇的层模拟窗口效果-提供演示和下载
Jan 20 Javascript
整理8个很棒的 jQuery 倒计时插件和教程
Dec 12 Javascript
通过js获取div的background-image属性
Oct 15 Javascript
javascript 常见功能汇总
Jun 11 Javascript
浅谈js内置对象Math的属性和方法(推荐)
Sep 19 Javascript
js窗口震动小程序分享
Nov 28 Javascript
详解windows下vue-cli及webpack 构建网站(三)使用组件
Jun 17 Javascript
Angular+Bootstrap+Spring Boot实现分页功能实例代码
Jul 21 Javascript
Javascript(es2016) import和require用法和区别详解
Aug 11 Javascript
使用express+multer实现node中的图片上传功能
Feb 02 Javascript
完美解决iview 的select下拉框选项错位的问题
Mar 02 Javascript
JS实现分页导航效果
Feb 19 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读取和编写XML DOM的实现代码
2011/02/03 PHP
php fputcsv命令 写csv文件遇到的小问题(多维数组连接符)
2011/05/24 PHP
PHP的MVC模式实现原理分析(一相简单的MVC框架范例)
2014/04/29 PHP
php实现检查文章是否被百度收录
2015/01/27 PHP
PHP stream_context_create()函数的使用示例
2015/05/12 PHP
php单例模式的简单实现方法
2016/06/10 PHP
PHP unset函数原理及使用方法解析
2020/08/14 PHP
JavaScript下申明对象的几种方法小结
2008/10/02 Javascript
js获得当前时区夏令时发生和终止的时间代码
2014/02/23 Javascript
jquery获取及设置outerhtml的方法
2015/03/09 Javascript
js事件处理程序跨浏览器解决方案
2016/03/27 Javascript
jquery实现表格中点击相应行变色功能效果【实例代码】
2016/05/09 Javascript
package.json文件配置详解
2017/06/15 Javascript
Vue2 添加数据可视化支持的方法步骤
2019/01/02 Javascript
JS块级作用域和私有变量实例分析
2019/05/11 Javascript
小程序实现左滑删除效果
2019/07/25 Javascript
vue 解决mintui弹窗弹起来,底部页面滚动bug问题
2020/11/12 Javascript
简单的通用表达式求10乘阶示例
2014/03/03 Python
Python异常学习笔记
2015/02/03 Python
win10系统中安装scrapy-1.1
2016/07/03 Python
Python按行读取文件的实现方法【小文件和大文件读取】
2016/09/19 Python
Python中你应该知道的一些内置函数
2017/03/31 Python
python RabbitMQ 使用详细介绍(小结)
2018/11/08 Python
python实现合并多个list及合并多个django QuerySet的方法示例
2019/06/11 Python
Django中URL的参数传递的实现
2019/08/04 Python
pygame实现烟雨蒙蒙下彩虹雨
2019/11/11 Python
python代码打印100-999之间的回文数示例
2019/11/24 Python
详解用selenium来下载小姐姐图片并保存
2021/01/26 Python
CSS3对背景图片的裁剪及尺寸和位置的设定方法
2016/03/07 HTML / CSS
使用HTML5捕捉音频与视频信息概述及实例
2018/08/22 HTML / CSS
浅谈pc和移动端的响应式的使用
2019/01/03 HTML / CSS
汉森冲浪板:Hansen Surfboards
2018/05/19 全球购物
委托书样本
2014/04/02 职场文书
保洁员岗位职责
2015/02/04 职场文书
儿童诗两首教学反思
2016/02/23 职场文书
教师实习自我鉴定总结
2019/08/20 职场文书