0.4.7 • Published 3 months ago

env-manage-plugin v0.4.7

Weekly downloads
-
License
MIT
Repository
github
Last release
3 months ago

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",
  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",
      // 关联的开发服务器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 文件,工具支持热更新,修改后无需重启服务即可生效。

依赖

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

许可证

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

贡献

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

作者


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

0.4.5

3 months ago

0.4.7

3 months ago

0.4.6

3 months ago

0.4.4

3 months ago

0.4.1

4 months ago

0.4.3

3 months ago

0.4.2

4 months ago

0.3.0

4 months ago

0.2.7

4 months ago

0.2.6

4 months ago

0.2.9

4 months ago

0.2.8

4 months ago

0.3.2

4 months ago

0.3.1

4 months ago

0.3.4

4 months ago

0.3.3

4 months ago

0.2.1

4 months ago

0.2.0

4 months ago

0.2.3

4 months ago

0.2.2

4 months ago

0.2.5

4 months ago

0.2.4

4 months ago

0.0.5

5 months ago

0.0.4

6 months ago

0.0.3

6 months ago

0.0.1

6 months ago