-
-
Notifications
You must be signed in to change notification settings - Fork 1
/
server.js
57 lines (46 loc) · 1.51 KB
/
server.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
const node server.js
const express = require('express');
const http = require('http');
const socketIo = require('socket.io');
const mysql = require('mysql');
const app = express();
const server = http.createServer(app);
const io = socketIo(server);
// Configuração do banco de dados
const db = mysql.createConnection({
host: 'localhost', // ou o endereço do seu servidor de banco de dados
user: 'usuario',
password: 'senha',
database: 'database'
});
db.connect((err) => {
if (err) throw err;
console.log('Conectado ao banco de dados!');
});
// Rota principal
app.get('/', (req, res) => {
res.sendFile(__dirname + '/index.html');
});
// Lógica para atualizar informações em tempo real
io.on('connection', (socket) => {
console.log('Um usuário se conectou');
// Função para buscar dados do banco de dados
const fetchData = () => {
db.query('SELECT * FROM sua_tabela', (err, results) => {
if (err) throw err;
socket.emit('data', results); // Envia os dados para o cliente
});
};
// Chama a função inicialmente
fetchData();
// Configura um intervalo para atualizar os dados a cada 10 segundos
const intervalId = setInterval(fetchData, 10000);
socket.on('disconnect', () => {
console.log('Usuário desconectado');
clearInterval(intervalId); // Limpa o intervalo ao desconectar
});
});
const PORT = process.env.PORT || 3000;
server.listen(PORT, () => {
console.log(`Servidor rodando na porta ${PORT}`);
});