想要使用 Nginx 部署多个前端项目,可行吗?

简介: 想要使用 Nginx 部署多个前端项目,可行吗?

在实际的 web 开发中,经常需要同时部署多个前端项目。Nginx 是一款高性能的 Web 服务器,同时也是一款反向代理服务器,可以通过配置多个虚拟主机来部署多个前端项目。本文将介绍如何使用 Nginx 部署多个前端项目。

安装 Nginx

首先,在 Ubuntu 系统上安装 Nginx,可以通过以下命令进行安装:

sudo apt update
sudo apt install nginx

安装完成后,可以使用以下命令启动 Nginx:

sudo systemctl start nginx

配置 Nginx

创建虚拟主机

在 Nginx 中,每个网站被称为一个虚拟主机。要创建一个虚拟主机,需要在 Nginx 的配置文件中添加一个新的 server 块。默认情况下,Nginx 的配置文件存储在 /etc/nginx 目录下。

打开 Nginx 的默认配置文件 /etc/nginx/nginx.conf,找到 http 块,在其中添加一个 server 块,用于配置一个虚拟主机。

示例代码如下:

http {
   
    # ...
    server {
   
        listen       80;
        server_name  mywebapp.com;
        root         /var/www/mywebapp;
        index        index.html;

        location /api/ {
   
            proxy_pass http://127.0.0.1:8000/;
        }
    }
    # ...
}

在上述示例代码中,我们创建了一个名为 mywebapp.com 的虚拟主机。其中:

  • listen 用于指定监听的端口号;
  • server_name 用于指定虚拟主机的域名或 IP 地址;
  • root 指定虚拟主机的根目录;
  • index 是虚拟主机默认访问的文件;
  • location 用于配置反向代理。

配置反向代理

在实际开发中,很多前端项目都需要与后端 API 进行交互。为了避免跨域问题,可以使用 Nginx 进行反向代理。

在上面的示例代码中,我们使用了 location /api/ {} 块来配置反向代理。其中,proxy_pass 指定要转发的 URL 地址。

配置多个虚拟主机

如果需要部署多个前端项目,可以在 Nginx 配置文件中添加多个 server 块,每个 server 块对应一个虚拟主机。例如:

http {
   
    # ...
    server {
   
        listen       80;
        server_name  mywebapp1.com;
        root         /var/www/mywebapp1;
        index        index.html;

        location /api/ {
   
            proxy_pass http://127.0.0.1:8000/;
        }
    }

    server {
   
        listen       80;
        server_name  mywebapp2.com;
        root         /var/www/mywebapp2;
        index        index.html;

        location /api/ {
   
            proxy_pass http://127.0.0.1:8001/;
        }
    }
    # ...
}

在上述示例代码中,我们创建了两个虚拟主机:mywebapp1.com 和 mywebapp2.com。每个虚拟主机都有一个不同的 root 目录和反向代理配置。

重载 Nginx 配置

完成配置后,需要使用以下命令重载 Nginx 配置:

sudo nginx -s reload

文件权限

在部署前端项目时,需要注意文件权限问题。Nginx 进程运行于 www-data 用户下,因此需要将前端项目的目录和文件设置为 www-data 用户可读取和执行。

可以使用以下命令修改文件权限:

chown -R www-data:www-data /var/www/mywebapp
chmod -R 755 /var/www/mywebapp

HTTPS 配置

在实际生产环境中,为了保证数据的安全性,我们通常会使用 HTTPS 加密协议来加密网站的通信。下面是一个简单的设置 SSL/TLS 的 Nginx 配置示例:

server {
   
    listen 80;
    server_name mywebapp.com;

    # 自动跳转到 HTTPS
    return 301 https://{
   mathJaxContainer[0]}request_uri;
}

server {
   
    listen 443 ssl;
    server_name mywebapp.com;

    # SSL/TLS 相关配置
    ssl on;
    ssl_certificate /path/to/certfile.crt;
    ssl_certificate_key /path/to/keyfile.key;
    ssl_protocols TLSv1.2 TLSv1.3;
    ssl_ciphers HIGH:!aNULL:!MD5;

    location / {
   
        root /var/www/mywebapp;
        index index.html;
    }

    location /api/ {
   
        proxy_pass http://127.0.0.1:8000/;
    }
}

在上述示例代码中,我们创建了一个名为 mywebapp.com 的虚拟主机,并使用了 SSL/TLS 加密协议。其中,ssl_certificate 和 ssl_certificate_key 分别指定 SSL 证书和私钥的路径。

