Criando Microservices Reativos com Java
Rodrigo Cândido da Silva
@rcandidosilva
Agenda
• Monolito vs. Microservices
• Manifesto Reativo
• Resiliência
• Elasticidade
• Message-Driven
• Perguntas
Monolito vs. Microservices
Microservices
• Pequenos
• Deployment interdependente
• Independente de tecnologia
• Infra-estrutura separada
"Small independent component with well-
defined boundaries that’s doing one thing,
but doing it well"
Manifesto Reativo
Resiliência
• Quais os principais desafios?
• Configuração centralizada
• Serviço de registro e descoberta
• Roteamento
• Tolerância à falhas
• Gestão de segurança
Spring BootSpring Cloud
Spring Cloud + Netflix OSS
Spring Cloud + Netflix OSS
“Nice match to build resilient microservices with
Java"
Gerenciamento de Configuração Spring Cloud Config + Bus
Descoberta de Serviços Netflix Eureka
Balanceamento de Carga Netflix Ribbon
Circuit Breaker Netflix Hystrix + Turbine
Proxy Server Netflix Zuul
Segurança Spring Cloud Security
Spring Cloud Config
Netflix Eureka
Netflix Ribbon
Netflix Hystrix
• Circuit Breaker Pattern
Netflix Zuul
Spring Cloud Security
Discovery	
Client
Relying Party
Resource
Server
Get an access token
& an ID Token (JWT)
Use an access token
Authorization
Server
Iden.ty	Provider	or	
IDP	or		
OpenID	Provider	or	
OP	
	
	
Authorization
Endpoint
Token
Endpoint
Important Stuff
Userinfo
Endpoint
Registration
Endpoint
JWKS
Endpoint
JWKS
Endpoint
Validate
(JWT)
ID Token
/.well-known	
/webfinger	
/openid-configura.on
Check Session IFrame
End Session Endpoint
Elasticidade
• Quais os principais desafios?
• Deployment Distribuído
• Auto Escalabilidade
• Orquestração
• Balanceamento de carga
• Redundância
• Monitoramento
Deployment
Deployment
Monolito Microservice
Auto Scaling
• Capacidade de aumentar e diminuir a escalabilidade
automaticamente
Orquestração
• Gerenciamento da comunicação dos serviços em containers
diferentes
Deployment vs Environments
• Múltiplos ambientes diferentes de execução
Monitoramento
• Utilização de ferramentas para agregação logs
• ELK, Sentry, Logentries, Splunk
• Mecanismos de correlação de eventos
• Spring Cloud Sleuth
• Utilização de ferramentas para tracing
• Zipkin, HTrace
• Monitoramento com health check
• Spring Boot Admin
Ferramentas
AWS ECS
Message-Driven
• Quais os principais desafios?
• Comunicação Assíncrona
• Non blocking I/O
• Ambiente Distribuido
• Queuing
• Consistência
• Event sourcing
• CQRS
Blocking vs Non-Blocking
Sync vs Async
Sync
Async
Reactive Programming
• Baseado no consumo de eventos e streams
• “Everything is stream"
• Alteração de dados “over time” (via callbacks)
• Comunicação Async e Non-Blocking
• Modelo publish / subscribe
• Java 9
• java.util.concurrent.Flow
• reactive-streams.org
Alternativas Reativas com Java EE
JMS EJB 3
Message-Driven
Beans
Asynchronous
Session Beans
CDI
Events
Observers
Servlet
Asynchronous
NIO
JAX-RS
Async on Server
Async on Client
WebSocket
Async Remote
Endpoints
Concurrency
Utilities
RxJava
• Biblioteca para criação de non-blocking apps
• Implementação de reactive streams
• Interage com Java 8 functional API
• Suporta comportamentos especiais
• Error handling, scheduling, flow control
• Utilizado pelo Netflix na “async service layer”
RxJava
RxJava
API Gateway
• Design pattern at microservices
• Requisições podem ser apenas repassadas, ou
modificadas
• Pode implementar uma camada de serviços assíncrona
“Single entry point for the service clients”
Service Endpoint
@RestController
public class UserRestController {
private static final List<User> users = new ArrayList<>();
static {
users.add(new User(1, "Rodrigo", "C", "da Silva"));
users.add(new User(2, "Israel", "B", "Rodriguez"));
users.add(new User(3, "Bruno", "", "Souza"));
users.add(new User(4, "Edson", "", "Yanaga"));
}
@RequestMapping(method = RequestMethod.GET, value = "/users")
public List<User> getUsers() {
return users;
}
@RequestMapping(method = RequestMethod.GET, value = "/user/{id}")
public User getUser(@PathVariable("id") Integer id) {
return users.stream().filter(g -> g.getId() == id)
.collect(Collectors.toList()).get(0);
}
}
Async Service Proxy
@Component
public class UserServiceProxy {
@Autowired UserService service;
@HystrixCommand(fallbackMethod = "defaultUsersObservable")
public Observable<List<User>> getUsersObservable() {
return new ObservableResult<List<User>>() {
@Override
public List<User> invoke() {
return service.getUsers();
}
};
}
public Observable<User> defaultUsersObservable() {
return null;
}
} @FeignClient("USER-SERVICE")
public interface UserService {
@RequestMapping(value = "/users", method = RequestMethod.GET)
List<User> getUsers();
@RequestMapping(value = "/user/{id}", method = RequestMethod.GET)
User getUser(@PathVariable("id") Integer id);
}
API Gateway
@RestController
public class APIGateway {
@Autowired
GroupServiceProxy groupService;
@Autowired
UserServiceProxy userService;
@RequestMapping(method = RequestMethod.GET, value = "/userGroups")
public UserGroup getUserGroups() {
Observable<List<Group>> groups = groupService.getGroupsObservable();
Observable<List<User>> users = userService.getUsersObservable();
Observable<UserGroup> userGroupObservable =
Observable.zip(groups, users, (g, u) -> new UserGroup(u, g));
return userGroupObservable.toList().toBlocking().single().get(0);
}
}
Outras Alternativas
Project Reactor
Conclusões
• Arquitetura com microservices é complexa
• Manifesto reativo define princípios para implementar uma
arquitetura de microservices reativa
• Async e Non-Blocking IO são praticas importantes para
atingir princípios reativos
• RxJava oferece uma implementação para streams reativos
• Não se esqueça de implementar API Gateway’s
• Enjoy it ;)
Perguntas
?
References
• http://projects.spring.io/spring-cloud/
• https://netflix.github.io/
• http://www.reactive-streams.org/
• http://www.reactivemanifesto.org/
• https://github.com/reactivemanifesto/website-manifesto/tree/master/public/pdf
• https://github.com/ReactiveX/RxJava
• https://projectreactor.io/
• http://reactivex.io/
• https://cloud.spring.io/spring-cloud-stream/
Muito Obrigado!
@rcandidosilva
rodrigocandido.me

