Ubuntu配置nginx

  1. 安装 Nginx
bash 复制代码
sudo apt update && sudo apt upgrade -y
sudo apt install nginx -y
sudo systemctl enable --now nginx      # 开机自启并立即启动

  1. 放通防火墙
bash 复制代码
sudo ufw allow 'Nginx Full'            # 80+443 一次开
sudo ufw allow OpenSSH                 # 别把自己锁死
sudo ufw enable && sudo ufw status

  1. 验证默认页
    浏览器访问 http://<服务器公网IP>
    出现 "Welcome to nginx!" 说明安装成功。

  1. 准备自己的页面
    假设本地已打包出 dist 目录(含 index.html)。
bash 复制代码
# 上传到服务器
scp -r dist user@<IP>:/home/user/dist

# 移到标准位置并赋权
sudo mv /home/user/dist /var/www/myapp
sudo chown -R www-data:www-data /var/www/myapp
sudo chmod -R 755 /var/www/myapp

  1. 新建虚拟主机(ServerBlock)
bash 复制代码
sudo nano /etc/nginx/sites-available/myapp

内容(单页应用模板,直接粘):

nginx 复制代码
server {
    listen 80;
    server_name <IP 或域名>;     # 例:115.190.211.218  jf_domain.com

    root /var/www/myapp;         # 指向目标目录
    index index.html;

    location / {
        try_files $uri $uri/ /index.html;   # 前端路由回退
    }

    gzip on;
    gzip_types text/plain text/css application/javascript application/json;
    gzip_vary on;

    access_log /var/log/nginx/myapp.access.log;
    error_log  /var/log/nginx/myapp.error.log;
}

  1. 启用配置 & 去默认
bash 复制代码
sudo ln -sf /etc/nginx/sites-available/myapp /etc/nginx/sites-enabled/
sudo unlink /etc/nginx/sites-enabled/default   # 防止冲突
sudo nginx -t                                  # 语法检查
sudo systemctl reload nginx

  1. 本地测试(无域名时)
    Windows/Mac/Linux 客户端
    编辑 C:\Windows\System32\drivers\etc\hosts/etc/hosts

    115.190.211.218 jf_domain.com

浏览器访问 http://jf_domain.com 即可。


  1. 一键排错 checklist

| 仍欢迎页 | sites-enabled 是否只剩自己的链接 | unlink default & reload |

| 403 | 权限/目录在 /root | chown -R www-data:www-data /var/www/xxx |

| 404 | root 路径拼错或缺 try_files | 核对路径、加 try_files |

| 配置不生效 | sudo nginx -t 报错 | 按提示修正断链/语法 |


  1. 后续可选
  • HTTPS:
    sudo apt install certbot python3-certbot-nginx && sudo certbot --nginx -d 你的域名
  • 开机自启已做,日常重启:
    sudo systemctl restart nginx
  • 看实时日志:
    sudo tail -f /var/log/nginx/myapp.access.log
相关推荐
如意.7595 小时前
【Linux开发工具实战】Git、GDB与CGDB从入门到精通
linux·运维·git
Thera7776 小时前
C++ 高性能时间轮定时器:从单例设计到 Linux timerfd 深度优化
linux·开发语言·c++
yy55276 小时前
Nginx 性能优化与监控
运维·nginx·性能优化
爱吃土豆的马铃薯ㅤㅤㅤㅤㅤㅤㅤㅤㅤ7 小时前
Linux 查询某进程文件所在路径 命令
linux·运维·服务器
安当加密8 小时前
无需改 PAM!轻量级 RADIUS + ASP身份认证系统 实现 Linux 登录双因子认证
linux·运维·服务器
内卷焦虑人士9 小时前
Windows安装WSL2+Ubuntu 22.04
linux·windows·ubuntu
dddddppppp12310 小时前
qemu模拟的一个内核驱动 io口中断
linux
程序员老赵10 小时前
超全 Docker 镜像源配置指南|Windows/Mac/Linux一键搞定,拉镜像再也不卡顿
linux·后端·容器
门豪杰11 小时前
Ubuntu下安装Claude Code
linux·运维·ubuntu·claude·claude code
总要冲动一次11 小时前
离线安装 percona-xtrabackup-24
linux·数据库·mysql·centos