1. 前置说明与订购建议
小节1: 区域与带宽选取 - 选新加坡(SG)节点以保证亚太低延迟;带宽按业务吞吐选1-5Mbps或更高。
小节2: 镜像与规格 - 建议Ubuntu 22.04 LTS,2vCPU / 4GB RAM 起步,SSD存储,快照功能可选。
小节3: 准备工作 - 本文假设有本地Linux/Mac终端或Windows + WSL/PowerShell,已安装ssh与scp。
2. 系统初始化(首日必做)
小节1: 登录 - 使用提供的控制台密码首次登录后立即更改:ssh root@vps_ip。
小节2: 创建非root用户并配置sudo:
命令:adduser devuser && usermod -aG sudo devuser
切换:su - devuser
小节3: 时区与本地化:sudo timedatectl set-timezone Asia/Singapore && sudo locale-gen en_US.UTF-8
3. SSH密钥与安全强化
小节1: 在本地生成密钥:ssh-keygen -t ed25519 -C "dev@yourdomain",然后 ssh-copy-id devuser@vps_ip。
小节2: 禁用root、禁止密码登录并重启sshd:
sudo sed -i 's/PermitRootLogin yes/PermitRootLogin no/' /etc/ssh/sshd_config
sudo sed -i 's/#PasswordAuthentication yes/PasswordAuthentication no/' /etc/ssh/sshd_config
sudo systemctl reload sshd
小节3: 安装fail2ban:sudo apt update && sudo apt install -y fail2ban
4. 防火墙与基础网络配置
小节1: 使用ufw快速配置:
sudo apt install -y ufw
sudo ufw allow OpenSSH && sudo ufw allow 80 && sudo ufw allow 443
sudo ufw enable
小节2: 常用端口说明 - 22(SSH),80/443(HTTP/HTTPS),如果有应用自定义端口一并放行。
小节3: 开启IP转发或NAT时注意net.ipv4.ip_forward设置。
5. 安装运行时与包管理
小节1: Node.js(示例):
curl -fsSL https://deb.nodesource.com/setup_18.x | sudo -E bash -
sudo apt install -y nodejs build-essential
小节2: Python(示例):
sudo apt install -y python3 python3-venv python3-pip
小节3: 建议使用nvm/pyenv在开发环境保持多版本兼容。
6. 部署方式选择:原生 vs 容器
小节1: 本文聚焦原生部署(直接在系统上运行),优点:性能、调试简单;缺点:依赖管理需谨慎。
小节2: 若选择Docker,请安装docker-ce并参考官方镜像部署;原生建议用虚拟环境和systemd管理服务。
小节3: 依赖隔离:Node可用pm2或systemd,Python用venv + gunicorn + systemd。
7. 示例:Node.js应用原生部署完整步骤
小节1: 上传代码 - 使用git clone或scp传输:git clone
/var/www/myapp。
小节2: 安装依赖并构建:
cd /var/www/myapp && npm ci && npm run build
小节3: 创建systemd服务文件 /etc/systemd/system/myapp.service:
[Unit]\nDescription=MyApp\nAfter=network.target
[Service]\nUser=www-data\nWorkingDirectory=/var/www/myapp\nExecStart=/usr/bin/node /var/www/myapp/dist/index.js\nRestart=always\nEnvironment=NODE_ENV=production
然后 sudo systemctl daemon-reload && sudo systemctl enable --now myapp
8. 反向代理与HTTPS(Nginx + Let's Encrypt)
小节1: 安装Nginx:sudo apt install -y nginx && sudo systemctl enable --now nginx。
小节2: 配置站点 /etc/nginx/sites-available/myapp:
server { listen 80; server_name example.com; location / { proxy_pass http://127.0.0.1:3000; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; } }
启用并测试:sudo ln -s ... && sudo nginx -t && sudo systemctl reload nginx
小节3: 申请证书:
sudo apt install -y certbot python3-certbot-nginx
sudo certbot --nginx -d example.com
9. 日志、监控与日志轮转
小节1: systemd日志:使用 journalctl -u myapp -f 查看实时日志。
小节2: 配置logrotate:/etc/logrotate.d/myapp,按日或按大小切分。
小节3: 简单监控:安装netdata或使用Prometheus + Grafana,或至少用htop、iotop观察资源。
10. 常用调试技巧(实战)
小节1: 进程调试:ps aux | grep myapp,使用 strace -p PID 跟踪系统调用。
小节2: 网络/端口问题:ss -tulpn | grep 3000,curl -I http://127.0.0.1:3000 检查响应。
小节3: 日志排查:sudo journalctl -u myapp --since "1 hour ago",查看Nginx错误日志 /var/log/nginx/error.log。
11. 远程调试与开发体验提升
小节1: VSCode Remote-SSH:在本地打开远程文件、断点调试;配置 launch.json 指向远程运行的端口。
小节2: Node远程调试:启动时加 --inspect=0.0.0.0:9229(注意绑定与防火墙),本地用VSCode附加。
小节3: Python调试:使用 debugpy,pip install debugpy 并在启动时加入 -m debugpy --listen 0.0.0.0:5678。
12. 备份、快照与恢复策略
小节1: 定期快照:在VPS控制面板开启自动快照或手动创建。
小节2: 应用级备份:数据库(mysqldump / pg_dump)、静态文件 rsync 到另一台备份服务器或对象存储。
小节3: 恢复演练:定期在临时实例上演练恢复步骤,保证文档与脚本有效。
13. 性能优化与成本控制小贴士
小节1: 使用Nginx缓存静态资源、gzip压缩并开启HTTP/2。
小节2: 适时使用swap或调整内核参数,监控OOM日志,避免频繁重启。
小节3: 按需调配实例规格,利用自动快照/弹性公网IP避免额外迁移成本。
14. 问:新加坡VPS部署原生应用,最容易被忽视的安全项是什么?
答:通常是SSH和证书管理。很多人只改了密码却没禁用密码登录或启用密钥,建议强制使用SSH密钥、禁用root登录并启用fail2ban与ufw;证书要设置自动续期(certbot renew)并监控到期提醒。
15. 问:如何在不重启服务的情况下部署小改动(零停机)?
答:可采用反向代理加两套后台实例(蓝绿部署)或使用systemd socket activation/rolling restart。简易方法是先在新端口启动新版本,测试通过后切换Nginx proxy_pass 到新端口,再停止旧进程。
16. 问:遇到不可预期的高CPU/内存占用如何快速定位?
答:先用 top/htop 确认占用进程,使用 strace -p PID 或 pstack(对于C/C++)定位卡住点;Node可用 clinic 或内存快照工具,Python 可用 tracemalloc。结合 journalctl 和应用日志查看异常请求或死循环。
来源:面向开发者的新加坡vps 原生环境部署与调试经验分享