This Project exemplifies a Real-World Java / React Web App.
- Languages: Java JDK21 / Typescript v5
- Frameworks: Spring Boot v3 / React v18 (MaterialUI v5)
- Rel. Database: MySQL v8
- SearchEngine: Elasticsearch v8
- File Storage: MinIO
The app is secured with JWT authentication. The techstack is kept up-to-date.
When entering the field of software engineering you need to learn how to build applications professionally. You need to learn from good code bases (at best: similar to company code). There are the typical blog examples (here) but what is about search functionality or the handling of images? How is the App deployed on a home server? How to generate client code with openapi-specifications? How can I preload my App with data? The answer to all these questions and more can be found in this codebase.
The project can be rather easily rebuild locally (for a project of this size). If you want to explore a deployed instance of the IMDB Clone then visit imdb-clone.the-coding-lab.com. Here's a diagram of the setup:
The app can be built in 2 steps:
- Run the Spring Boot Backend with
./gradlew bootRun
(this will automatically spin up mysql/elastic/minio containers) - Run the React Frontend with
yarn install
&yarn start
At first, we have to run the with data preloaded stateful services (MySQL, Elasticsearch and
MinIO) which are used by the backend. I created a docker image of each service preloaded with
data, so we just have to execute the docker-compose.yaml
.
For more information on how data were collected, processed and imported look into the infrastructure-folder.
Now we can start the Spring Boot app:
./gradlew build
./gradlew bootRun
This will automatically pull/start the stateful containers. So pulling might take time depending on your bandwidth. For more information on how data were collected, processed and imported look into the infrastructure-folder.
The backend can now be reached at port 8080 on localhost. You can test if the backend works properly by sending some http requests. Use the provided .http files.
Now we can run the React frontend. We have to move into the frontend-folder and build & run with yarn or npm.
cd ./frontend
yarn install
yarn run build:moviesGen
yarn start
The FE is served to `http://localhost:3000/. We can search for movies and more.
I also added a Makefile as a little cheat sheet to refresh our memory for all the important commands we use during development.
- Set up Database and import Movie Data
- Create Java Backend
- Set up Elasticsearch, Photos / File Storage
- Deploy on Home Server with Docker-Compose
- enable HTTPS with reverse-proxy
- simplify local development with spring-boot-starter-docker-compose
- setup and add integration tests
- Add Monitoring (Prometheus, Grafana, Exporters) and expose Grafana
- Add Logging (ELK Stack) and expose Kibana
- Create React Frontend
- Account Settings Page
- Movie Search Page
- Movie Detail View with Rating / Watchlist Feature
- Watchlist Page
- Edit / Create Movies Page
- Home Page
- Detail View: Comments Feature
- Make Mobile Compatible
- Deploy on HA K3s Home Server
- Use Flux for GitOps CD
- Add Integration Namespace in K3s next to the Prod Env for Testing
- Add Selenium for E2E-tests from FE to BE
- Add more Features like Chat Functionality