部署 Vite 项目到服务器
创始人
2024-09-26 04:22:35
0

1. 配置环境变量文件

        在 Vite 项目中,为了适应不同的环境需求,需要根据开发和生产环境动态设置 config.js 中的 baseURL。在开发环境中,通常将 baseURL 设置为 http://localhost,这样方便连接本地的后端服务。但是,如果在生产环境中仍然使用 localhost,其他电脑在访问服务器时会把 localhost 解析为它们自己的本地地址,而不是指向后端服务。为了解决这个问题,需要将 baseURL 修改为后端服务的 IP 地址,这样无论是服务器本机还是局域网内的其他设备,都能通过正确的 IP 地址访问后端服务。

步骤

①.创建 .env.development.env.production 文件,分别为开发环境和生产环境配置不同的 VITE_BASE_URL

  • .env.development
VITE_BASE_URL=http://localhost:5240(后端服务定义的访问端口)
  • .env.production
VITE_BASE_URL=http://<服务器_IP>:5240 

②.vite.config.js 中,使用 loadEnv 加载环境变量,并根据当前环境动态设置 baseURL

import { defineConfig, loadEnv } from 'vite' import path from 'path' import createVitePlugins from './vite/plugins'  export default defineConfig(({ mode, command }) => {   // 使用 loadEnv 方法加载环境变量,mode 是当前环境模式,process.cwd() 是当前工作目录   const env = loadEnv(mode, process.cwd())   return {     // 部署生产环境和开发环境下的URL。     // 默认情况下,vite 会假设你的应用是被部署在一个域名的根路径上     base: '/',     plugins: createVitePlugins(env, command === 'build'),     resolve: {       alias: {         '~': path.resolve(__dirname, './'),         '@': path.resolve(__dirname, './src')       },       extensions: ['.mjs', '.js', '.ts', '.jsx', '.tsx', '.json', '.vue']     },     server: {       port: 8420            },     // 根据不同的环境,传递不同的.env文件里的值     define: {       'process.env': env     }   } }) 

 

2. 设定 server.host 支持外部访问

        Vite 默认绑定到 localhost,这意味着只有本地设备可以访问。在生产环境或部署到服务器后,需要将 server.host 设置为 0.0.0.0,以允许来自外部设备的连接。

        在 vite.config.js 中,配置 server.host0.0.0.0,确保服务器监听所有网络接口。这样,其他设备可以通过服务器的 IP 地址进行访问。

import { defineConfig, loadEnv } from 'vite' import path from 'path' import createVitePlugins from './vite/plugins'  export default defineConfig(({ mode, command }) => {   const env = loadEnv(mode, process.cwd())    return {     base: '/',     plugins: createVitePlugins(env, command === 'build'),     resolve: {       alias: {         '~': path.resolve(__dirname, './'),         '@': path.resolve(__dirname, './src')       },       extensions: ['.mjs', '.js', '.ts', '.jsx', '.tsx', '.json', '.vue']     },     server: {       host: '0.0.0.0',  // 允许外部访问       port: 8080        // 指定访问端口号     },     define: {       'process.env': env     }   } }) 

        同时,需检查服务器的防火墙配置,确保所使用的端口(如 8080)允许外部访问。例如,使用以下命令打开指定端口:

sudo ufw allow 8080/tcp 

3. 在 package.json 中设定环境

        在 package.json 中,可以根据开发环境和生产环境定义不同的脚本命令,以便使用不同的配置和命令运行项目。常见的命令包括 devbuildpreview,其中 preview 命令可用于预览生产环境的构建结果。

{   "scripts": {     "dev": "vite",                          // 启动开发服务器     "build": "vite build",                  // 构建生产环境代码     "preview": "vite preview --port 8420"   // 预览生产环境代码   } } 
开发环境

        启动开发服务器,运行本地开发环境。此命令会读取 vite.config.js 中的开发配置,并通过 localhost 和指定的端口(如 8080)启动服务器。开发人员可以通过这个服务器实时预览和调试代码,进行快速的迭代开发。

npm run dev   或者:  vite

生产环境

        打包构建生产环境代码。此命令会将项目编译、优化,并生成静态文件,通常位于 dist 目录下。这些文件是用于生产环境部署的,经过优化后体积更小、性能更佳。

npm run build   或者:  vite build

        预览构建后的生产环境代码。此命令启动一个本地服务器,用于模拟生产环境的运行,默认使用端口 4173。需要注意,server.port 的配置仅适用于开发服务器(即 npm run dev),不会影响 npm run preview 的端口。可以通过在运行 npm run preview 时添加 --port 参数来指定端口号。

npm run preview -- --port 8080  或者:  vite preview  -- --port 8080

        或者在 package.json 中,使用“preview": "vite preview --port 8080”,确保 npm run preview 使用指定的端口 8080

{   "scripts": {     "dev": "vite",     "build": "vite build",     "preview": "vite preview --port 8080"  // 使用指定端口   } } 

4. Nginx 配置

        在生产环境中,通常需要使用 Nginx 作为 Web 服务器来提供静态资源服务。Vite 构建后的文件通常会部署到 /var/www/html 目录下。为了确保正确访问这些文件,需配置 Nginx 并将请求路由到正确的位置。

        以下是一个简单的 Nginx 配置示例:

server {     listen 80;     server_name your_domain_or_ip;      location / {         root /var/www/html;         index index.html;         try_files $uri $uri/ /index.html;     } } 

        此配置将确保所有访问请求都路由到 index.html,并通过 Nginx 提供静态文件服务。

相关内容

热门资讯

发现开挂!wpk透视辅助方法,... 发现开挂!wpk透视辅助方法,微乐小程序辅助器出租,开挂(透视)辅助工具(详细教程)>>您好:软件加...
第4分钟辅助"潮汕汇... 第4分钟辅助"潮汕汇软件辅助"先前有开挂辅助透视软件(有挂助手)您好:潮汕汇软件辅助这款游戏可以开挂...
透视透视!蜀山四川小程序辅助插... 大家好,今天小编来为大家解答蜀山四川小程序辅助插件这个问题咨询软件客服可以免费测试直接加微信(136...
指南开挂"潮友辅助插... 指南开挂"潮友辅助插件"开挂(工具)辅助下载(有挂教学)这是一款可以让一直输的玩家,快速成为一个“必...
发现开挂!德普之星怎么设置埋牌... >>您好:潮友会鱼虾蟹破解确实是有挂的,很多玩家在这款潮友会鱼虾蟹破解游戏中打牌都会发现很多用户的牌...
九分钟开挂"花花生后... 九分钟开挂"花花生后圈开挂"本来有开挂辅助透视器(有挂详细);无需打开直接搜索微信(13670430...
透视安卓版!宁夏微乐科技辅助,... 透视安卓版!宁夏微乐科技辅助,aapoker辅助器是真的吗(透视)开挂辅助下载黑科技教程>>您好:软...
绝活儿开挂"智星菠萝... 绝活儿开挂"智星菠萝可以辅助吗"开挂(插件)辅助下载(有挂透视);打开点击测试直接进入微信(1367...
传授辅助!wpk有辅助吗,钱塘... 传授辅助!wpk有辅助吗,钱塘十三水透视,开挂(透视)辅助平台(有挂攻略);无需打开直接搜索打开薇:...
四分钟开挂"hhpo... 四分钟开挂"hhpoker有后台操作吗"本然有开挂透视辅助下载(有挂功能) 【无需打开直接搜索加薇1...