Mais conteúdo relacionado

PDF
TDC Floripa 2016 - Decolando seus micro-serviços na Spring Cloud
PDF
GUJavaSC - Combinando Micro-serviços com Práticas DevOps
PDF
QCon SP 2016 - Construindo Microservices Auto-curáveis com Spring Cloud e Net...
PDF
Workshop Microservices - Microservices com Spring Cloud e Netflix OSS
PDF
GUJavaSC - Combinando AngularJS com Java EE
PDF
Workshop Microservices - Arquitetura Microservices
PDF
QCon 2015 - Combinando AngularJS com Java EE
PDF
JavaOne LATAM 2016 - Combinando AngularJS com Java EE
TDC Floripa 2016 - Decolando seus micro-serviços na Spring Cloud
GUJavaSC - Combinando Micro-serviços com Práticas DevOps
QCon SP 2016 - Construindo Microservices Auto-curáveis com Spring Cloud e Net...
Workshop Microservices - Microservices com Spring Cloud e Netflix OSS
GUJavaSC - Combinando AngularJS com Java EE
Workshop Microservices - Arquitetura Microservices
QCon 2015 - Combinando AngularJS com Java EE
JavaOne LATAM 2016 - Combinando AngularJS com Java EE

Mais procurados (20)

PDF
GUJavaSC - Protegendo Microservices em Java
PDF
Workshop Microservices - Construindo APIs RESTful com Spring Boot
PDF
GUJavaSC - Mini-curso Java EE
PDF
JavaOne LATAM 2015 - Segurança em Recursos RESTful com OAuth2
PDF
JavaOne LATAM 2016 - RESTful Services Simplificado com Spring Data REST
PDF
Workshop Microservices - Distribuindo os Microservices com Docker e Kubernetes
PDF
Microservices
PDF
TDC 2015 - Segurança em Recursos RESTful com OAuth2
PDF
As novidades da nova versão do Java 9
PDF
QCon SP 2016 - WebAPIs e delivery: Matando a fome de 1 milhão de pedidos men...
PDF
Webinar de Final de Ano WSO2: Novidades e Atualizações em nossa plataforma
PDF
Microservices: uma abordagem para arquitetura de aplicações (Devcamp 2015)
PPTX
Reduza seu trabalho de gerenciamento do kubernetes tdc 2018 poa
PDF
Integrando infraestruturas híbridas
PPTX
Windows Azure Pack - Visão Geral
PDF
Vantagens e desvantagens de uma arquitetura microservices
PPTX
Microservices - ALM Roadshow 2015
PPTX
Conteineres no Microsoft Azure
PPTX
Azure Security Center - 120715 - PTBR-Final
PPTX
Windows Server 2016, System Center 2016 e OMS
GUJavaSC - Protegendo Microservices em Java
Workshop Microservices - Construindo APIs RESTful com Spring Boot
GUJavaSC - Mini-curso Java EE
JavaOne LATAM 2015 - Segurança em Recursos RESTful com OAuth2
JavaOne LATAM 2016 - RESTful Services Simplificado com Spring Data REST
Workshop Microservices - Distribuindo os Microservices com Docker e Kubernetes
Microservices
TDC 2015 - Segurança em Recursos RESTful com OAuth2
As novidades da nova versão do Java 9
QCon SP 2016 - WebAPIs e delivery: Matando a fome de 1 milhão de pedidos men...
Webinar de Final de Ano WSO2: Novidades e Atualizações em nossa plataforma
Microservices: uma abordagem para arquitetura de aplicações (Devcamp 2015)
Reduza seu trabalho de gerenciamento do kubernetes tdc 2018 poa
Integrando infraestruturas híbridas
Windows Azure Pack - Visão Geral
Vantagens e desvantagens de uma arquitetura microservices
Microservices - ALM Roadshow 2015
Conteineres no Microsoft Azure
Azure Security Center - 120715 - PTBR-Final
Windows Server 2016, System Center 2016 e OMS
Anúncio

