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工具進行全鏈路性能監控,快速定位問題。