Doorgaan naar hoofdcontent

Microservices Conference 2018 in Berlin - A small recap

Conference

On the 22 and 23rd of March i went to the "Microservices Conference 2018, MicroXchg" in Berlin. This blog post is a short recap of my experience of this conference, which was held for the 4th time.
My goal was to learn more about the Microservices world, to fill my toolset of possible architecture solutions and of course to see Berlin a bit. Furthermore i interviewed Chris Richardson about Microservices and his upcoming book on Patterns. This interview is added to this blog as well.
A note: everything within this blog is purely my own opinion.






Location

The location where the conference was held, was Kalkscheune in Berlin. A nice location with big conference rooms. There were 5 different rooms and everything was recorded.

Overall program

There were 4 parallel sessions with 1 indepth-session. The normal sessions were 50 minutes long, so this was a good time to get some more detailed information and there was also time for questions. As i wanted to have a global idea of the Microservices world, i did not attend any of the indepth-session. I therefore can not tell anything about the level of these sessions. 
The division of the type of sessions was:

  • Technical sessions (i.e. tooling, languages, products): 21 sessions
  • Architectural sessions (i.e. modeling, design, architecture): 17 sessions
  • Organizational sessions (i.e. impact on organisations): 3 sessions

Audience

I did not speak to everyone, but in my opinion the majority of the audience was technical oriented and mostly German. There were also foreign speakers. This gives me the idea that Microservices is still mostly a technical IT party. Maybe not everyone does agree me on that, but the number of managers and CIOs was nihil or maybe even zero. If you want to use the Microservices architecture style within your organization, there will also be a lot of structural consequences. This was a little bit underexposed within the conference.
Of course there were also a couple of stands of the sponsors of the event.




Sessions

Micro frontends

I went to the conference with a couple of questions, one of them was if the UI is part of a Microservice or not. There were 2 great sessions about this topic from Matthias Laug and Elisabeth Engel. Even the term micro frontends was introduced (at least a new term for me). In the talk of Matthias he opt that the front end part should be deployed as 1 microservice, together with the backend part. Aggregation of several Microservices is done using frames and this should be a thin layer.

Sagas

A talk by Chris Richardson about using Sagas to implement data consistency within Microservices and using local transactions i.s.o. two-phase-commit transactions. Saga uses compensation handling and/or event driven architectures to deal with data consistency. This makes the design of such systems not easier.

Event storming

