Ce diaporama a bien été signalé.
Le téléchargement de votre SlideShare est en cours. ×

Implementing Resilience with Micronaut

Publicité
Publicité
Publicité
Publicité
Publicité
Publicité
Publicité
Publicité
Publicité
Publicité
Publicité
Publicité
Chargement dans…3
×

Consultez-les par la suite

1 sur 20 Publicité

Implementing Resilience with Micronaut

Télécharger pour lire hors ligne

Slides from my demonstration of implementing resilience with micronaut framework. The patterns included in the demo consists of the timeout, retry, circuit breaker, and fallback.

Slides from my demonstration of implementing resilience with micronaut framework. The patterns included in the demo consists of the timeout, retry, circuit breaker, and fallback.

Publicité
Publicité

Plus De Contenu Connexe

Similaire à Implementing Resilience with Micronaut (20)

Plus par Naresha K (20)

Publicité

Plus récents (20)

Implementing Resilience with Micronaut

  1. 1. Implementing Resilience with Micronaut Naresha K @naresha_k https://blog.nareshak.com/
  2. 2. About me Developer, Architect & Tech Excellence Coach Founder & Organiser Bangalore Groovy User Group
  3. 3. • The Network is Reliable • Latency is Zero • Bandwidth is Infinite • The Network is Secure • Topology Doesn’t Change • There is One Administrator • Transport Cost is Zero • The Network is Homogeneous https://web.archive.org/web/20171107014323/http://blog.fogcreek.com/eight-fallacies-of-distributed-computing-tech-talk/ Fallacies of distributed computing
  4. 4. Timeout
  5. 5. package com.nareshak.demo import io.micronaut.http.annotation.Get import io.micronaut.http.client.annotation.Client @Client(value = "http://localhost:8081/") interface PresentationClient { @Get("/{presentationId}") PresentationInfo getPresentationInfo(Long presentationId) }
  6. 6. micronaut: http: client: read-timeout: 5s application.yml
  7. 7. Retry
  8. 8. @Retryable(attempts = "5", delay = "2s", multiplier = "2.0") PresentationInfo getPresentation() { }
  9. 9. package com.nareshak.demo import io.micronaut.http.annotation.Get import io.micronaut.http.client.annotation.Client import io.micronaut.retry.annotation.Retryable @Client(value = "http://localhost:8081/") @Retryable(attempts = "5", delay = "2s", multiplier = "2.01") interface PresentationClient { @Get("/{presentationId}") PresentationInfo getPresentationInfo(Long presentationId) }
  10. 10. Circuit Braker
  11. 11. package com.nareshak.demo import io.micronaut.http.client.annotation.Client import io.micronaut.retry.annotation.CircuitBreaker @Client(value = "http://localhost:8081/") @CircuitBreaker(reset = "60s", attempts = "1") interface PresentationClient extends PresentationOps { }
  12. 12. Fallback
  13. 13. package com.nareshak.demo import io.micronaut.retry.annotation.Fallback @Fallback class PresentationClientFallback implements PresentationOps { @Override PresentationInfo getPresentationInfo(Long presentationId) { new PresentationInfo(title: “TBD") } }
  14. 14. References • https://github.com/naresha/agileindia2020resiliencemincronaut • https://micronaut.io/
  15. 15. Thank You

×