Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/khauser/microservices4vaadin
Sample application to show the secured integration of microservices and vaadin
https://github.com/khauser/microservices4vaadin
authserver docker eventstore gradle microservice oauth2 rancher redis service-discovery spring-session sso vaadin
Last synced: 2 months ago
JSON representation
Sample application to show the secured integration of microservices and vaadin
- Host: GitHub
- URL: https://github.com/khauser/microservices4vaadin
- Owner: khauser
- Created: 2015-12-21T09:30:22.000Z (about 9 years ago)
- Default Branch: master
- Last Pushed: 2020-09-18T11:48:49.000Z (over 4 years ago)
- Last Synced: 2024-08-03T09:05:45.652Z (6 months ago)
- Topics: authserver, docker, eventstore, gradle, microservice, oauth2, rancher, redis, service-discovery, spring-session, sso, vaadin
- Language: Java
- Size: 783 KB
- Stars: 30
- Watchers: 8
- Forks: 16
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-list-microservice - microservices4vaadin
README
# microservices4vaadin ![CircleCI](https://circleci.com/gh/khauser/microservices4vaadin.png?style=shield&circle-token=e56d14269e12d73dcc8b45b8dad847985d4e20fb) [![Coverage Status](https://coveralls.io/repos/github/khauser/microservices4vaadin/badge.svg?branch=master)](https://coveralls.io/github/khauser/microservices4vaadin?branch=master)
Exemplary application to show the SSO and OAuth2 secured integration of microservices with Spring Cloud and Vaadin. Main concepts in this projects are:
* Microservices ("Software that Fits in Your Head")
* Secured Gateway (SSO and OAuth2)
* Service Discovery
* Circuit Breaking
* Shared Session overall Services
* Event store to fulfill CQRS principles## Architecture:
![Architecture](/doc/Architecture.png)* **Authserver**:
* Authentification and authorization service
* Allows user login and also user registration via REST
* Generates spring session (persisted in Redis) which also holds the security context
* **Configserver**
* Centralized configuration of each service
* **Edge**:
* SSO Gateway to Frontend and also directly to the Backend
* UI for the landing page, the login and the registration panels
* Gets the security context and the user data from spring session
* **Eventstore**:
* Distribute events across microservices via RabbitMQ and persist them in MongoDB
* **Frontend**:
* Vaadin frontend with some simple but responsive UI
* Load balanced (Ribbon) access to backend
* Gets user data from spring session
* **UserService**:
* Represents the user domain
* **Backend**:
* Simple but secured REST resource as backend for the frontend
* **Discovery**: service discovery with eureka
* **Turbine**+**Hystrixdashboard**: use hystrix as circuit breakerToDo:
* add a backend service## Main frameworks:
* Spring: [Boot] (http://projects.spring.io/spring-boot/), [Data JPA] (http://projects.spring.io/spring-data-jpa), [Session] (http://projects.spring.io/spring-session), [Cloud Security] (http://cloud.spring.io/spring-cloud-security)
* [Vaadin] (https://www.vaadin.com/)
* Netflix: [Zuul] (https://github.com/Netflix/zuul), [Eureka] (https://github.com/Netflix/eureka), [Hystrix] (https://github.com/Netflix/Hystrix)
* [AxonFramwork] (http://www.axonframework.org/)
* [Rancher] (http://rancher.com/)## Installation:
* install JDK 8
* install Redis+RabbitMQ+MongoDB+MySQL (you can also use the [docker-compose.yml](docker-compose.yml) file
* Run `gradlew clean build` to compile and build the application
* Run `start-all.bat` to start the list of services
* `http://localhost` should bring you to the landing page (with a redirect to https)## Development:
* Git, Eclipse with Gradle IDE (Buildship), and [lombok] (https://projectlombok.org/)### Set up project:
* checkout git repository
* run `docker-compose up -d` do start dependent Redis, RabbitMQ, MongoDB and MySQL services (also DBs will be added automatically)
* `gradlew clean build` to compile project
* run `start-all.bat` in windows or `start-all.sh` in unix##Deployment:
* The project could be deployed to a rancher stack using the given `rancher-docker-compose.yml`. The databases from above also here need to be added manually, here within the execute shell of the MySQL-container.
![Rancher stack](/doc/rancher_stack_graph.png)* If all works fine (services might need to be restarted) you should see the this landing page:
![Landing page](/doc/landing_page.png)
Initial test credentials then are `[email protected]/quert6`.* Fingers crossed.. Finally the Vaadin UI should show up:
![Vaadin UI](/doc/vaadin_ui.png)