环境变量里面的.env文件是如何起作用的?

1. 配置文件的加载机制:

让我们看看代码中是如何处理这些配置文件的:

js 复制代码
// src/config/index.js 中的代码
const loadEnv = () => {
  const env = process.env.NODE_ENV || 'development';  // 获取当前环境
  const envPath = path.resolve(process.cwd(), `.env.${env}`);  // 根据环境选择配置文件
  
  dotenv.config({ path: envPath });  // 加载对应的配置文件
};

通过path.resolve(process.cwd(),.env.${env}); 获取到环境变量的文件,然后读取信息。

2. 环境切换机制:

在 package.json 中定义了不同环境的启动命令:

js 复制代码
{
  "scripts": {
    "dev": "cross-env NODE_ENV=development nodemon src/app.js",    // 开发环境
    "start": "cross-env NODE_ENV=production node src/app.js"       // 生产环境
  }
}

工作流程:

  1. 开发环境(执行 npm run dev):
  • 设置 NODE_ENV=development
  • 加载 .env.development 文件
  • 使用 nodemon 启动服务(支持热重载)
  • 输出详细的调试信息
  • 使用本地数据库配置
  1. 生产环境(执行 npm start):
  • 设置 NODE_ENV=production
  • 加载 .env.production 文件
  • 使用 node 直接启动服务
  • 只输出重要的日志信息
  • 使用生产环境数据库配置

3. 配置文件的使用:

在代码中通过 process.env 来使用这些配置,例如:

js 复制代码
// src/config/db.js 中的数据库配置
const sequelize = new Sequelize({
  dialect: 'mysql',
  host: process.env.DB_HOST,        // 使用配置文件中的数据库主机
  port: process.env.DB_PORT,        // 使用配置文件中的数据库端口
  database: process.env.DB_NAME,    // 使用配置文件中的数据库名
  username: process.env.DB_USER,    // 使用配置文件中的用户名
  password: process.env.DB_PASSWORD // 使用配置文件中的密码
});

// src/app.js 中的跨域配置
app.use(cors({
  origin: process.env.CORS_ORIGIN,  // 使用配置文件中的跨域配置
  credentials: true
}));
  1. 安全考虑:
  • 这两个文件都在 .gitignore 中,不会被提交到代码仓库
  • 生产环境的敏感信息(如密码、密钥)应该通过安全的方式管理
  • 配置文件中的值可以被环境变量覆盖

使用示例:

js 复制代码
# 开发环境启动
npm run dev
# 此时会加载 .env.development 的配置
# 使用 nodemon 启动,支持热重载

# 生产环境启动
npm start
# 此时会加载 .env.production 的配置
# 使用 node 直接启动,不支持热重载
相关推荐
im_AMBER1 分钟前
React 16
前端·笔记·学习·react.js·前端框架
02苏_2 分钟前
ES6模板字符串
前端·ecmascript·es6
excel5 分钟前
⚙️ 一次性警告机制的实现:warnOnce 源码深度解析
前端
excel7 分钟前
Vue SFC 样式编译核心机制详解:compileStyle 与 PostCSS 管线设计
前端
excel8 分钟前
🧩 使用 Babel + MagicString 实现动态重写 export default 的通用方案
前端
excel8 分钟前
Vue SFC 编译器主导出文件解析:模块组织与设计哲学
前端
excel11 分钟前
深度解析:Vue SFC 模板编译器核心实现 (compileTemplate)
前端
excel12 分钟前
Vue SFC 解析器源码深度解析:从结构设计到源码映射
前端
excel17 分钟前
Vue SFC 编译全景总结:从源文件到运行时组件的完整链路
前端
excel18 分钟前
Vue SFC 编译核心解析(第 5 篇)——AST 遍历与声明解析:walkDeclaration 系列函数详解
前端