nginx部署多个vue或react项目

下载nginx(tar.gz)

nginx: download(官方地址)

部署nginx

bash 复制代码
# 进入nginx压缩包所在目录
cd /usr/nginx
 
# 解压
tar -zxvf nginx-1.25.3.tar.gz

# 安装nginx的相关依赖
yum -y install gcc zlib zlib-devel pcre-devel openssl openssl-devel

# 生成Makefile可编译文件
cd /usr/nginx/nginx-1.25.3
# --prefix=PATH:指定nginx的安装目录(默认/usr/local/nginx)
./configure --with-http_ssl_module

# 编译和安装
make
make install

# 进入nginx安装目录下的sbin目录(默认:/usr/local/nginx/sbin)
cd /usr/local/nginx/sbin

# 执行脚本启动 nginx 服务
./nginx

# 安装查看端口的工具
yum install net-tools

# 查看nginx进程
ps -ef | grep nginx
# 查看进程id所占用的端口号(默认80端口)
netstat -nap | grep 进程id

配置vue或者react项目(以vite构建的项目为例,修改vite.config.ts文件)

主项目

TypeScript 复制代码
import { defineConfig } from 'vite'
import react from '@vitejs/plugin-react'

// https://vitejs.dev/config/
export default defineConfig({
  base: "/",
  plugins: [react()],
})

子项目(注意:这里base不能为/,否则不生效)

TypeScript 复制代码
import {defineConfig} from 'vite'
import vue from '@vitejs/plugin-vue'

// https://vitejs.dev/config/
export default defineConfig({
    base: "/like/",
    plugins: [vue()],
    server: {
        host: '0.0.0.0',
        port: 10000
    },
})

将打包好的dist目录上传到自己配置的linux目录下(例如我是放到/usr/web目录中)

配置nginx.cnf文件(默认位置:/usr/local/nginx/conf/)

bash 复制代码
worker_processes  1;

events {
    worker_connections  1024;
}

http {
    include       mime.types;
    default_type  application/octet-stream;

    sendfile        on;
    keepalive_timeout  65;

    server {
        listen       80;
        server_name  localhost;

        location / {
            root   /usr/web/main/dist/;
            index  index.html index.htm;
            try_files $uri $uri/ /index.html;
        }

        # 子项目
        location /like {
            alias /usr/web/like/dist/;
            try_files $uri $uri/ /dist/index.html last;
            index index.html;
        }
    }
}

修改完成后重启nginx

bash 复制代码
./nginx -s reload

这个时候就可以分别访问了

效果如下:

访问:ip

访问:ip/like

相关推荐
yoyo_zzm12 分钟前
Laravel9.x新特性全解析
数据库·mysql·nginx
Front思22 分钟前
前端的.hbs
前端
_.Switch35 分钟前
东方财富股票数据JS逆向:secids字段和AES加密实战
开发语言·前端·javascript·网络·爬虫·python·ecmascript
软件技术NINI35 分钟前
webkit简介及工作流程
开发语言·前端·javascript·udp·ecmascript·webkit·yarn
普通网友36 分钟前
ES6模块化、Promise、async、await、EventLoop、API接口案例_export function 与 await
前端·ecmascript·es6
難釋懷38 分钟前
Vue混入
前端·javascript·vue.js
訾博ZiBo41 分钟前
Vue3响应式高阶用法之toRaw()
javascript·vue.js·ecmascript
若梦plus42 分钟前
TypeScript进阶
前端·javascript·typescript·ecmascript
直奔標竿42 分钟前
Java开发者AI转型第二十七课!Spring AI 个人知识库实战(六)——全栈闭环收官,解锁前端流式渲染终极技巧
java·开发语言·前端·人工智能·后端·spring
@PHARAOH1 小时前
WHAT - cursor cli 开发范式
前端·ai·ai编程