云服务器部署实战:ECS上从零搭建生产级Web服务全记录

简介: 本文手把手教你将本地Web项目部署到阿里云ECS服务器:从安全组配置、SSH初始化、Nginx反向代理,到应用进程管理(systemd)、安全加固(fail2ban/防火墙)及日志监控,全程覆盖Linux云服务器生产级部署要点,助新手快速实现“代码→公网服务”闭环。

前言

最近帮朋友把一个练手项目部署上线,顺手整理了一份在云服务器上的完整部署流程。如果你刚接触云服务器,或者之前只在本地跑过项目,本文会帮你把「写好的代码变成公网可访问的服务」这件事从头到尾串一遍。

我们以一台 Linux 云服务器为环境,最终目标:浏览器输入公网 IP,就能看到一个正常运行的 Web 服务,并且具备基本的运维安全配置。


为什么选云服务器

部署个人项目的选择其实不少:虚拟主机、Serverless、容器平台,甚至可以直接用 ngrok 内网穿透。

但长期来看,一台属于自己的云服务器有几个好处:

  • 完全可控:操作系统、软件版本、网络配置全由自己决定,不受平台约束。
  • 学习价值高:服务器运维本身就是一项硬技能,部署过程中你会接触到 Linux、网络、安全等知识。
  • 性价比:目前主流云厂商的经济型实例价格已经很低,对于个人开发和轻量项目来说成本几乎可以忽略。

实例选型:不花冤枉钱

选实例是第一步,也是最容易被「配置焦虑」带偏的一步。我的建议是:按实际负载选,不要提前为「以后可能用上」付费

如果是个人项目、博客、小型 API 服务,推荐从这个配置起步:

场景 推荐实例 典型配置
学习/测试/轻量服务 u2i 经济型 2核 4G,月成本极低
有一定并发需求 c9i 企业级 2核~4核,至强6处理器,单核性能提升了约 20%

u2i 经济型实例目前新用户的价格很低,适合拿来做实验环境。c9i 是阿里云第 9 代企业级实例,用了英特尔至强 6 处理器,支持 AMX 矩阵加速和 TDX 机密计算,如果你有 AI 推理或者对安全性要求较高的场景会更合适。

本文的演示环境基于阿里云 ECS如果你还没有账号,可以通过这个邀请链接注册:快速注册或登录地址,目前新用户有经济型实例优惠和百元套餐包,适合拿来做测试。


第一步:安全组配置——先想再动手

很多新人拿到服务器第一件事就是 SSH 上去装软件,这个顺序错了。先配置安全组

安全组是云服务器的第一道防火墙,决定了哪些流量能进、能出。默认的安全组通常只开放了 22 端口,我们需要额外放开 HTTP/HTTPS:

方向 端口 协议 授权对象 说明
入方向 22 TCP 你的固定IP或0.0.0.0/0 SSH管理
入方向 80 TCP 0.0.0.0/0 HTTP
入方向 443 TCP 0.0.0.0/0 HTTPS

在阿里云控制台 → ECS → 实例 → 安全组 → 配置规则 中添加入方向规则即可,操作直观,不需要命令行。

安全建议:22 端口的授权对象尽量限制为你自己的 IP,如果 IP 不固定,后续我们会用 fail2ban 做登录防护。


第二步:SSH 连接与系统初始化

安全组配好后,通过 SSH 连接服务器:

ssh root@你的公网IP

首次登录后,先做三件事:

1. 更新系统包

# CentOS/RHEL/Alibaba Cloud Linux
yum update -y

# Ubuntu/Debian
apt update && apt upgrade -y

2. 创建普通用户(避免长期使用 root)

useradd -m -s /bin/bash deploy
passwd deploy
usermod -aG wheel deploy   # CentOS
# usermod -aG sudo deploy  # Ubuntu

3. 配置 SSH 密钥登录(可选但强烈建议)

在本地生成密钥对,把公钥拷贝到服务器:

# 本地执行
ssh-keygen -t ed25519 -C "your-label"
ssh-copy-id -i ~/.ssh/id_ed25519.pub deploy@你的公网IP

验证密钥登录成功后,可以考虑禁止 root 登录和密码登录:

# /etc/ssh/sshd_config
PermitRootLogin no
PasswordAuthentication no
PubkeyAuthentication yes

# 重启 sshd
systemctl restart sshd

第三步:安装 Nginx 并配置反向代理

Web 服务的入口我们统一交给 Nginx,它负责接收外部请求并转发给后端的应用进程。

安装 Nginx

# Alibaba Cloud Linux / CentOS
yum install -y nginx

# Ubuntu
apt install -y nginx

启动并设置开机自启:

systemctl start nginx
systemctl enable nginx

此时浏览器访问 http://你的公网IP,应该能看到 Nginx 默认欢迎页。

配置反向代理

我们以一个 Node.js 应用为例,它监听在本地 127.0.0.1:3000,由 Nginx 转发:

# /etc/nginx/conf.d/myapp.conf

server {
   
    listen 80;
    server_name _;  # 暂时用 IP 访问,后续换成域名

    # 日志
    access_log /var/log/nginx/myapp_access.log;
    error_log /var/log/nginx/myapp_error.log;

    # 静态文件直接由 Nginx 返回
    location /static/ {
   
        root /home/deploy/myapp/public;
        expires 7d;
        add_header Cache-Control "public, immutable";
    }

    # API 请求转发到应用
    location / {
   
        proxy_pass http://127.0.0.1:3000;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;

        # 超时设置
        proxy_connect_timeout 60s;
        proxy_read_timeout 60s;
    }

    # 限制请求体大小(防止恶意上传)
    client_max_body_size 10m;
}

测试并重载配置:

nginx -t
systemctl reload nginx

几个值得注意的点

  • proxy_set_header X-Real-IPX-Forwarded-For 能保证后端拿到真实的客户端 IP,否则日志里全是 127.0.0.1。
  • 静态文件直接由 Nginx 返回,能大幅降低后端的请求量。
  • client_max_body_size 按自己业务设,默认 1m 对上传场景偏小。

第四步:部署应用进程

这里用一个最小 Node.js 服务演示,换成 Python Flask / Go / Java 的流程完全一样。

应用代码 (/home/deploy/myapp/server.js):

const http = require('http');

const server = http.createServer((req, res) => {
   
  const url = new URL(req.url, `http://${
     req.headers.host}`);

  if (url.pathname === '/api/health') {
   
    res.writeHead(200, {
    'Content-Type': 'application/json' });
    return res.end(JSON.stringify({
    status: 'ok', uptime: process.uptime() }));
  }

  res.writeHead(200, {
    'Content-Type': 'text/html; charset=utf-8' });
  res.end('<h1>Hello from ECS!</h1><p>部署成功。</p>');
});

server.listen(3000, '127.0.0.1', () => {
   
  console.log('Server running on port 3000');
});

用 systemd 管理应用进程

直接 node server.js & 不是生产级的做法 —— 进程挂了不会自动重启,服务器重启后也不会自动拉起。systemd 可以解决这些问题:

# /etc/systemd/system/myapp.service

[Unit]
Description=MyApp Web Service
After=network.target nginx.service

[Service]
Type=simple
User=deploy
WorkingDirectory=/home/deploy/myapp
ExecStart=/usr/bin/node /home/deploy/myapp/server.js
Restart=on-failure
RestartSec=5s
StandardOutput=journal
StandardError=journal
Environment=NODE_ENV=production

# 安全加固
NoNewPrivileges=yes
PrivateTmp=yes

[Install]
WantedBy=multi-user.target

启动:

systemctl daemon-reload
systemctl start myapp
systemctl enable myapp
systemctl status myapp   # 确认运行状态

第五步:安全加固

公网服务器是 24 小时暴露的,安全配置不能省略。以下是几条投入产出比最高的措施:

5.1 配置系统防火墙

安全组是第一层(网络层),系统防火墙(iptables/firewalld)是第二层(主机层),双层防护更稳妥:

# firewalld (CentOS/ALinux)
systemctl start firewalld
systemctl enable firewalld
firewall-cmd --permanent --add-service=ssh
firewall-cmd --permanent --add-service=http
firewall-cmd --permanent --add-service=https
firewall-cmd --reload

5.2 安装 fail2ban 防暴力破解