HTTP 跳转至 HTTPS

为了让用户访问时自动跳转至 HTTPS,可以使用以下代码:

server {
   
    listen 80;
    server_name mywebapp.com;

    # 自动跳转到 HTTPS
    return 301 https://{
   mathJaxContainer[1]}request_uri;
}

这段代码会将所有 HTTP 请求自动重定向到 HTTPS。

总结

本文介绍了如何使用 Nginx 部署多个前端项目和配置 HTTPS。要部署多个前端项目,需要在 Nginx 的配置文件中创建多个虚拟主机,并为每个虚拟主机指定根目录和反向代理配置。为了保证数据的安全性,我们还可以使用 HTTPS 加密协议来加密网站的通信。

目录
相关文章
|
4天前
|
人工智能 JavaScript 前端开发
Vue 性能革命:揭秘前端优化的终极技巧;Vue优化技巧,解决Vue项目卡顿问题
Vue在处理少量数据和有限dom的情况下技术已经非常成熟了,但现在随着AI时代的到来,海量数据场景会越来越多,Vue优化技巧也是必备技能。 博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
13天前
|
JSON 自然语言处理 前端开发
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
111 72
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
|
26天前
|
安全 前端开发 开发工具
【01】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-项目开发实战-优雅草卓伊凡拟开发一个一站式家政服务平台-前期筹备-暂定取名斑马家政软件系统-本项目前端开源-服务端采用优雅草蜻蜓Z系统-搭配ruoyi框架admin后台-全过程实战项目分享-从零开发到上线
【01】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-项目开发实战-优雅草卓伊凡拟开发一个一站式家政服务平台-前期筹备-暂定取名斑马家政软件系统-本项目前端开源-服务端采用优雅草蜻蜓Z系统-搭配ruoyi框架admin后台-全过程实战项目分享-从零开发到上线
68 5
【01】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-项目开发实战-优雅草卓伊凡拟开发一个一站式家政服务平台-前期筹备-暂定取名斑马家政软件系统-本项目前端开源-服务端采用优雅草蜻蜓Z系统-搭配ruoyi框架admin后台-全过程实战项目分享-从零开发到上线
|
1月前
|
JSON 前端开发 API
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
66 5
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
|
1月前
|
Dart 前端开发 Android开发
【09】flutter首页进行了完善-采用android studio 进行真机调试开发-增加了直播间列表和短视频人物列表-增加了用户中心-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【09】flutter首页进行了完善-采用android studio 进行真机调试开发-增加了直播间列表和短视频人物列表-增加了用户中心-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
57 4
【09】flutter首页进行了完善-采用android studio 进行真机调试开发-增加了直播间列表和短视频人物列表-增加了用户中心-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
|
1月前
|
前端开发 Java Shell
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
182 20
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
|
2月前
|
Dart 前端开发 容器
【07】flutter完成主页-完成底部菜单栏并且做自定义组件-完整短视频仿抖音上下滑动页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
【07】flutter完成主页-完成底部菜单栏并且做自定义组件-完整短视频仿抖音上下滑动页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
101 18
【07】flutter完成主页-完成底部菜单栏并且做自定义组件-完整短视频仿抖音上下滑动页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
|
2月前
|
缓存 前端开发 IDE
【06】flutter完成注册页面-密码登录-手机短信验证-找回密码相关页面-并且实现静态跳转打包demo做演示-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
【06】flutter完成注册页面-密码登录-手机短信验证-找回密码相关页面-并且实现静态跳转打包demo做演示-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
38 0
【06】flutter完成注册页面-密码登录-手机短信验证-找回密码相关页面-并且实现静态跳转打包demo做演示-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
|
2月前
|
Dart 前端开发
【05】flutter完成注册页面完善样式bug-增加自定义可复用组件widgets-严格规划文件和目录结构-规范入口文件-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
【05】flutter完成注册页面完善样式bug-增加自定义可复用组件widgets-严格规划文件和目录结构-规范入口文件-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
132 75
【05】flutter完成注册页面完善样式bug-增加自定义可复用组件widgets-严格规划文件和目录结构-规范入口文件-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
|
2月前
|
缓存 前端开发 Android开发
【04】flutter补打包流程的签名过程-APP安卓调试配置-结构化项目目录-完善注册相关页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程
【04】flutter补打包流程的签名过程-APP安卓调试配置-结构化项目目录-完善注册相关页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程
117 12
【04】flutter补打包流程的签名过程-APP安卓调试配置-结构化项目目录-完善注册相关页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程

热门文章

最新文章