摘要:為了解決工具起多個服務(wù)的時候端口被占用的情況。分享研究的代碼片段。
為了解決 ssr 工具 起多個服務(wù)的時候端口被占用的情況。分享研究的代碼片段。
// 檢測port是否被占用 function probe(port, callback) { var server = net.createServer().listen(port) var calledOnce = false var timeoutRef = setTimeout(function () { calledOnce = true callback(false,port) }, 2000) timeoutRef.unref() var connected = false server.on("listening", function() { clearTimeout(timeoutRef) if (server) server.close() if (!calledOnce) { calledOnce = true callback(true,port) } }) server.on("error", function(err) { clearTimeout(timeoutRef) var result = true if (err.code === "EADDRINUSE") result = false if (!calledOnce) { calledOnce = true callback(result,port) } }) }
使用例子:
function server(_port){ var pt = _port || __port; probe(pt,function(bl,_pt){ // 端口被占用 bl 返回false // _pt:傳入的端口號 if(bl === true){ // ssr(_pt) server = http.createServer(connListener); server = server.listen(parseInt(_pt, 10)); console.log(" Static file server running at" + " => http://localhost:" + _pt + " "); }else{ server(_pt+1) } }) }
關(guān)注公眾號
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/91535.html
摘要:如果一個即時定時器是被一個正在執(zhí)行的回調(diào)排入隊列的,則該定時器直到下一次事件循環(huán)迭代才會被觸發(fā)。參數(shù)描述在事件循環(huán)的當(dāng)前回合結(jié)束時要調(diào)用的函數(shù)。事件輪詢隨后的調(diào)用,會在任何事件包括定時器之前運行。 系列文章 Nodejs高性能原理(上) --- 異步非阻塞事件驅(qū)動模型Nodejs高性能原理(下) --- 事件循環(huán)詳解 前言 終于開始我nodejs的博客生涯了,先從基本的原理講起.以前寫...
摘要:前言使用過進(jìn)行項目開發(fā)的同學(xué),一定知道或者使用過腳手架,他能夠很好的搭建項目結(jié)構(gòu)和工程,讓我們能夠把足夠的精力放在業(yè)務(wù)開發(fā)上。對象提供一系列屬性,用于返回系統(tǒng)信息返回當(dāng)前進(jìn)程的命令行參數(shù)數(shù)組。 前言 使用過 vue 進(jìn)行項目開發(fā)的同學(xué),一定知道或者使用過 vue-cli 腳手架,他能夠很好的搭建項目結(jié)構(gòu)和工程,讓我們能夠把足夠的精力放在業(yè)務(wù)開發(fā)上。也正是因為這樣,很多時候我們會因為項目...
摘要:當(dāng)這些隱藏于幕后的工作者處理完委托給它們的事件后,它們會觸發(fā)綁定在這些事件上的回調(diào)函數(shù)去通知。習(xí)慣回調(diào)是一個單線程事件驅(qū)動的運行環(huán)境,也就是說,在里,任何事都是對事件的響應(yīng)。 原文地址:https://codeburst.io/the-only-nodejs-introduction-youll-ever-need-d969a47ef219 作者:vick_onrails 摘要:這...
摘要:前言是一個微服務(wù)工具集,它賦予系統(tǒng)易于連續(xù)構(gòu)建和更新的能力。這個對象既包含某個微服務(wù)所需要調(diào)取另一個微服務(wù)的特征,同時也包含傳參。和微服務(wù)發(fā)現(xiàn)有些類似不過是用模式代替,目前為止模式是完全可以實現(xiàn)服務(wù)發(fā)現(xiàn)功能,但是否更加靈活還有待去挖掘。 前言 seneca是一個nodejs微服務(wù)工具集,它賦予系統(tǒng)易于連續(xù)構(gòu)建和更新的能力。下面會逐一和大家一起了解相關(guān)技術(shù)入門以及實踐。 這里插入一段硬廣...
摘要:每家公司在前端項目發(fā)布體系可能不盡相同,本篇文章僅僅介紹袋鼠云的前端發(fā)布體系,希望能對大家能有所啟發(fā)。目前袋鼠云采用的是前后端分離的方式,但是開發(fā)中還是比較依賴后端的,接口數(shù)據(jù)還不是很完善。 前言 在目前的大趨勢下,前端和后端解耦已經(jīng)是一個業(yè)界的趨勢。前端和后端一旦解耦之后,前端的項目和后端的項目便可以自己發(fā)布,互不影響。這樣極大地提高工作效率,免去了很多互相等待的時間。每家公司在前端...
閱讀 1178·2021-09-10 10:51
閱讀 909·2019-08-30 15:53
閱讀 2735·2019-08-30 12:50
閱讀 986·2019-08-30 11:07
閱讀 1998·2019-08-30 10:50
閱讀 3607·2019-08-29 18:47
閱讀 1319·2019-08-29 18:44
閱讀 1607·2019-08-29 17:01