首頁 > web前端 > js教程 > 主體

在Node.js中如何偵測連接埠是否被佔用

亚连
發布: 2018-06-22 14:02:29
原創
2009 人瀏覽過

這篇文章主要給大家介紹了關於利用Node.js檢測端口是否被佔用的相關資料,文中透過範例程式碼介紹的非常詳細,對大家的學習或工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。

前言

在學習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]
登入後複製

上面是我整理給大家的,希望今後會對大家有幫助。

相關文章:

在angularjs中如何實作長條圖動態載入

在Vue中有關響應式原理(詳細教學)

使用js如何實作時間戳與日期格式之間轉換

#在vue.js中有關預設路由不載入問題

以上是在Node.js中如何偵測連接埠是否被佔用的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板