An interesting talk by Lutz Huehnken about designing the microservices boundaries using event storming. This is a method where you do not look at the business entities, but at the events that happening within the processes. The focus is more on the dynamics than on the nouns and structures. The events will then lead to the commands needed and which entities (nouns) are involved. He argued that this will lead to better reactive systems as stated within its manifesto (https://www.reactivemanifesto.org/). I think we will use the design techniques that will have the closest relation with the business problem at hand. But thrilled to have new tools available again.

Service Mesh

I also read about service meshes so was curious what this is all about. Fortunately there was a talk about this subject by Daniel Bryant. A service mesh is about the communication between the services. As services can be executed in several containers within even several hosts, the requests must be routed to a service. So runtime service discovery is needed. A service mesh will take care of this. It can also contain some more (business) rules, so that for example european requests are sent to different containers or hosts. Linkedr, Conduit and Istio are some examples of services meshes. However Daniel warned that care must be taken when using them in production, because they are not mature enough yet. It also sounded for me the new replacement of the ESB, because it is also a central component within service communication and contains routing rules. Lets see how these service meshes evolve.

How to be an architect in a Microservices world

This talk was about the architect Felix Muller and his experiences within the Architecture field. For me there were no specific new elements. He talked about (software) architects in teams and an architecture board for alignment. This is not very different in the way organisations already work. Also technical reviews were mentioned which are not specifically new (at least for me).In a truly Microservice architecture you hope to have less alignment because of the self management of the teams and the loose coupled services. In practice i think this will be not the case, because the services will also share common services (i.e. CI/CD pipelines, service meshes, PaaS and IaaS, security ,API gateways).

Patterns and anti-patterns

Stefan Tilkov is a well known speaker and I know him as one of the first RESTefarian. It is always good fun to watch him and he has always good content to think about. His talk was about patterns and anti-patterns. Those patterns are used as a standard for communication and are not part (yet?) of an official pattern catalog. Chris Richardson is also working on Microservices patterns that can be used. The following anti-patterns were discussed:
  • Distributed monolith (microservices gone through the roof, getting too complex)
  • Decoupling illusion (technical separation does not match the business domain separation)
  • Micro platform (standardization of shared functionality)
  • Entity Service (wide business entities as boundaries)
  • Anemic Service (layering in data services)
  • Unjustified re-use (extremely generic utility functions)
Patterns:
  • Autonomous cells (decentralized domain focused cells)

    Size patterns
  • Function as a Service (FaaS, small services, serverless)
  • microSOA (small self hosted, synchronous)
  • Distributed Domain Driven Design (business events)
  • Self-contained systems (UI+DB)
  • Monoliths

Interview with Chris Richardson

One of the speakers of the conference was Chris Richardson, a well known man within the Microservices world. He is currently writing a book on Microservices patterns, and this will be released soon (see also http://microservices.io/patterns/microservices.html). I got the change to meet him and interview him. Here you can see and listen the interview. Be aware, it was my first interview, i was a little bit nervos and i used my phone to record it. Oh and forgive me for the tight blouse ;-)

Conclusions

The following conclusions i would like to point out:
  • The conference was visited well, but mainly by technical audience
  • A good mix between tooling, frameworks and architecture sessions
  • It gave me a good impression about the status of the Microservices architectural pattern, which on the tooling level is still immature on some points (i.e. Service Meshes)
  • Hopefully will Service Mesh not be the new ESB hell.
  • Breaking down the problem domain in Microservices is hard
  • Languages/frameworks emerge that are more closely related to the modeling of events (i.e. eventuate). This means again that the model is within the language itself (just like it was for object oriented design and OO languages)
  • Entity modeling and business capabilities modeling are really two different modeling techniques of which entity modeling is the most wrongly? used for modeling Microservices
  • CQRS and Event Sourcing are two topics i have to dig into
  • There are a lot of (new) terms and tools within the Microservices world
  • Hopefully next time all presentations and slides are available on the conference site: http://microxchg.io/2018/index.html
In a next blog i hope to share a Microservices reference architecture with a sheet of possible tools/frameworks/products within a particular concept within that architecture.

Reacties

Een reactie posten

Populaire posts van deze blog

OSB 10gR3 and SWA and MTOM

This blog is about using soap with attachments and the use of MTOM within the OSB (10gR3). A service is created that accepts a soap with attachment (DocumentService) and translates it to a service that accepts a binary element. MTOM is used for performance reasons for the second. Some notes: * For the use of attachments you need RPC-style document instead of the usual document-style. This due to the fact that the document-style limits a message to a single . * A service can not have both SWA and MTOM within OSB. First a WSDL is setup for the DocumentService: The $attachments variable holds the attachments and the body holds the attachment data. Also other data is stored within the attachment element (see h

Microservices mindmap

"The tree" - See also   my photo page When you are fairly new within the Microservices land, there are a lot of terms fired at you. So also for my own understanding i have made a mindmap. I think it has a good status now, so that i can share it with you. As always feedback is very welcome ! You can download the mindmap here .

Book review: Data Management at Scale (Piethein Strengholt)

 This blog is a review of the book "Data Management at Scale (See also at bol.com ) Data Management is a hot topic nowadays and this book does a fantastic job at adding value to this topic. It is a must read and one of the few technical books I finished reading in a weekend. The book gives a fantastic overview on how to implement a Data Mesh data architecture. The Data Mesh concept is explained by Martin Fowler here . The book is a good mix between conceptual and implementation architecture level. It gives a lot of examples of how this architecture at scale can work, for both small and big companies. It is practical and I used it to implement it at one of my customers. The book describes an architecture in which the focus is on the DIAL (Data- and Integration Access Layer).  On a high level the book covers the following topics: The key principles for data management at scale - Domain-Driven Design  - Domain Data Stores - Meta data management Ready Data Store The concept of servin