利用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 相关文章推荐
关于IE浏览器以及Firefox下的javascript冒泡事件的响应层级
Oct 14 Javascript
js获取通过ajax返回的map型的JSONArray的方法
Jan 09 Javascript
获取当前点击按钮的id用this.id实现
Mar 17 Javascript
AngularJS入门教程(一):静态模板
Dec 06 Javascript
原生js获取元素样式的简单方法
Aug 06 Javascript
Angular ng-repeat 对象和数组遍历实例
Sep 14 Javascript
javascript字符串对象常用api函数小结(连接,替换,分割,转换等)
Sep 20 Javascript
微信小程序 animation API详解及实例代码
Oct 08 Javascript
jQuery插件ajaxFileUpload异步上传文件
Oct 19 Javascript
微信小程序 判断手机号的实现代码
Apr 19 Javascript
JavaScript中filter的用法实例分析
Feb 27 Javascript
vue实现桌面向网页拖动文件的示例代码(可显示图片/音频/视频)
Mar 01 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图片验证码代码
2008/03/27 PHP
PHP初学者最感迷茫的问题小结
2010/03/27 PHP
PHP文件读写操作之文件读取方法详解
2011/01/13 PHP
PHP session会话的安全性分析
2011/09/08 PHP
php隐藏实际地址的文件下载方法
2015/04/18 PHP
PHP Hash算法:Times33算法代码实例
2015/05/13 PHP
php header函数的常用http头设置
2015/06/25 PHP
帝国cms常用标签汇总
2015/07/06 PHP
PHP的serialize序列化数据以及JSON格式化数据分析
2015/10/10 PHP
100多行PHP代码实现socks5代理服务器[2]
2016/05/05 PHP
PhpStorm本地断点调试的方法步骤
2018/05/21 PHP
PHP面向对象程序设计中的self、static、parent关键字用法分析
2019/08/14 PHP
静态图片的十一种滤镜效果--不支持Ie7及非IE浏览器。
2007/03/06 Javascript
jquery 指南/入门基础
2007/11/30 Javascript
js setTimeout opener的用法示例详解
2013/10/23 Javascript
javascript ajax的5种状态介绍
2014/08/18 Javascript
node.js中的console.log方法使用说明
2014/12/09 Javascript
简单谈谈json跨域
2016/03/13 Javascript
jQuery.parseHTML() 函数详解
2017/01/09 Javascript
Vue计算属性的使用
2017/08/04 Javascript
vue2.0 移动端实现下拉刷新和上拉加载更多的示例
2018/04/23 Javascript
react koa rematch 如何打造一套服务端渲染架子
2019/06/26 Javascript
node+multer实现图片上传的示例代码
2020/02/18 Javascript
Python去除字符串两端空格的方法
2015/05/21 Python
python爬虫 模拟登录人人网过程解析
2019/07/31 Python
春节到了 教你使用python来抢票回家
2020/01/06 Python
200行python代码实现贪吃蛇游戏
2020/04/24 Python
大学自我鉴定
2013/12/20 职场文书
承诺书模板
2014/08/30 职场文书
优秀党员事迹材料
2014/12/18 职场文书
西安大雁塔导游词
2015/02/10 职场文书
火烧圆明园的观后感
2015/06/03 职场文书
新郎结婚感言
2015/07/31 职场文书
MYSQL如何查看进程和kill进程
2022/03/13 MySQL
《帝国时代4》赛季预告 新增内容编译器可创造地图
2022/04/03 其他游戏
排查MySQL生产环境索引没有效果
2022/04/11 MySQL