利用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 相关文章推荐
如何用jQuery实现ASP.NET GridView折叠伸展效果
Sep 26 Javascript
js实现超酷的照片墙展示效果图附源码下载
Oct 08 Javascript
javaScript给元素添加多个class的简单实现
Jul 20 Javascript
JavaScript学习小结之被嫌弃的eval函数和with语句实例详解
Aug 01 Javascript
Vuex2.0+Vue2.0构建备忘录应用实践
Nov 30 Javascript
js 去掉字符串前后空格实现代码集合
Mar 25 Javascript
ES6中Iterator与for..of..遍历用法分析
Mar 31 Javascript
vue实现页面加载动画效果
Sep 19 Javascript
Node.js中sequelize时区的配置方法
Dec 10 Javascript
vue中子组件向父组件传递数据的实例代码(实现加减功能)
Apr 20 Javascript
JS实现点击按钮随机生成可拖动的不同颜色块示例
Jan 30 Javascript
ES6入门教程之Array.from()方法
Mar 23 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&java(一)
2006/10/09 PHP
PHP实现二叉树深度优先遍历(前序、中序、后序)和广度优先遍历(层次)实例详解
2018/04/20 PHP
缓动函数requestAnimationFrame 更好的实现浏览器经动画
2012/12/07 Javascript
使用js判断TextBox控件值改变然后出发事件
2014/03/07 Javascript
jquery弹窗插件colorbox绑定动态生成元素的方法
2014/06/20 Javascript
jQuery实现返回顶部功能适合不支持js的浏览器
2014/08/19 Javascript
基于豆瓣API+Angular开发的web App
2015/01/02 Javascript
JS使用正则表达式实现关键字替换加粗功能示例
2016/08/03 Javascript
微信小程序 Video API实例详解
2016/10/02 Javascript
jQuery利用sort对DOM元素进行排序操作
2016/11/07 Javascript
AngularJS实现的回到顶部指令功能实例
2017/05/17 Javascript
详解vue-cli项目中用json-sever搭建mock服务器
2017/11/02 Javascript
浅谈es6 javascript的map数据结构
2017/12/14 Javascript
ajax前台后台跨域请求处理方式
2018/02/08 Javascript
详解50行代码,Node爬虫练手项目
2019/04/22 Javascript
vuex vue简单使用知识点总结
2019/08/29 Javascript
javascript 对象 与 prototype 原型用法实例分析
2019/11/11 Javascript
vue:el-input输入时限制输入的类型操作
2020/08/05 Javascript
[00:33]2016完美“圣”典风云人物:BurNIng宣传片
2016/12/10 DOTA
Python的Socket编程过程中实现UDP端口复用的实例分享
2016/03/19 Python
深入理解python中的闭包和装饰器
2016/06/12 Python
python和shell获取文本内容的方法
2018/06/05 Python
django与小程序实现登录验证功能的示例代码
2019/02/19 Python
pandas计算最大连续间隔的方法
2019/07/04 Python
Python数据库小程序源代码
2019/09/15 Python
python对文件的操作方法汇总
2020/02/28 Python
python 下载文件的多种方法汇总
2020/11/17 Python
python语言time库和datetime库基本使用详解
2020/12/25 Python
详解CSS3实现响应式手风琴效果
2020/06/10 HTML / CSS
美赞臣新加坡官方旗舰店:Enfagrow新加坡
2019/05/15 全球购物
客户代表实习人员自我鉴定
2013/09/27 职场文书
销售自我评价
2013/10/22 职场文书
五年级音乐教学反思
2014/02/06 职场文书
2015中秋节慰问信范文
2015/03/23 职场文书
防震减灾主题班会
2015/08/14 职场文书
导游词之四川熊猫基地
2020/01/13 职场文书