Semelhante a TDC Floripa 2017 - Criando Microservices Reativos com Java (20)

PDF
MC - Java Enterprise Edition 6 (Java EE)
PPTX
Azure Data Overview
PPTX
Microservices & Service Mesh Pattern presentation
PPTX
DevTalk 08/2019
ODP
Microprofile - Como o Java EE esta se adequando aos microserviços
PDF
Goldark - Microservices
PDF
Um método para o desenvolvimento de software baseado em microsserviços
PDF
Microservices reativos e a experiência do iFood
PDF
Devcamp 2017 Microservices Reativos
PDF
Programando interfaces reativas com Xamarin e Reactive UI
PDF
Desenvolvendo software como serviço para negócios
PDF
QConSP 2014 - Cassandra no Desenvolvimento de Aplicações para serviços Móveis
PDF
QConSP 2014 - Cassandra no Desenvolvimento de Aplicações para serviços Móveis
PPSX
Netshoes - API Gateway
PDF
QCon SP 2017 - Reactive Microservices e a experiência do iFood
PPTX
Microservices
PPTX
Microservices com Spring Boot e Spring Cloud Netflix
PDF
5. rodando containers docker na aws
PPTX
Release contínuo de um microsserviço com Docker ASP.net core e Azure Containe...
PDF
Plataforma Android: Produtividade Além do SDK
MC - Java Enterprise Edition 6 (Java EE)
Azure Data Overview
Microservices & Service Mesh Pattern presentation
DevTalk 08/2019
Microprofile - Como o Java EE esta se adequando aos microserviços
Goldark - Microservices
Um método para o desenvolvimento de software baseado em microsserviços
Microservices reativos e a experiência do iFood
Devcamp 2017 Microservices Reativos
Programando interfaces reativas com Xamarin e Reactive UI
Desenvolvendo software como serviço para negócios
QConSP 2014 - Cassandra no Desenvolvimento de Aplicações para serviços Móveis
QConSP 2014 - Cassandra no Desenvolvimento de Aplicações para serviços Móveis
Netshoes - API Gateway
QCon SP 2017 - Reactive Microservices e a experiência do iFood
Microservices
Microservices com Spring Boot e Spring Cloud Netflix
5. rodando containers docker na aws
Release contínuo de um microsserviço com Docker ASP.net core e Azure Containe...
Plataforma Android: Produtividade Além do SDK
Anúncio

