A powerful CLI tool designed to simplify the management and execution of multiple micro frontend applications. mfer helps developers run, update, and organize their micro frontend projects with minimal configuration and maximum efficiency.
- 🚀 Features
- 📦 Installation
- 🛠️ Quick Start
- 📋 Commands
- ⚙️ Configuration
- 🎯 Use Cases
- 🔧 Advanced Usage
- 🛠️ Development
- 🐛 Troubleshooting
- 🤝 Contributing
- 📄 License
- 🙏 Acknowledgments
- Concurrent Execution: Run multiple micro frontends simultaneously with organized output
- Group Management: Organize micro frontends into logical groups for selective execution
- Git Integration: Pull latest changes from all repositories with a single command
- Smart Configuration: Interactive setup wizard with TOML-based configuration
- Cross-Platform: Works on Windows, macOS, and Linux
- Graceful Shutdown: Clean termination of all processes with Ctrl+C
- Node.js 18 or higher
- Git (for repository management)
npm install -g mfergit clone https://github.com/srimel/mfer.git
cd mfer
npm install
npm run build
npm install -g .Start by setting up your mfer configuration:
mfer initThis interactive wizard will guide you through:
- Setting up your GitHub username
- Specifying the directory containing your micro frontends
- Selecting which projects to include in your default group
# Run all micro frontends
mfer run
# Run a specific group
mfer run frontend
# Run with a custom group name
mfer run shared# Pull latest changes from all repositories
mfer pull
# Pull from a specific group
mfer pull frontendmfer init- Interactive setup wizardmfer run- Run micro frontend applications (supports per-MFE run modes)mfer pull- Pull latest changes from git repositoriesmfer install- Install dependencies for micro frontendsmfer clone- Clone repositories that don't exist locallymfer lib- Manage internal npm packagesmfer config- Manage configuration settingsmfer help- Display help information
Interactive setup wizard to create your configuration file.
Options:
-f, --force: Force re-initialization even if config exists
Example:
mfer init --forceRun micro frontend applications concurrently.
Arguments:
group_name: Name of the group to run (defaults to "all")
Options:
-c, --command <command>: Custom command to run for all MFEs (default: npm start)-a, --async: Run custom command concurrently instead of sequentially (only with--command)-m, --mode <mode_name>: Run MFEs using a named mode from config (see Per-MFE Run Modes)-s, --select: Prompt to select which micro frontends to run
Note:
--modeand--commandare mutually exclusive.
Examples:
mfer run # Run all MFEs with default command (npm start)
mfer run frontend # Run frontend group with default command
mfer run --mode mock # Run all MFEs in mock mode (per-MFE commands from config)
mfer run frontend --mode mock # Run frontend group in mock mode
mfer run --command "npm ci" home # Run custom command sequentially on home group
mfer run -c "yarn install" shared # Run yarn install sequentially on shared group
mfer run --command "npm ci" --async home # Run custom command concurrently on home group
mfer run --command "npm run build" --select # Select MFEs and run build sequentiallyPull latest changes from git repositories.
Arguments:
group_name: Name of the group to pull from (defaults to "all")
Options:
-s, --select: Prompt to select which repositories to pull
Examples:
mfer pull # Pull from all repositories
mfer pull shared # Pull from shared components group only
mfer pull --select # Select repositories to pull interactively
mfer pull frontend --select # Select repositories from frontend groupInstall dependencies for all micro frontends in a group.
Arguments:
group_name: Name of the group to install dependencies for (defaults to "all")
Options:
-s, --select: Prompt to select which micro frontends to install
Examples:
mfer install # Install dependencies for all micro frontends
mfer install frontend # Install dependencies for frontend group only
mfer install --select # Select micro frontends to install interactively
mfer install shared --select # Select micro frontends from shared groupClone repositories that don't exist locally.
Arguments:
group_name: Name of the group to clone repositories from (defaults to "all")
Example:
mfer clone # Clone all repositories
mfer clone shared # Clone repositories in shared group onlyManage your configuration settings.
Subcommands:
mfer config list: Display current configurationmfer config edit: Open configuration file in your default editor
Example:
mfer config list # Show current configuration
mfer config edit # Edit configuration in your editorDisplay help information for mfer commands.
Example:
mfer help # Show general help
mfer help run # Show help for run command
mfer help config # Show help for config commandManage internal npm packages and their distribution to micro frontends.
Subcommands:
mfer lib build- Build internal npm packagesmfer lib deploy- Copy built libraries to micro frontendsmfer lib publish- Build and deploy libraries to micro frontendsmfer lib list- List configured libraries and their statusmfer lib pull- Pull latest changes from library git repositoriesmfer lib install- Install dependencies for libraries
Build internal npm packages.
Arguments:
lib-name: Name of the library to build (builds all if not specified)
Options:
-s, --select: Prompt to select which libraries to build
Examples:
mfer lib build # Build all libraries
mfer lib build my-shared-utils # Build specific library
mfer lib build --select # Select libraries to build interactivelyCopy built libraries to micro frontends.
Arguments:
lib-name: Name of the library to deploy (deploys all if not specified)
Options:
-s, --select: Prompt to select which libraries to deploy
Examples:
mfer lib deploy # Deploy all libraries
mfer lib deploy my-shared-utils # Deploy specific library
mfer lib deploy --select # Select libraries to deploy interactivelyBuild and deploy libraries to micro frontends.
Arguments:
lib-name: Name of the library to publish (publishes all if not specified)
Options:
-s, --select: Prompt to select which libraries to publish
Examples:
mfer lib publish # Publish all libraries
mfer lib publish my-shared-utils # Publish specific library
mfer lib publish --select # Select libraries to publish interactivelyList configured libraries and their status.
Example:
mfer lib list # Show all configured libraries and their build statusPull latest changes from library git repositories.
Arguments:
lib-name: Name of the library to pull from (pulls all if not specified)
Options:
-s, --select: Prompt to select which libraries to pull
Examples:
mfer lib pull # Pull from all libraries
mfer lib pull my-shared-utils # Pull from specific library only
mfer lib pull --select # Select libraries to pull interactively
mfer lib pull my-design-system --select # Select libraries from specific libraryInstall dependencies for libraries.
Arguments:
lib-name: Name of the library to install dependencies for (installs all if not specified)
Options:
-s, --select: Prompt to select which libraries to install
Examples:
mfer lib install # Install dependencies for all libraries
mfer lib install my-shared-utils # Install dependencies for specific library only
mfer lib install --select # Select libraries to install interactively
mfer lib install my-design-system --select # Select libraries from specific librarymfer uses a TOML configuration file located at ~/.mfer/config.toml. Here's an example structure:
base_github_url = "https://github.com/your-username"
mfe_directory = "/path/to/your/micro-frontends"
lib_directory = "/path/to/your/internal-libs"
libs = ["my-shared-utils", "my-design-system", "my-common-components"]
[groups]
all = ["my-main-app", "my-admin-panel", "my-shared-components"]
main = ["my-main-app", "my-shared-components"]
admin = ["my-admin-panel", "my-shared-components"]
# optional, per-MFE configuration
[[mfes.my-main-app.modes]]
mode_name = "mock"
command = "npm run start:mocked"Migrating from v3.x? v4.0.0 is a breaking change: YAML config is no longer supported. Run
mfer config migrateto convert your existing~/.mfer/config.yamlto TOML automatically.
base_github_url: Your GitHub base URL for repository operationsmfe_directory: Path to the directory containing all your micro frontend projectslib_directory: Path to the directory containing your internal npm packages (optional)libs: List of internal npm package names to manage (optional)groups: Named collections of micro frontend projectsall: Default group containing all projects (required)- Custom groups: Any additional groups you want to create
mfes: Per-MFE configuration (optional). Each key is an MFE name matching one ingroups.modes: Array of named run modes for the MFE. Each mode has:mode_name: Name used withmfer run --mode <name>command: The command to run for this MFE when the mode is active
Run modes let individual MFEs use a different start command while the rest of the group continue using npm start. This is useful when some MFEs support a mocked/stubbed backend while others don't need it.
Config example — root-config runs with a mocked API, everything else runs normally:
[groups]
all = ["root-config", "mfe-nav", "mfe-dashboard"]
[[mfes.root-config.modes]]
mode_name = "mock"
command = "npm run start:mocked"Usage:
mfer run --mode mock
# root-config → npm run start:mocked
# mfe-nav → npm start (no mock mode defined, falls back to default)
# mfe-dashboard → npm start- MFEs that do not have the mode defined silently fall back to
npm start. - If no MFE in the group has the requested mode, a warning is printed but the command still runs (all MFEs use
npm start). --modecannot be combined with--command; they are mutually exclusive.
You can edit your configuration in several ways:
-
Interactive editor (recommended):
mfer config edit
-
Direct file editing:
# On macOS/Linux nano ~/.mfer/config.toml # On Windows notepad %USERPROFILE%\.mfer\config.toml
-
Migrate a legacy YAML config:
mfer config migrate
Converts
~/.mfer/config.yaml→~/.mfer/config.toml. Prompts before overwriting an existing TOML file and optionally removes the legacy YAML afterward.
# Start your day
mfer pull # Get latest changes
mfer run main # Start main application
# Later, switch to admin panel work
mfer run admin # Start admin panelOrganize your micro frontends into logical groups:
[groups]
all = ["main-app", "admin-panel", "user-dashboard", "shared-components", "design-system"]
core = ["main-app", "shared-components", "design-system"]
admin = ["admin-panel", "user-dashboard", "shared-components"]
ui = ["shared-components", "design-system"]- Share configuration files with your team
- Standardize development environment setup
- Ensure everyone runs the same services
By default, mfer runs npm start in each project directory. You can customize this in two ways:
- Same command for all MFEs: use
--command(e.g.mfer run --command "yarn start") - Per-MFE commands via modes: define
mfes[name].modesin config and use--mode(see Per-MFE Run Modes)
mfer respects your existing environment setup and will use the same Node.js and npm versions you have configured.
- All processes are managed concurrently with organized output
- Use Ctrl+C to gracefully shut down all running services
- Failed processes are reported with detailed error information
For contributing to mfer or setting up a local development environment:
git clone https://github.com/srimel/mfer.git
cd mfer
npm install
npm run build
npm install -g .The project includes a comprehensive playground for testing mfer commands with sample micro frontends. The playground contains:
- libs/common-utils: A shared utility library
- frontends/mfe1, mfe2, mfe3: Three React micro frontends with different themes
- Complete setup instructions and testing scenarios
📖 View detailed local development guide →
"No configuration file detected"
# Run the initialization wizard
mfer init"Group not found"
# Check available groups
mfer config list
# Edit configuration to add missing group
mfer config edit"Directory does not exist"
- Ensure the
mfe_directorypath in your configuration is correct - Use absolute paths for better reliability
- Check that the directory exists and is accessible
"Not a git repository"
- Ensure all projects in your configuration are valid git repositories
- Run
mfer cloneto clone missing repositories
Contributions are welcome! Please feel free to submit a Pull Request. For major changes, please open an issue first to discuss what you would like to change.
This project is licensed under the MIT License - see the LICENSE file for details.
Built with:
- Commander.js - CLI framework
- Inquirer - Interactive prompts
- Concurrently - Process management
- Chalk - Terminal styling
- smol-toml - Configuration parsing
- YAML - Legacy config parsing for
mfer config migrate