当前位置: 首页 > article >正文

nginx部署多个vue或react项目

下载nginx(tar.gz)

nginx: download(官方地址)

部署nginx

# 进入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文件) 

主项目

import { defineConfig } from 'vite'
import react from '@vitejs/plugin-react'

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

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

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/)

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

./nginx -s reload

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

 效果如下:

访问:ip

访问:ip/like


http://www.kler.cn/a/157242.html

相关文章:

  • python通过正则匹配SQL
  • 【Linux】查询磁盘空间被谁占用了
  • AtCoder Beginner Contest 385(A~F)题解
  • “檢測到不安全的代理”怎麼修復?
  • 使用TC命令模拟弱网丢包
  • SQL 实战:窗口函数的妙用 – 分析排名与分组聚合
  • 回溯法及例题(C++实现)
  • 大三上oracle数据库期末复习
  • dp-拦截导弹2
  • 计算机辅助药物设计AIDD-小分子-蛋白质|分子生成|蛋白质配体相互作用预测
  • RWA+AI 叙事下的 ProsperEx,对 Web3 时代交易的重新定义
  • JAVA泛型概念的理解
  • 电压驻波比
  • Oracle 11g安装过程
  • 初识动态规划算法(题目加解析)
  • SSM校园组团平台系统开发mysql数据库web结构java编程计算机网页源码eclipse项目
  • 【0241】Parser解析分析统计信息(PARSE ANALYSIS STATISTICS)
  • C语言面试之旅:掌握基础,探索深度(面试实战之ARM架构一)
  • Boost:内存映射文件
  • C++ 指针详解
  • mysql which is not in SELECT list; this is incompatible with DISTINCT解决方案
  • Module build failed: Error: ENOENT: no such file or directory
  • 现在的00后,实在是太卷了......
  • springboot遇到的问题02
  • 【前端系列】前端存档术之keep-alive
  • 微信开发者工具里面模拟操作返回、录屏、网络速度、截屏等操作