为什么socket.io使服务器的CPU为100%? Nuxt + koaJS

时间:2019-03-02 05:25:09

标签: node.js vue.js socket.io nuxt.js koa

我对SocketIO + NuxtJS有问题。 在生产模式下,自从我安装socketIO服务器以来,有时服务器的CPU使用率突然达到了100%。如果您知道此问题,请帮助我。 thx ..

也许我想这个问题与断开事件“ Transport Polling”有关。我调试了套接字io服务器日志,所有日志的最后一行都是user disconnected: H2X9WQSD6DSzMFT-AAEO, polling

我的后端代码

// server.js
…
const http = require('http')
const app = new Koa()
const socket = require('Socket.IO')
… 
const server = http.createServer(app.callback())
const io = socket(server)
…
io.sockets.on('connection', function(socket) {
    console.log('a user connected’)
    socket.on('message', message => {
        io.sockets.emit('message', message)
    })
    socket.on('disconnect', () => {
      console.log('user disconnected: ' + socket.id + ', ' + socket.handshake.query.transport)
    })
})
server.listen(port)
…

我的前端代码

// plugin/socket.js

import Vue from 'vue'
import io from 'Socket.IO-client'
Vue.prototype.$socket = io(process.env.HOST_URL)

// nuxt.config.js
...
plugins: [
 { src: '~/plugins/socket.js', ssr: false },
 ],
...

// pages/test.vue
...
export default {
 data() {
    return { messages: [], message: '' }
 },
 mounted() {
    this.$socket.on('message', message => {
        this.messages.push(message)
    })
 },
 beforeDestroy() {
    this.$socket.off('message')
 },
 methods: {
    //chat to server 
    handleChat() {
        if (this.message) {
            this.$socket.emit('message', this.message)
            this.message = ''
        }
    },
 }
}

CPU 100% Image

0 个答案:

没有答案