Nx's Module Federation support is provided through a mixture of executors
and the withModuleFederation()
util that is used in your webpack.config
or rspack.config
file. Understanding what is happening under the hood can help when developing applications that use Module Federation as well as debugging any potential issues you run into. With Rspack, Module Federation support can also be provided through the NxModuleFederationPlugin
and NxModuleFederationDevServerPlugin
plugins that can be used in the rspack.config
file when utilizing Inferred Tasks.
What happens when you serve your host?
Section titled “What happens when you serve your host?”When you serve your host application via nx serve host
, the Nx module-federation-dev-server
executor or NxModuleFederationDevServerPlugin
is invoked. These do a few things that aim to provide a more holistic local development while ensuring a great DX (development experience).
The executor does the following:
- Finds all the
remotes
that thehost
depends on. - Determines which
remotes
need to be served statically and which need to be served viawebpack-dev-server
. - For the
static remotes
, it will invokenx run-many -t build --projects={listOfStaticRemotes}
. - If required, it will move the built artifacts of each
remote
to a common directory. - It will run
http-server
at the common directory such that those files are available on the network from a single port. - It will create proxy servers via
express
listening on the ports where eachremote
should be located (as configured in the host'smodule-federation.config.ts
ormodule-federation.manifest.json
file).- These proxy servers will proxy requests from the server to the
http-server
to fetch the correct files as requested by Module Federation.
- These proxy servers will proxy requests from the server to the
- Only Applicable for Executor Usage: If the
--devRemotes
option has been passed, it will serve eachdev remote
viawebpack-dev-server
allowing for HMR and live reloading when working on those remotes. - It will serve the
host
viawebpack-dev-server
.
If you prefer diagrams, the one below outlines the above steps.
Using Module Federation with Continuous Tasks
Section titled “Using Module Federation with Continuous Tasks”Continuous Tasks are a new feature in Nx 21. Using Rspack Module Federation, you can now use Continuous Tasks to serve your remotes
and host
application.
Thanks to the benefits of Continuous Tasks, you no longer need to run nx serve host --devRemotes=remote
to serve your host
application with HMR enabled for your remote applications.
Instead, you can run nx serve remote
and it will serve the remote
along with your host
application with HMR enabled.
This is a great way to develop your application locally and have a great DX. It also makes it easier to explain to your team how to work with Module Federation as there is no longer any special command required to serve their application.
The NxRuntimeLibraryControlPlugin
Section titled “The NxRuntimeLibraryControlPlugin”Previously, when using shared workspace libraries as part of your Module Federation application, there was a chance that the workspace library would be provided by one of the static remotes
. This would cause issues where changes to those shared libraries would not be reflected in the locally served application.
To combat this issue, we developed the NxRuntimeLibraryControlPlugin
. This is a Runtime Plugin that will ensure that workspace libraries are only shared via any active dev remote
. This means that any changes to the shared library will be picked up by webpack-dev-server
and, as such, reflected in the locally served application.
This plugin is enabled by default, however, you can turn it off in your module-federation.config
file:
export const config: ModuleFederationConfig = { ..., disableNxRuntimeLibraryControlPlugin: true}