Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/aws-samples/micro-frontends-on-aws

Sample project for Micro Frontends with React/Typescript and AWS CDK
https://github.com/aws-samples/micro-frontends-on-aws

Last synced: 3 months ago
JSON representation

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

Awesome Lists containing this project

README

        

# Micro Frontends on AWS

This is a sample project to show how to configure React/Typescript applications for the [`Micro Frontends pattern`](https://microfrontends.com/) and deploy it to AWS with [`Webpack Module Federation`](https://webpack.js.org/concepts/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!](/preview.png 'ScreenShot')

## Architecture Overview

![Architecture!](/diagram.png '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.

```js
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.

```typescript
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.

```js
// 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.

```bash
npm i -g lerna
```

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

```bash
npm run start
```

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

- Host: http://localhost:3000
- Remote-1: http://localhost:4000
- Remote-2: http://localhost:4001

## 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.

```bash
npm run clean
```

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

```bash
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.

```bash
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.

```bash
cdk destroy --all
```

## License

This sample project is licensed under the [MIT-0](https://github.com/aws/mit-0) license.