Mais de Rodrigo Cândido da Silva (14)

PDF
Java 9, 10 e ... 11
PDF
Cloud Native Java EE
PDF
Protegendo Microservices: Boas Práticas e Estratégias de Implementação
PDF
Protecting Java Microservices: Best Practices and Strategies
PDF
GUJavaSC - Criando Micro-serviços Reativos com Java
PDF
JavaOne 2016 - Reactive Microservices with Java and Java EE
PDF
JavaOne LATAM 2015 - Batch Processing: Processamento em Lotes no Mundo Corpor...
PDF
ConFoo 2015 - Supporting Multi-tenancy Applications with Java EE
PDF
ConFoo 2015 - Securing RESTful resources with OAuth2
PDF
GUJavaSC - Unit Testing com Java EE
PDF
JavaOne 2014 - Securing RESTful Resources with OAuth2
PDF
JavaOne 2014 - Supporting Multi-tenancy Applications with Java EE
PDF
Suportando Aplicações Multi-tenancy com Java EE
PDF
Batch Processing - Processamento em Lotes no Mundo Corporativo
Java 9, 10 e ... 11
Cloud Native Java EE
Protegendo Microservices: Boas Práticas e Estratégias de Implementação
Protecting Java Microservices: Best Practices and Strategies
GUJavaSC - Criando Micro-serviços Reativos com Java
JavaOne 2016 - Reactive Microservices with Java and Java EE
JavaOne LATAM 2015 - Batch Processing: Processamento em Lotes no Mundo Corpor...
ConFoo 2015 - Supporting Multi-tenancy Applications with Java EE
ConFoo 2015 - Securing RESTful resources with OAuth2
GUJavaSC - Unit Testing com Java EE
JavaOne 2014 - Securing RESTful Resources with OAuth2
JavaOne 2014 - Supporting Multi-tenancy Applications with Java EE
Suportando Aplicações Multi-tenancy com Java EE
Batch Processing - Processamento em Lotes no Mundo Corporativo

Último (17)

