1. 选择合适的Node.js版本
使用最新的稳定版或LTS(长期支持)版本,新版本通常包含性能改进、bug修复和安全更新,能显著提升应用稳定性和执行效率。
2. 调整系统内核参数优化网络性能
修改/etc/sysctl.conf
文件,调整以下关键参数以提升网络连接处理能力:
net.ipv4.tcp_tw_reuse = 1
:启用TCP连接复用,减少TIME_WAIT状态的连接占用;net.ipv4.tcp_max_syn_backlog = 8192
:增加半连接队列长度,应对高并发连接请求;net.core.somaxconn = 1024
:增大监听端口的最大连接队列长度,避免连接被拒绝;net.ipv4.ip_local_port_range = "1024 65535"
:扩大本地端口范围,支持更多并发外出连接。sysctl -p
使配置生效。3. 优化Node.js内存配置
通过--max-old-space-size
参数调整堆内存上限(单位:MB),避免因内存不足导致进程崩溃。例如,将内存限制提升至4GB:
node --max-old-space-size=4096 app.js
若使用PM2进程管理器,可在ecosystem.config.js
中配置:
module.exports = {
apps: [{
name: 'my-app',
script: 'app.js',
max_memory_restart: '4G' // 内存超过4GB时自动重启
}]
};
同时,避免内存泄漏:及时移除无用的事件监听器、清理定时器、避免全局变量滥用。
4. 利用多进程提升并发处理能力
const cluster = require('cluster');
const os = require('os');
if (cluster.isMaster) {
for (let i = 0; i < os.cpus().length; i++) cluster.fork(); // 创建与CPU核心数相同的Worker
cluster.on('exit', (worker) => console.log(`Worker ${worker.process.pid} died`));
} else {
require('./app.js'); // Worker进程启动应用
}
cluster
模式(exec_mode: 'cluster'
)自动管理多进程,支持负载均衡和自动重启,简化运维流程。5. 使用反向代理服务器(如Nginx)
配置Nginx作为反向代理,可实现以下优化:
Round Robin
、Least Connections
等策略将请求分发到多个Node.js实例;server {
listen 80;
server_name example.com;
location /static/ {
alias /var/www/static/; # 静态文件缓存路径
expires 30d; # 缓存30天
}
location / {
proxy_pass http://localhost:3000; # 转发到Node.js实例
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
}
}
```。
**6. 代码层面优化**
- **异步编程**:使用`async/await`或`Promise`替代回调函数,避免阻塞事件循环;
- **流(Stream)处理**:处理大文件或大量数据时,使用流(如`fs.createReadStream`、`res.write`)分块读写,减少内存占用;
- **数据库优化**:为常用查询字段创建索引,使用连接池(如`mysql2`的`pool`)管理数据库连接,避免频繁建立/断开连接;
- **缓存策略**:使用`node-cache`(内存缓存)或`Redis`(分布式缓存)缓存频繁访问的数据,减少重复计算或数据库查询。
**7. 监控与性能分析**
- **内置工具**:使用`--inspect`参数启动应用,通过Chrome DevTools分析CPU、内存使用情况,检测性能瓶颈;
- **第三方工具**:使用PM2的`pm2 monit`命令实时监控应用状态(CPU、内存、日志),或使用New Relic、Datadog等APM工具进行全链路性能监控,快速定位问题。