亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

監控Nodejs的性能實例代碼

2024-05-06 16:53:00
字體:
來源:轉載
供稿:網友

下面給大家介紹下監控Nodejs的性能,

最近想監控一下Nodejs的性能。記錄分析Log太麻煩,最簡單的方式是記錄每個HTTP請求的處理時間,直接在HTTP Response Header中返回。

記錄HTTP請求的時間很簡單,就是收到請求記一個時間戳,響應請求的時候再記一個時間戳,兩個時間戳之差就是處理時間。

但是,res.send()代碼遍布各個js文件,總不能把每個URL處理函數都改一遍吧。

正確的思路是用middleware實現。但是Nodejs沒有任何攔截res.send()的方法,怎么破?

其實只要稍微轉換一下思路,放棄傳統的OOP方式,以函數對象看待res.send(),我們就可以先保存原始的處理函數res.send,再用自己的處理函數替換res.send:

app.use(function (req, res, next) {  // 記錄start time:  var exec_start_at = Date.now();  // 保存原始處理函數:  var _send = res.send;  // 綁定我們自己的處理函數:  res.send = function () {    // 發送Header:    res.set('X-Execution-Time', String(Date.now() - exec_start_at));    // 調用原始處理函數:    return _send.apply(res, arguments);  };  next();});‘

只用了幾行代碼,就把時間戳搞定了。

對于res.render()方法不需要處理,因為res.render()內部調用了res.send()。

調用apply()函數時,傳入res對象很重要,否則原始的處理函數的this指向undefined直接導致出錯。

實測首頁響應時間9毫秒:

x-execution-time

監控,Nodejs,性能,代碼

ps:下面給大家介紹下nodejs實現遠程桌面監控的方法,具體內容如下所示:

最近使用node實現了一個遠程桌面監控的應用,分為服務端和客戶端,客戶端可以實時監控服務端的桌面,并且可以通過鼠標和鍵盤來控制服務端的桌面。

監控,Nodejs,性能,代碼

 
監控,Nodejs,性能,代碼

 

這里因為我是用的同一臺電腦,所以監控畫面是這樣的,當然使用兩臺電腦一個跑 客戶端 ,一個跑 服務端 才有意義。

原理

其實這個應用的功能主要分為兩部分,一是實現監控,即在客戶端可以看到服務端的桌面,這部分功能是通過定時截圖來實現的,比如服務端一秒截幾次圖,然后通過 socketio 發送到客戶端,客戶端通過改變img的src來實現一幀幀的顯示最新的圖片,這樣就能看到動態的桌面了。監控就是這樣實現的。

另一個功能是控制,即客戶端對監控畫面的操作,包括鼠標和鍵盤的操作都可以在服務端的桌面真正的生效,這部分功能的實現是在electron的應用中監聽了所有的鼠標和鍵盤事件,比如keydown、keyup、keypress,mousedown、mouseup、mousemove、click等,然后通過socketio把事件傳遞到服務端,服務端通過 robot-js 來執行不同的事件,這樣就能使得客戶端的事件在服務端觸發了。

實現

原理講完,我們來具體實現一下( 源碼鏈接在這 )。

實現socket通信

首先,服務端和客戶端分別引入 socket.io 和 socket.io-client , 分別初始化

服務端:

const app = new Koa();const server = http.createServer(app.callback());createSocketIO(server);app.use((ctx): void => { ctx.body = 'please connect use socket';});server.listen(port, (): void => { console.log('server started at http://localhost:' + port);});
//createSocketIOconst io = socketIO(server, { pingInterval: 10000, pingTimeout: 5000, cookie: false });io.on('connect', (socket): void => { socket.emit('msg', 'connected');}

客戶端:

var socket = this.socket = io('http://' + this.ip + ':3000')socket.on('msg', (msg) => { console.log(msg)})socket.on('error', (err) => { alert('出錯了' + err)})

這樣,服務端和客戶端就通過socketio建立了鏈接。

實現桌面監控

之后我們首先要在服務端來截圖,使用 screenshot-desktop 這個包

const screenshot = require('screenshot-desktop')const SCREENSHOT_INTERVAL = 500;export const createScreenshot = (): Promise<[string, Buffer]> => { return screenshot({format: 'png'}).then((img): [string, Buffer] => { return [ img.toString('base64'), img]; }).catch((err): {} => { console.log('截圖失敗', err); return err; })}export const startScreenshotTimer = (callback): {} => { return setInterval((): void => { createScreenshot().then(([imgStr, img]): void => {  callback(['data:image/png;base64,' + imgStr, img]); }) }, SCREENSHOT_INTERVAL)}

然后通過socketio的emit來傳到客戶端:

startScreenshotTimer(([imgStr, img]): void => { io.sockets.emit('screenshot', imgStr);});

客戶端收到圖片后,設置到img的src上(這里是base64的圖片url):

<img  class="screenshot"  :src="screenshot"/>data () { return { screenshot: '' }}socket.on('screenshot', (data) => { this.screenshot = data})

其實這樣就已經實現了桌面監控了,有興趣的同學可以照著這個思路實現看看,并不是很麻煩。

當然這樣的方案是有問題的,因為我們需要知道服務端桌面尺寸的大小,然后根據這個來調整客戶端顯示的圖片尺寸。

實現這個細節是使用的 get-pixels 這個庫,可以讀取本地圖片文件的寬度高度等信息,所以我先把圖片寫入本地,然后又讀取出來,這樣獲取到的屏幕尺寸。

interface ScreenSize { width: number; height: number;}function getScreenSize(img): Promise<ScreenSize> { const imgPath = path.resolve(process.cwd(), './tmp.png'); fs.writeFileSync(imgPath, img); return new Promise((resolve): void => { getPixels(imgPath, function(err, pixels): void {  if(err) {  console.log("Bad image path")  return  }  resolve({  width: pixels.shape[0],  height: pixels.shape[1]  }); }); })}

然后通過socektio傳遞給客戶端

getScreenSize(img).then(({ width, height}) => { io.sockets.emit('screensize', { width, height })});

客戶端收到之后調整圖片大小就可以了

<img  class="screenshot"  :src="screenshot" :style="screenshotStyle"/>data () { return { screenshot: '', screenshotStyle: '', }}socket.on('screensize', (screensize) => { this.screenshotStyle = {'width': screensize.width + 'px', 'height': screensize.height + 'px'}})

至此已經實現了桌面監控,并且圖片尺寸和服務端屏幕的尺寸是一致的。

這里還有一個細節,就是獲取到的圖片大小是物理像素,而客戶端設置的px是設備無關像素,也就是要除以dpr才是px的值。這里需要獲取dpr,因為目前只是在mac下用,所以直接除以2了。

實現遠程控制

代碼寫到這里,客戶端的electron應用中已經可以實時顯示服務端的桌面了。(當然像輸入ip的彈框,以及electron-vue和typescript等和主要邏輯無關的細節就不展開了。)

接下來我們要實現遠程控制,也就是監聽事件,傳遞事件,執行事件這幾部分。

首先我們定義一下傳遞的事件的格式:

interface MouseEvent { type: string; buttonType: string; x: number; y: number;}interface KeyboardEvent { type: string; keyCode: number; keyName: string;}

鼠標事件MouseEvent,type為鼠標事件的類型,具體的值包括mousedown、mouseup、mousemove、click、dblclick,buttonType指的是鼠標的左鍵還是右鍵,值為 left 或 right,x和y是具體的坐標。

鍵盤事件KeyboardEvent,type為鍵盤事件的類型,具體的值包括keydown、keyup、keypress,keyCode為鍵盤碼,keyName為鍵的名字。

接下來我們要在客戶端監聽事件:

<img  class="screenshot"  :src="screenshot" :style="screenshotStyle" @mousedown="handleMouseEvent" @mousemove="handleMouseEvent"  @mouseup="handleMouseEvent" @click="handleMouseEvent" @dblclick="handleMouseEvent" />window.onkeypress = window.onkeyup = window.onkeydown = this.handleKeyboardEvent

通過socekt把事件傳遞到服務端

handleKeyboardEvent (e) { this.socket && this.socket.emit('userevent', { type: 'keyboard', event: { type: e.type, keyName: e.key, keyCode: e.keyCode } }) }, handleMouseEvent (e) { this.socket && this.socket.emit('userevent', { type: 'mouse', event: { type: e.type, buttonType: e.buttons === 2 ? 'right' : 'left', x: e.clientX, y: e.clientY } }) },

然后在服務端把事件取出來執行,執行事件使用的是 robot-js :

const { Mouse, Point, Keyboard } = require('robot-js');interface MouseEvent { type: string; buttonType: string; x: number; y: number;}interface KeyboardEvent { type: string; keyCode: number; keyName: string;}export default class EventExecuter { public mouse; public keyboard; public constructor(){ this.mouse = new Mouse(); this.keyboard = new Keyboard(); } public executeKeyboardEvent(event: KeyboardEvent): void { switch(event.type) {  case 'keydown':  this.keyboard.press(event.keyCode);  break;  case 'keyup':  this.keyboard.release(event.keyCode);  break;  case 'keypress':  this.keyboard.click(event.keyCode);  break;  default: break; } } public executeMouseEvent(event): void { Mouse.setPos(new Point(event.x, event.y)); const button = event.buttonType === 'left' ? 0 : 2 switch(event.type) {  case 'mousedown':  this.mouse.press(button);  break;  case 'mousemove':  break;  case 'mouseup':   this.mouse.release(button);  break;  case 'click':   this.mouse.click(button);  break;  case 'dblclick':   this.mouse.click(button);  this.mouse.click(button);  break;  default: break; } } public exectue(eventInfo): void { console.log(eventInfo); switch (eventInfo.type) {  case 'keyboard':  this.executeKeyboardEvent(eventInfo.event);  break;  case 'mouse':  this.executeMouseEvent(eventInfo.event);  break;  default: break; } }}

至此,桌面監控和遠程控制的客戶端還有服務端的部分,以及兩端的通信都已經實現了。思路其實并不麻煩,但細節還是很多的。有興趣的同學可以把代碼下下來跑跑試試,或者按著這個思路自己實現一遍,還是挺好玩的。

總結

以上所述是小編給大家介紹的nodejs實現遠程桌面監控的方法,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久色乳综合思思在线视频| 久久在线免费观看视频| 久久久久久久激情视频| 欧美性资源免费| 欧美国产日韩视频| 欧美丰满少妇xxxxx做受| 九九久久综合网站| 国产精品久久久久久久av大片| 最近2019年好看中文字幕视频| 国产欧美精品在线| 91国内揄拍国内精品对白| 中文字幕国产日韩| 欧美亚洲激情视频| 中文字幕欧美日韩在线| 一区二区三区高清国产| 亚洲欧美日韩爽爽影院| 国产成人一区二区三区电影| 成人久久一区二区三区| 另类专区欧美制服同性| 亚洲综合日韩中文字幕v在线| 国产97人人超碰caoprom| 播播国产欧美激情| 欧美成人免费视频| 久久网福利资源网站| 奇米成人av国产一区二区三区| 国产欧美一区二区三区视频| 国产精品欧美一区二区| 亚洲美女av在线播放| 少妇激情综合网| 欧美自拍视频在线观看| 成人网在线免费看| 日韩av不卡在线| 久热精品视频在线观看一区| 91欧美日韩一区| 国产亚洲日本欧美韩国| 欧美一区三区三区高中清蜜桃| 亚洲xxxx在线| 欧美在线观看一区二区三区| 久久久久久久久久久免费精品| 国产日韩欧美91| 欧美亚洲视频在线看网址| 欧美精品videosex极品1| 欧美电影免费看| 91麻豆国产精品| 久久久久久久久久久久久久久久久久av| 国产一区二区欧美日韩| 精品国产美女在线| 欧美激情一二三| 黑人巨大精品欧美一区二区三区| 国产精品99蜜臀久久不卡二区| 午夜精品美女自拍福到在线| 欧美丝袜一区二区| 亚洲影院色在线观看免费| 日韩精品中文字幕有码专区| 亚洲精品国产品国语在线| 欧美日韩视频免费播放| 日韩av在线电影网| 欧美理论电影在线观看| 亚洲aaaaaa| 欧美激情视频给我| 色偷偷综合社区| 欧美成人剧情片在线观看| 日韩电影在线观看免费| 亚洲欧洲国产伦综合| 日韩欧美aⅴ综合网站发布| 91视频国产精品| 国产成人在线视频| 亚洲国产精品视频在线观看| 亚洲成人精品视频在线观看| 亚洲国产私拍精品国模在线观看| 大伊人狠狠躁夜夜躁av一区| 欧美成人免费观看| www.日韩不卡电影av| 日韩电影在线观看永久视频免费网站| 欧美精品做受xxx性少妇| 国产精品免费一区二区三区都可以| 亚洲国产黄色片| 国产91精品最新在线播放| 亚洲第一天堂av| 欧美激情国产高清| 亚洲精品久久久久中文字幕欢迎你| 亚洲影视中文字幕| 国产欧洲精品视频| 97国产精品久久| 亚洲国产成人精品一区二区| 日韩在线视频播放| 91极品视频在线| 在线观看亚洲区| 国产成人精彩在线视频九色| 久久久av电影| 久久精品久久精品亚洲人| 2019精品视频| 欧美日韩午夜视频在线观看| 狠狠躁天天躁日日躁欧美| 久久欧美在线电影| 欧美有码在线观看| 欧美在线观看一区二区三区| 久久不射热爱视频精品| 日韩视频中文字幕| 亚洲字幕一区二区| 国产精品免费久久久久影院| 成人午夜在线观看| 国产视频精品久久久| 一区二区三区视频免费| 午夜精品免费视频| 亚洲人成电影网站| 91精品久久久久久久久| 日韩在线观看免费高清完整版| 亚洲精品日韩激情在线电影| 欧美特级www| 久久69精品久久久久久国产越南| 国产精品爱啪在线线免费观看| 一区二区国产精品视频| 久久久成人的性感天堂| 日韩欧美中文第一页| 欧美网站在线观看| 国产福利视频一区| 91成人在线播放| 91高清免费视频| 国产精品一区二区女厕厕| 国产精品久久久久久五月尺| 中国china体内裑精亚洲片| 青草青草久热精品视频在线观看| 日韩精品视频免费专区在线播放| 亚洲欧美中文另类| 国产精品成人aaaaa网站| 欧美大肥婆大肥bbbbb| 一区二区三区高清国产| 精品久久久999| 成人精品福利视频| 日韩在线激情视频| 97不卡在线视频| 欧美激情精品久久久久久变态| 国产一区二区三区毛片| 欧美激情国产高清| 热re91久久精品国99热蜜臀| 欧美黑人性生活视频| 日韩免费黄色av| 97国产在线观看| 亚洲女人天堂av| 福利二区91精品bt7086| 亚洲精品狠狠操| 国产91精品黑色丝袜高跟鞋| 日韩中文在线中文网三级| 91sa在线看| 性日韩欧美在线视频| 国产偷亚洲偷欧美偷精品| 欧美人成在线视频| 精品国产一区久久久| 久久国产精品久久国产精品| 久久91亚洲精品中文字幕| 亚洲精品美女在线观看播放| 亚洲乱亚洲乱妇无码| 成人淫片在线看| 久久亚洲精品毛片| 日韩精品视频在线播放| 日日摸夜夜添一区| 精品少妇v888av| 成人黄在线观看| 亚洲级视频在线观看免费1级| 亚洲精品美女久久| 51午夜精品视频| 亚洲欧美自拍一区| 久久国产精品久久精品|