Work on Hexagonal Architecture presentation
This commit is contained in:
parent
6f3e2985a4
commit
4c24d99414
@ -23,8 +23,8 @@ Allow an application to equally be driven by users, programs, automated test or
|
|||||||
## Applicability
|
## Applicability
|
||||||
Use Hexagonal Architecture pattern when
|
Use Hexagonal Architecture pattern when
|
||||||
|
|
||||||
* it is important that the application is fully testable
|
* When the application needs to be independent of any frameworks
|
||||||
* you use Domain Driven Design methodology and/or Microservices architectural style
|
* When it is important that the application highly maintainable and fully testable
|
||||||
|
|
||||||
## Real world examples
|
## Real world examples
|
||||||
|
|
||||||
|
BIN
hexagonal/etc/hexagon.png
Normal file
BIN
hexagonal/etc/hexagon.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 51 KiB |
BIN
hexagonal/etc/layers.png
Normal file
BIN
hexagonal/etc/layers.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 16 KiB |
95
hexagonal/etc/presentation.html
Normal file
95
hexagonal/etc/presentation.html
Normal file
@ -0,0 +1,95 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<title>Title</title>
|
||||||
|
<meta charset="utf-8">
|
||||||
|
<style>
|
||||||
|
@import url(https://fonts.googleapis.com/css?family=Yanone+Kaffeesatz);
|
||||||
|
@import url(https://fonts.googleapis.com/css?family=Droid+Serif:400,700,400italic);
|
||||||
|
@import url(https://fonts.googleapis.com/css?family=Ubuntu+Mono:400,700,400italic);
|
||||||
|
|
||||||
|
body { font-family: 'Droid Serif'; }
|
||||||
|
h1, h2, h3 {
|
||||||
|
font-family: 'Yanone Kaffeesatz';
|
||||||
|
font-weight: normal;
|
||||||
|
}
|
||||||
|
.remark-code, .remark-inline-code { font-family: 'Ubuntu Mono'; }
|
||||||
|
</style>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<textarea id="source">
|
||||||
|
|
||||||
|
class: center, middle
|
||||||
|
|
||||||
|
# Hexagonal Architecture
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
# Also known as
|
||||||
|
|
||||||
|
* Ports and Adapters
|
||||||
|
* Clean Architecture
|
||||||
|
* Onion Architecture
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
# Layered architecture problems
|
||||||
|
|
||||||
|
* No clear application core
|
||||||
|
* Business logic leaks to the presentation layer
|
||||||
|
<br />
|
||||||
|
<br />
|
||||||
|
|
||||||
|
.center[]
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
# Intent
|
||||||
|
|
||||||
|
* Application can be driven by users, programs, automated test or batch scripts
|
||||||
|
* Application can be developed and tested in isolation from its eventual run-time devices and databases
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
# Applicability
|
||||||
|
|
||||||
|
Use Hexagonal Architecture pattern
|
||||||
|
|
||||||
|
* When the application needs to be independent of any frameworks
|
||||||
|
* When it is important that the application highly maintainable and fully testable
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
# Diagram
|
||||||
|
|
||||||
|
.center[]
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
# Concepts
|
||||||
|
|
||||||
|
* Ports are interfaces
|
||||||
|
* Adapters are implementations
|
||||||
|
* Driver ports vs driven ports
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
# Real world examples
|
||||||
|
|
||||||
|
* [Apache Isis](https://isis.apache.org/)
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
# Implementation example
|
||||||
|
|
||||||
|
* http://java-design-patterns.com/patterns/hexagonal/
|
||||||
|
|
||||||
|
</textarea>
|
||||||
|
<script src="https://gnab.github.io/remark/downloads/remark-latest.min.js">
|
||||||
|
</script>
|
||||||
|
<script>
|
||||||
|
var slideshow = remark.create();
|
||||||
|
</script>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
|
|
@ -1,45 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html>
|
|
||||||
<head>
|
|
||||||
<title>Title</title>
|
|
||||||
<meta charset="utf-8">
|
|
||||||
<style>
|
|
||||||
@import url(https://fonts.googleapis.com/css?family=Yanone+Kaffeesatz);
|
|
||||||
@import url(https://fonts.googleapis.com/css?family=Droid+Serif:400,700,400italic);
|
|
||||||
@import url(https://fonts.googleapis.com/css?family=Ubuntu+Mono:400,700,400italic);
|
|
||||||
|
|
||||||
body { font-family: 'Droid Serif'; }
|
|
||||||
h1, h2, h3 {
|
|
||||||
font-family: 'Yanone Kaffeesatz';
|
|
||||||
font-weight: normal;
|
|
||||||
}
|
|
||||||
.remark-code, .remark-inline-code { font-family: 'Ubuntu Mono'; }
|
|
||||||
</style>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<textarea id="source">
|
|
||||||
|
|
||||||
class: center, middle
|
|
||||||
|
|
||||||
# Title
|
|
||||||
|
|
||||||
---
|
|
||||||
|
|
||||||
# Agenda
|
|
||||||
|
|
||||||
1. Introduction
|
|
||||||
2. Deep-dive
|
|
||||||
3. ...
|
|
||||||
|
|
||||||
---
|
|
||||||
|
|
||||||
# Introduction
|
|
||||||
|
|
||||||
</textarea>
|
|
||||||
<script src="https://gnab.github.io/remark/downloads/remark-latest.min.js">
|
|
||||||
</script>
|
|
||||||
<script>
|
|
||||||
var slideshow = remark.create();
|
|
||||||
</script>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
Loading…
x
Reference in New Issue
Block a user