Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

env-manage-plugin

helloskynet694MIT0.4.9TypeScript support: included

A dev env plugin that integrates an Express server with request proxying capabilities.

proxy, devServer, Development environment management, webpack-plugin, rollup-plugin, vite-plugin

readme

npm node npm

EnvManage - 环境管理工具

EnvManage 是一款强大的环境管理工具,专为管理和代理多个开发环境而设计,特别适用于需要同时运行多个开发环境的场景。无论是小型项目还是大型企业级应用,EnvManage 都能极大地提升开发效率,简化环境管理流程。

graph LR
    A[前置转发服务1<br>端口 3000] --> B[开发服务器(webpack等)<br>端口 8080]
    C[前置转发服务2<br>端口 3001] --> B
    B --> D[后置转发服务<br>端口 3099]
    D --> E[API 服务器1]
    D --> F[API 服务器2]

🌟功能特性

  • 动态环境管理

    通过简单的配置文件 envm.config.js,您可以轻松定义和管理多个开发环境。在该文件中,您能灵活设置不同环境的名称、端口、目标服务器地址等关键信息,实现对各个开发环境的精准区分与高效管理。

  • 请求代理

    支持前置和后置代理,确保请求准确无误地转发到指定的开发服务器。代理服务器会依据配置的目标服务器地址,将请求精准转发到对应的 API 服务器,保障数据交互顺畅。

  • 配置文件热更新

    无需繁琐的重启服务操作,EnvManage 支持配置文件热更新。当您对配置文件进行修改后,工具会自动检测并应用新的配置,显著提高开发效率,让您的开发过程更加流畅。

  • 多服务器管理

    轻松实现同时启动和管理多个开发服务器,并通过管理页面查看代理服务运行状态,同时可灵活启动或停止某个环境对应的服务器。

🚀 快速上手

安装

npm i -D env-manage-plugin

或者全局安装

npm i -g env-manage-plugin

配置

在项目根目录下创建 envm.config.js 文件,根据实际需求定义开发环境和开发服务器列表。

可以使用 npx envm init 命令快速初始化配置文件。

配置文件示例

// envm.config.js  支持CommonJS 和 ES Module
export default {
  // 管理服务器运行的端口,可根据实际需求修改,确保该端口未被其他程序占用
  port: 3099,
  // 基础路径,用于构建管理API请求的前缀,如果与业务相关接口冲突可调整此配置
  basePath: "/dev-manage-api",
  // 环境的索引路径,可作为环境的首页路径或特定的入口路径,可以被 envList 中的覆盖
  indexPage: "/Test",
  // 是否开启 cookie 的代理
  isEnableCookieProxy: true,
  // 开发服务器列表
  devServerList: [
    {
      // 为开发服务器命名,便于识别和管理,名称可自定义
      // prima key
      name: "your_dev_server_1",
      // 该开发服务器对应的目标地址,即实际提供服务的地址
      target: "http://localhost:5173",
    },
    // 可以添加更多开发服务器
  ],
  envList: [
    {
      // 为开发环境命名,如开发环境、测试环境等,方便区分
      // prima key
      name: "your_env_1",
      // 该环境对外暴露的端口,用于访问该环境下的应用
      // prima key
      port: 3000,
      // 该环境请求转发的目标服务器地址,通常是后端 API 服务地址
      target: "http://localhost:3010",
      // 环境的索引路径,可作为该环境的首页路径或特定的入口路径
      indexPage: "/Test",
      // 是否开启 cookie 的代理
      isEnableCookieProxy: true,
      // 关联的开发服务器Name 未设置时 默认为第一个
      devServerName: "your_dev_server_1",
      // 路由规则函数,根据请求和环境信息,返回请求应转发到的目标地址
      // 自定义 目标地址 可以覆盖 target 未提供时,使用target
      router: (req, env) => {
        return env.target;
      },
    },
    // 可以添加更多环境
  ],
};

router 配置同 http-proxy-middleware 的 router 选项,不过不支持对象形式,函数会额外传递第二个参数,代表当前envItem

envList

envList 的主键组合为 name 和 port 。若数据完全相同,则后一条数据会被忽略。对于 port 相同的情况,系统会自动进行互斥处理,即启动其中一个后,再尝试启动其他相同 port 的实例时,系统会自动关闭已启动的实例,避免冲突。

devServerList

devServerList 的主键为 name,相同则忽略后一个。

开发服务器配置

调整开发服务器,将需要代理到 API 服务器的请求,转发到 后置代理服务器。

webpack-dev-server

// webpack.config.js

module.exports = {
  devServer: {
    proxy: {
      "/two": "http://localhost:3099",
    },
  },
};

vite

// vite.config.js
import { defineConfig } from "vite";

// https://vite.dev/config/
export default defineConfig({
  server: {
    proxy: {
      "/dev-manage-api": {
        target: "http://localhost:3099",
        changeOrigin: true,
      },
      "/simple": {
        target: "http://localhost:3099",
        changeOrigin: true,
      },
      "/two": {
        target: "http://localhost:3099",
        changeOrigin: true,
      },
    },
  },
});

独立启动

运行以下命令启动管理服务器:

npx envm

或者通过命令行参数指定配置文件路径:

npx envm --config ./path/to/envm.config.js

未指定 config 时,默认搜索当前文件夹下的 envm.config.[m]js

访问管理页面 http://localhost:3099/ 对各个代理服务进行管理。

作为插件启动

env-manage-plugin 使用 Unplugin 为各种构建工具提供统一插件,作为插件启动。

webpack

// webpack.config.js
import { envmWebpackPlugin } from "env-manage-plugin";

export default {
  plugins: [
    envmWebpackPlugin({
      config: "./envm.config.mjs",
    }),
  ],
  // .... 其它配置
};

vite

// vite.config.js
import { defineConfig } from "vite";
import { envmVitePlugin } from "env-manage-plugin";

// https://vite.dev/config/
export default defineConfig({
  plugins: [envmVitePlugin()],
  // ... 其它配置
});

支持工具 vite,rollup,rolldown,webpack,rspack,esbuild,farm

配置文件热更新

如果需要修改环境配置,直接修改 envm.config.js 文件,工具支持热更新,修改后无需重启服务即可生效。

由于 Cookie 在同主机的不同端口会进行共享,从而导致不同环境的登录失效,故支持 Cookie 代理功能。

例如: 在 localhost:3001 端口登录 环境A,然后在 localhost:3002 登录 环境B;第二次登录的 set-cookie 操作,会覆盖 环境A 的登录操作设置的 Cookie。导致 3001 端口对 环境A 的登录失效。故设置此功能,将不同端口的登录 Cookie 分开存储,并在请求时替换成对应环境的 Cookie

其它:

  1. 通过配置项 isEnableCookieProxy 可以控制此功能的是否开启,默认开启;
  2. 通过管理页面的 清除所有代理 Cookie 按钮可以清除所有保存的代理Cookie

依赖

  • express: Web 框架,用于创建和管理服务器。
  • http-proxy-middleware: 用于创建代理中间件,转发请求到目标服务器。
  • chokidar: 用于监听配置文件的变化,实现热更新。
  • commander: 用于解析命令行参数。

许可证

本项目采用 MIT 许可证。详情请参阅 LICENSE 文件。

贡献

欢迎提交 Issue 和 Pull Request。请在提交之前阅读 贡献指南

作者


感谢使用 EnvManage!如果你有任何问题或建议,请随时联系我们。