1. 系统账户与权限管理
for temp in $(cut -d ":" -f 1 /etc/passwd | grep -v "root"); do passwd -l $temp; done
。nodeapp
)及同组,避免以root身份运行(降低权限滥用风险)。命令:sudo groupadd nodeapp; sudo useradd -g nodeapp nodeapp -s /bin/false
。/etc/pam.d/login
)限制TTY终端登录尝试次数(如auth required pam_tally2.so deny=5 unlock_time=300
),防止暴力破解。2. 系统级安全加固
ufw
(Uncomplicated Firewall)限制访问,仅开放必要端口(如HTTP 80、HTTPS 443)。命令:sudo ufw allow 22/tcp; sudo ufw allow 80/tcp; sudo ufw allow 443/tcp; sudo ufw enable
。/var/www
目录)。命令:setenforce 1
(临时启用);修改/etc/selinux/config
(永久生效)。3. Node.js应用安全配置
--uid
和--gid
参数指定专用用户(如PM2启动时:pm2 start app.js --uid nodeapp --gid nodeapp
),或使用nvm
在用户级别安装Node.js。X-Frame-Options
(防点击劫持)、X-XSS-Protection
(防XSS)等头,提升应用安全性。示例:const helmet = require('helmet'); app.use(helmet());
。validator
库或正则表达式过滤特殊字符,防止SQL注入、XSS攻击。eval()
、new Function()
等可执行字符串代码的函数,防止远程代码执行(RCE)。4. 依赖与版本管理
curl -sL https://deb.nodesource.com/setup_20.x | sudo -E bash -; sudo apt-get install -y nodejs
。nvm
(Node Version Manager)安装和管理多版本Node.js,便于切换和升级(避免系统级权限问题)。命令:sudo npm install -g n; sudo n latest
。npm audit
检查依赖项安全漏洞,npm update
更新到最新版本;或使用Snyk
等工具自动化漏洞扫描。5. HTTPS与加密配置
server {
listen 443 ssl;
server_name yourdomain.com;
ssl_certificate /etc/letsencrypt/live/yourdomain.com/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/yourdomain.com/privkey.pem;
location / {
proxy_pass http://localhost:3000;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
}
}
```。
dotenv
库加载.env
文件中的敏感信息(如数据库密码、API密钥),避免硬编码在代码中。命令:require('dotenv').config(); const dbPassword = process.env.DB_PASSWORD;
。6. 日志与监控
/var/log/my-node-app
),设置用户/组权限(chown nodeapp:nodeapp /var/log/my-node-app; chmod 750 /var/log/my-node-app
);使用Winston
或Bunyan
等日志库控制日志级别(如info
、error
)。/etc/logrotate.d/my-node-app
配置文件,设置日志轮转(每天轮转、保留14天、压缩旧日志)。示例配置:/var/log/my-node-app/*.log {
daily
missingok
rotate 14
compress
delaycompress
notifempty
create 640 nodeapp nodeapp
sharedscripts
postrotate
[ ! -f /var/run/my-node-app.pid ] || kill -USR1 `cat /var/run/my-node-app.pid`
endscript
}
```。
pm2
的监控功能(pm2 monit
)或Prometheus
+Grafana
监控应用性能(CPU、内存、请求量),设置异常告警(如邮件、短信)。7. 其他安全措施
express-rate-limit
中间件限制请求频率(如每分钟最多60次),防止DDoS攻击。示例:const rateLimit = require('express-rate-limit'); app.use(rateLimit({ windowMs: 60 * 1000, max: 60 }));
。cors
中间件限制允许的域名(如origin: 'https://yourdomain.com'
)、方法(如GET,POST
),防止恶意跨域访问。defaultSrc: ["'self'"]
),减少XSS攻击风险。