PPTX
ccursoammaiacursoammaiacursoammaia123456
PDF
Visão geral da SAP, SAP01 Col18, Introdução sistema SAP,
PPTX
3b - Bradesco Lean Agile Training Plan - Ritos Operacionais (1).pptx
PPTX
Aula 9 - Funções em Python (Introdução à Ciência da Computação)
PDF
Processamento da remessa no SAP ERP, SCM610 Col15
PPTX
Proposta de Implementação de uma Rede de Computador Cabeada.pptx
PDF
Aula 9 - Funções 202yttvrcrg5-1.pptx.pdf
PDF
SEMINÁRIO DE IHC - A interface Homem-Máquina
PDF
Banco de Dados 2atualização de Banco de d
PPT
Aula de Engenharia de Software principais caracteristicas
PDF
eBook - GUIA DE CONSULTA RAPIDA EM ROTEADORES E SWITCHES CISCO - VOL I.pdf
PDF
Jira Software projetos completos com scrum
PDF
Customizing básico em SAP Extended Warehouse Management, EWM110 Col26
PPTX
Tipos de servidor em redes de computador.pptx
PDF
Processos no SAP Extended Warehouse Management, EWM100 Col26
PPTX
Analise Estatica de Compiladores para criar uma nova LP
PPT
Conceitos básicos de Redes Neurais Artificiais
ccursoammaiacursoammaiacursoammaia123456
Visão geral da SAP, SAP01 Col18, Introdução sistema SAP,
3b - Bradesco Lean Agile Training Plan - Ritos Operacionais (1).pptx
Aula 9 - Funções em Python (Introdução à Ciência da Computação)
Processamento da remessa no SAP ERP, SCM610 Col15
Proposta de Implementação de uma Rede de Computador Cabeada.pptx
Aula 9 - Funções 202yttvrcrg5-1.pptx.pdf
SEMINÁRIO DE IHC - A interface Homem-Máquina
Banco de Dados 2atualização de Banco de d
Aula de Engenharia de Software principais caracteristicas
eBook - GUIA DE CONSULTA RAPIDA EM ROTEADORES E SWITCHES CISCO - VOL I.pdf
Jira Software projetos completos com scrum
Customizing básico em SAP Extended Warehouse Management, EWM110 Col26
Tipos de servidor em redes de computador.pptx
Processos no SAP Extended Warehouse Management, EWM100 Col26
Analise Estatica de Compiladores para criar uma nova LP
Conceitos básicos de Redes Neurais Artificiais

