Skip to content

Sample project for Micro Frontends with React/Typescript and AWS CDK

License

Notifications You must be signed in to change notification settings

aws-samples/micro-frontends-on-aws

Micro Frontends on AWS

This is a sample project to show how to configure React/Typescript applications for the Micro Frontends pattern and deploy it to AWS with Webpack Module Federation. This project consists of four pieces, a CDK app, a host app and two remotes apps remote-1 and remote-2.

Application Preview

ScreenShot!

Architecture Overview

Architecture!

AWS Services

  • AWS CDK
  • AWS CodeCommit
  • AWS CodeBuild
  • AWS CodeDeploy
  • Amazon S3
  • Amazon CloudFront

Application configuration

Host and remote apps for Micro Frontends are built using React/Typescript with Webpack 5 Module Federation. All configurations are in the webpack.config.js in each application and already all set. If you want to add or change your remote app name or components, you can update values under the ModuleFederationPlugin key.

Host App

Webpack config of Host app for using remote apps is already configured like below.

plugins: [
            new ModuleFederationPlugin({
                name: 'Host',
                remotes: {
                    Remote1: isProduction
                        ? process.env.REMOTE_1
                        : 'Remote1@http://localhost:4000/moduleEntry.js',
                    Remote2: isProduction
                        ? process.env.REMOTE_2
                        : 'Remote2@http://localhost:4001/moduleEntry.js',
                },

To use remote components, you should define Dynamic import for remote apps and renders them. Sample applications in this project are already configured.

const Remote1App = React.lazy(() => import('Remote1/App'));
const Remote1Button = React.lazy(() => import('Remote1/Button'));
const Remote2App = React.lazy(() => import('Remote2/App'));
const Remote2Button = React.lazy(() => import('Remote2/Button'));

Remote App

To expose your components in the remote app, you need to define a name and components. In this case, Remote1 app exports App and Button components.

// webpack.config.js of the Remote #1 app
 plugins: [
        new ModuleFederationPlugin({
            name: 'Remote1',
            filename: 'moduleEntry.js',
            exposes: {
                './App': './src/App',
                './Button': './src/Button',
            },

Running locally

This project uses Lerna to manage apps as a mono repo and if you have not installed it before, you need to install it globally.

npm i -g lerna

and then, run it in the root directory of this project.

npm run start

Lerna will start all applications (host, remote-1, and remote-2) in this project at once.

Deploying on AWS

If you previously ran lerna or npm install on your local before, you must first remove node_modules in the sample application directory. In the root directory, please run npm run clean command like below. It helps remove node_modules and some unnecessary directories to avoid errors in AWS Pipeline.

npm run clean

Then, you can run cdk deploy in the cdk directory.

cdk deploy --all --require-approval never

Finally, you would see a CloudFront URL for the Host app in your terminal like below when CDK deploys all.

Outputs:
HostPipelineStack.DistributionDomainName = hostappsample.cloudfront.net

Destroying Services

If you want to destroy the services, you can easily destroy them all with the command below.

cdk destroy --all

License

This sample project is licensed under the MIT-0 license.