# yum install -y epel-release  # CentOS 需要先装 EPEL
yum install -y fail2ban
systemctl enable fail2ban
systemctl start fail2ban

默认配置就能阻挡 SSH 暴力登录,可调的参数(/etc/fail2ban/jail.local):

[DEFAULT]
bantime = 3600
findtime = 600
maxretry = 5

5.3 自动安全更新

生产环境的安全补丁不应靠人工记忆:

# CentOS/ALinux 安装自动更新工具
yum install -y dnf-automatic
systemctl enable --now dnf-automatic.timer

第六步:日志与监控

journalctl 是排查问题的第一入口:

# 查看应用日志
journalctl -u myapp -f

# 查看最近 50 条
journalctl -u myapp -n 50 --no-pager

# 按时间范围过滤
journalctl -u myapp --since "2026-06-16 10:00" --until "2026-06-16 12:00"

对于 Nginx,建议定期检查访问日志和错误日志:

tail -f /var/log/nginx/myapp_access.log
tail -f /var/log/nginx/myapp_error.log

如果想更进一步,可以考虑接入阿里云控制台的云监控,直接在网页上配置 CPU、内存、网络流量的告警阈值,不用自己搭监控栈。


第七步:可选的进一步优化

部署跑通之后,以下方向可以根据需要深入:

  • HTTPS:用 Let's Encrypt 的 certbot 免费签发证书,全自动续期
  • 数据库:比如 MySQL/PostgreSQL,建议用云数据库托管版本(RDS),省去备份和主从切换的心智负担
  • CI/CD:接入 GitHub Actions,每次 push 自动部署到 ECS
  • CDN:静态资源推到 OSS + CDN,减少服务器带宽压力

总结

这篇文章从零走通了一个完整的服务器部署流程:安全组配置 → SSH 初始化 → Nginx 反向代理 → 应用进程部署(systemd)→ 安全加固 → 日志监控。

核心思路是做减法:只装真正需要的软件,只开必须的端口,权限能降就降。这条原则在云服务器运维中反复被验证有效。


本文的实验环境使用阿里云 ECS 搭建。如果你也想动手试试,可以通过这个邀请链接注册,新用户目前有经济型实例和百元套餐的优惠,刚好够搭一套测试环境。


