部署 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 提供静态文件服务。

相关内容

热门资讯

九分钟了解!Wepoke透明(... 九分钟了解!Wepoke透明(wPK)外挂辅助器插件,太难了原来是有挂(2021已更新)(哔哩哔哩)...
一分钟实锤!(德州数据辅助器!... 一分钟实锤!(德州数据辅助器!透视辅助)外挂辅助器软件(2025已更新)(哔哩哔哩);小薇(透视辅助...
域名icp备案怎么查(如何查询... IntroductionICP备案是指互联网信息服务提供者向工信部ICP(Internet Cont...
八分钟了解!wpk插件(wpK... 《八分钟了解!wpk插件(wpK)外挂辅助器神器,太明显了原来真的是有挂(2023已更新)(哔哩哔哩...
搬瓦工是什么(什么是搬瓦工?) 什么是搬瓦工?搬瓦工是一个提供VPS主机服务的公司,它的服务范围覆盖全球各地,是一个国际性的公司。它...
搭建服务器可以做什么(搭建服务... 什么是服务器?服务器是一种计算机硬件,可以存储、管理和共享网络和应用程序的信息资源。服务器负责处理网...
搬瓦工是干什么的(搬瓦工是一家... 搬瓦工是干什么的?——一家为用户提供稳定、强大、灵活的云服务器服务供应商搬瓦工是一家提供高性能、高品...
域名买了之后怎么建站(如何建立... 域名买了之后怎么建站一旦您购买了域名,接下来的重要一步就是建立一个网站。本文将介绍如何用最简单的方式...
域名push怎么操作(用什么工... 什么是Push?Push是一种Web技术,可以让服务器主动将信息推送给客户端,而不是客户端定期向服务...
域名买了怎么续费(如何续费已经... 什么是域名续费?在购买域名后,为了持续使用该域名作为个人或企业的网址,就需要对域名进行续费。域名续费...