Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
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
- Host: GitHub
- URL: https://github.com/aws-samples/micro-frontends-on-aws
- Owner: aws-samples
- License: mit-0
- Created: 2023-01-24T17:38:40.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2024-06-20T06:03:58.000Z (7 months ago)
- Last Synced: 2024-07-23T01:45:11.162Z (6 months ago)
- Language: TypeScript
- Homepage:
- Size: 2.2 MB
- Stars: 61
- Watchers: 4
- Forks: 8
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-learn-aws - Micro Frontends on AWS
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.