在 Linux 上优化 Node.js 应用的数据库连接,可以从以下几个方面入手:
连接池可以显著提高数据库连接的效率。大多数数据库驱动程序都支持连接池。
const { Pool } = require('pg');
const pool = new Pool({
user: 'your_user',
host: 'your_host',
database: 'your_database',
password: 'your_password',
port: 5432,
max: 20, // 最大连接数
idleTimeoutMillis: 30000, // 连接空闲时间
connectionTimeoutMillis: 2000, // 连接超时时间
});
根据你的应用需求和硬件资源,调整数据库的配置参数。
-- 调整最大连接数
ALTER SYSTEM SET max_connections = 200;
-- 调整共享缓冲区大小
ALTER SYSTEM SET shared_buffers = '25%';
-- 调整工作内存
ALTER SYSTEM SET work_mem = '4MB';
-- 重启数据库服务
sudo systemctl restart postgresql
确保你的数据库操作是异步的,以避免阻塞事件循环。
pool.query('SELECT * FROM users WHERE id = $1', [userId], (err, res) => {
if (err) {
console.error(err);
return;
}
console.log(res.rows);
});
使用监控工具来跟踪数据库连接的使用情况和性能指标。例如,使用 pg_stat_activity 视图来监控 PostgreSQL 的活动连接。
SELECT * FROM pg_stat_activity;
如果你的应用需要处理大量请求,可以考虑使用负载均衡器来分发请求到多个数据库实例。
使用缓存来减少对数据库的直接访问。例如,使用 Redis 或 Memcached 来缓存频繁查询的结果。
const redis = require('redis');
const client = redis.createClient();
client.on('error', (err) => {
console.error('Redis error:', err);
});
pool.query('SELECT * FROM users WHERE id = $1', [userId], (err, res) => {
if (err) {
console.error(err);
return;
}
if (res.rows.length > 0) {
client.setex(`user:${userId}`, 3600, JSON.stringify(res.rows[0]));
} else {
client.get(`user:${userId}`, (err, data) => {
if (data) {
console.log(JSON.parse(data));
} else {
// 从数据库查询并存入缓存
pool.query('SELECT * FROM users WHERE id = $1', [userId], (err, res) => {
if (err) {
console.error(err);
return;
}
client.setex(`user:${userId}`, 3600, JSON.stringify(res.rows[0]));
});
}
});
}
});
定期对数据库进行维护,包括索引优化、碎片整理和统计信息更新。
-- 更新统计信息
ANALYZE;
-- 重建索引
REINDEX INDEX your_index_name;
通过以上这些方法,你可以显著提高 Node.js 应用在 Linux 上的数据库连接性能和稳定性。