Почему socket.io делает процессор на сервере 100%?Nuxt + koaJS - PullRequest
0 голосов
/ 02 марта 2019

У меня проблема с SocketIO + NuxtJS.В производственном режиме иногда загрузка ЦП сервера внезапно становится 100%, так как я подключаю сервер socketIO.Пожалуйста, помогите мне, если вы знаете об этой проблеме.thx ..

Возможно, я думаю, что эта проблема связана с событием отключения "Опрос транспорта".Я отлаживал логи сервера сокетов 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)
…

Мой код FrontEnd

// 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

...