相关文章
|
4天前
|
缓存 测试技术 API
Qwen 3.7 Plus 与 Max 实测:性价比与多模态能力差异解析(2026)
2026 年 6 月 1 日,阿里悄无声息地发布了 Qwen 3.7 Plus,距 Qwen 3.7 Max 上线刚好 11 天。同样的 1M 上下文,同样的 35 小时自治上限。但价格才是头条:Plus 是 0.40/M输入,Max是 2.50/M——便宜约 6 倍——并且还能看图、看视频。Vision Arena 上 Plus 已经排到 #16。所以这周真正值得讨论的问题不是”要不要为视觉能力买单”,而是”Max 凭什么用 6 倍价格换来 2 个百分点的 benchmark 领先”。
|
5天前
|
人工智能 自然语言处理 文字识别
阿里云百炼Qwen3.7-Max简介:能力、优势、支持订阅计划参考
Qwen3.7-Max是阿里云百炼面向智能体时代推出的新一代旗舰模型,对标GPT-5.5、Claude Opus 4.7等闭源旗舰。该模型支持百万级token上下文窗口,具备顶级推理能力、多模态搜索与视觉理解增强、流式输出低延迟响应等核心优势,覆盖编程、办公、长周期自主执行等复杂场景。同时支持OpenAI接口兼容,便于系统快速迁移。用户可通过Token Plan团队或节省计划等订阅方式灵活调用,适合企业级高要求场景使用。
8637 37
阿里云百炼Qwen3.7-Max简介:能力、优势、支持订阅计划参考
|
5天前
|
JavaScript 定位技术 API
CodeGraph 爆火:编程 Agent 需要的不是更多上下文,而是一张提前画好的代码地图
CodeGraph 是一款爆火的本地代码智能工具,通过 tree-sitter 解析 AST 构建结构化知识图谱(存于 SQLite),为编程 Agent 提前生成“代码地图”。它显著降低 Agent 在中大型项目中的探索成本——实测工具调用减少71%、Token 降57%、速度提升46%,支持19+语言及主流框架路由识别,完全离线、无需 API Key。
654 4
CodeGraph 爆火:编程 Agent 需要的不是更多上下文,而是一张提前画好的代码地图
|
5天前
|
人工智能 运维 JavaScript
阿里云Qoder CN(原通义灵码)全解析 产品形态、版本划分与技术适配说明
在AI辅助开发与智能办公工具持续普及的当下,阿里云旗下原通义灵码正式更名为Qoder CN,同时延伸出QoderWork CN、Qoder CN CLI、Qoder CN Mobile等多款配套产品,形成覆盖代码开发、日常办公、终端交互、移动端使用的完整工具矩阵。Qoder CN核心定位为AI智能编码助手,深度适配主流代码编辑器、集成开发环境以及终端场景;QoderWork CN则偏向桌面端综合办公辅助,二者面向不同使用场景,划分了多个版本档位,搭配差异化资源配额、功能权限与计费规则,同时兼容多款主流大模型。
659 5
|
5天前
|
数据采集 人工智能 前端开发
让 Coding Agent 从黑盒到透明:阿里云 Agent 观测审计数据采集实践
AI Agent 规模化落地带来执行黑盒、行为难追溯、成本难度量三大难题。阿里云基于 OTel 标准,面向 Coding Agent、个人通用助理和框架型 Agent,推出 LoongSuite Pilot、插件及探针等无侵入采集方案,让 Agent 实现可看见、可分析、可审计、可治理。
727 148
|
5天前
|
存储 安全 Java
AgentScope Java 2.0:打造分布式、企业级智能体底座
AgentScope 2.0 面向分布式部署、稳定运行、权限安全等企业级需求全面升级,打造支持多租户隔离与长期稳定运行的企业级智能体底座。
|
5天前
|
人工智能 运维 自然语言处理
阿里云百炼Qwen3.7-Max模型详解:综合能力、核心优势与订阅计划参考指南
2026年,大模型技术持续向通用化、高性能、场景化方向迭代,阿里云百炼作为一站式大模型服务平台,持续推出迭代升级的模型产品,Qwen3.7-Max便是当前主力旗舰级大模型之一。该模型依托深度优化的底层架构与大规模训练数据,在文本理解、逻辑推理、多模态交互、代码生成、长文本处理等多个维度实现能力升级,同时搭配灵活的订阅计划体系,能够适配个人开发者、中小企业、大型企业、政企机构等不同类型用户的使用需求。
566 2
|
5天前
|
人工智能 缓存 自然语言处理
阿里Qwen3.7-Max评测:Agent能力显著提升,耗时与调用成本大幅下降
阿里云百炼推出面向智能体的旗舰大模型Qwen3.7-Max,具备长周期自主执行能力,显著提升编程、办公自动化等复杂任务处理水平;支持MCP集成与多框架兼容,并以限时5折+100万Tokens免费试用大幅降低使用门槛,助力企业高效落地AI应用。在阿里云百炼平台快速体验:https://t.aliyun.com/U/fPVHqY
1961 10
|
5天前
|
JSON 缓存 安全
通过 CC Switch 本地路由让 Codex CLI 接入 DeepSeek 等第三方模型
CC Switch 通过本地路由(`127.0.0.1:15721`)实现协议转换:将 Codex 的 Responses API 请求自动映射为 DeepSeek 等厂商的 Chat Completions 接口,兼容流式响应与工具调用,无需修改 Codex 源码,安全隔离 API Key。(239字)
1614 2
通过 CC Switch 本地路由让 Codex CLI 接入 DeepSeek 等第三方模型
|
5天前
|
人工智能 运维 API
2026年阿里云百炼通义千问Qwen3.7-plus深度介绍 功能特性、使用优势及618大促订阅方案指南
大模型技术的普及,让AI能力逐步融入个人办公、内容创作、代码编写、企业运营、教育培训等各类场景。不同定位的模型对应不同使用需求,旗舰级模型性能强劲但使用成本偏高,轻量化模型价格低廉却难以胜任复杂任务,而介于两者之间的中端主力模型,凭借均衡的能力、亲民的定价、广泛的场景适配性,成为绝大多数个人用户、小型团队、中小企业的首选。
773 1