TDC Floripa 2017 - Criando Microservices Reativos com Java

  • 1. Criando Microservices Reativos com Java Rodrigo Cândido da Silva @rcandidosilva
  • 2. Agenda • Monolito vs. Microservices • Manifesto Reativo • Resiliência • Elasticidade • Message-Driven • Perguntas
  • 4. Microservices • Pequenos • Deployment interdependente • Independente de tecnologia • Infra-estrutura separada "Small independent component with well- defined boundaries that’s doing one thing, but doing it well"
  • 6. Resiliência • Quais os principais desafios? • Configuração centralizada • Serviço de registro e descoberta • Roteamento • Tolerância à falhas • Gestão de segurança
  • 7. Spring BootSpring Cloud Spring Cloud + Netflix OSS
  • 8. Spring Cloud + Netflix OSS “Nice match to build resilient microservices with Java" Gerenciamento de Configuração Spring Cloud Config + Bus Descoberta de Serviços Netflix Eureka Balanceamento de Carga Netflix Ribbon Circuit Breaker Netflix Hystrix + Turbine Proxy Server Netflix Zuul Segurança Spring Cloud Security
  • 12. Netflix Hystrix • Circuit Breaker Pattern
  • 14. Spring Cloud Security Discovery Client Relying Party Resource Server Get an access token & an ID Token (JWT) Use an access token Authorization Server Iden.ty Provider or IDP or OpenID Provider or OP Authorization Endpoint Token Endpoint Important Stuff Userinfo Endpoint Registration Endpoint JWKS Endpoint JWKS Endpoint Validate (JWT) ID Token /.well-known /webfinger /openid-configura.on Check Session IFrame End Session Endpoint
  • 15. Elasticidade • Quais os principais desafios? • Deployment Distribuído • Auto Escalabilidade • Orquestração • Balanceamento de carga • Redundância • Monitoramento
  • 18. Auto Scaling • Capacidade de aumentar e diminuir a escalabilidade automaticamente
  • 19. Orquestração • Gerenciamento da comunicação dos serviços em containers diferentes
  • 20. Deployment vs Environments • Múltiplos ambientes diferentes de execução
  • 21. Monitoramento • Utilização de ferramentas para agregação logs • ELK, Sentry, Logentries, Splunk • Mecanismos de correlação de eventos • Spring Cloud Sleuth • Utilização de ferramentas para tracing • Zipkin, HTrace • Monitoramento com health check • Spring Boot Admin
  • 23. Message-Driven • Quais os principais desafios? • Comunicação Assíncrona • Non blocking I/O • Ambiente Distribuido • Queuing • Consistência • Event sourcing • CQRS
  • 26. Reactive Programming • Baseado no consumo de eventos e streams • “Everything is stream" • Alteração de dados “over time” (via callbacks) • Comunicação Async e Non-Blocking • Modelo publish / subscribe • Java 9 • java.util.concurrent.Flow • reactive-streams.org
  • 27. Alternativas Reativas com Java EE JMS EJB 3 Message-Driven Beans Asynchronous Session Beans CDI Events Observers Servlet Asynchronous NIO JAX-RS Async on Server Async on Client WebSocket Async Remote Endpoints Concurrency Utilities
  • 28. RxJava • Biblioteca para criação de non-blocking apps • Implementação de reactive streams • Interage com Java 8 functional API • Suporta comportamentos especiais • Error handling, scheduling, flow control • Utilizado pelo Netflix na “async service layer”
  • 31. API Gateway • Design pattern at microservices • Requisições podem ser apenas repassadas, ou modificadas • Pode implementar uma camada de serviços assíncrona “Single entry point for the service clients”
  • 32. Service Endpoint @RestController public class UserRestController { private static final List<User> users = new ArrayList<>(); static { users.add(new User(1, "Rodrigo", "C", "da Silva")); users.add(new User(2, "Israel", "B", "Rodriguez")); users.add(new User(3, "Bruno", "", "Souza")); users.add(new User(4, "Edson", "", "Yanaga")); } @RequestMapping(method = RequestMethod.GET, value = "/users") public List<User> getUsers() { return users; } @RequestMapping(method = RequestMethod.GET, value = "/user/{id}") public User getUser(@PathVariable("id") Integer id) { return users.stream().filter(g -> g.getId() == id) .collect(Collectors.toList()).get(0); } }
  • 33. Async Service Proxy @Component public class UserServiceProxy { @Autowired UserService service; @HystrixCommand(fallbackMethod = "defaultUsersObservable") public Observable<List<User>> getUsersObservable() { return new ObservableResult<List<User>>() { @Override public List<User> invoke() { return service.getUsers(); } }; } public Observable<User> defaultUsersObservable() { return null; } } @FeignClient("USER-SERVICE") public interface UserService { @RequestMapping(value = "/users", method = RequestMethod.GET) List<User> getUsers(); @RequestMapping(value = "/user/{id}", method = RequestMethod.GET) User getUser(@PathVariable("id") Integer id); }
  • 34. API Gateway @RestController public class APIGateway { @Autowired GroupServiceProxy groupService; @Autowired UserServiceProxy userService; @RequestMapping(method = RequestMethod.GET, value = "/userGroups") public UserGroup getUserGroups() { Observable<List<Group>> groups = groupService.getGroupsObservable(); Observable<List<User>> users = userService.getUsersObservable(); Observable<UserGroup> userGroupObservable = Observable.zip(groups, users, (g, u) -> new UserGroup(u, g)); return userGroupObservable.toList().toBlocking().single().get(0); } }
  • 36. Conclusões • Arquitetura com microservices é complexa • Manifesto reativo define princípios para implementar uma arquitetura de microservices reativa • Async e Non-Blocking IO são praticas importantes para atingir princípios reativos • RxJava oferece uma implementação para streams reativos • Não se esqueça de implementar API Gateway’s • Enjoy it ;)
  • 38. References • http://projects.spring.io/spring-cloud/ • https://netflix.github.io/ • http://www.reactive-streams.org/ • http://www.reactivemanifesto.org/ • https://github.com/reactivemanifesto/website-manifesto/tree/master/public/pdf • https://github.com/ReactiveX/RxJava • https://projectreactor.io/ • http://reactivex.io/ • https://cloud.spring.io/spring-cloud-stream/