data:image/s3,"s3://crabby-images/692bc/692bc2a00c0f69f6ac8518f1052eb04c3ba06ff9" alt="Eliminating Local Resource Constraints for Building Cloud Native Apps"
Telepresence
A guide to setting up shared development environments for teams on Kubernetes.
Is Minikube melting your laptop? Are your local integration tests suffering because you can’t run dependencies on your development machine?
As organizations adopt Kubernetes and cloud native architectures, development teams will often run into resource constraints as their architectures get more complex. Additionally, Kubernetes presents new challenges for configuring local development environments in comparison with legacy monolithic applications.
January 18, 2018 | 5 min read
data:image/s3,"s3://crabby-images/2f534/2f534477521c769d562f0a6f7aeb45a94796d0a7" alt="Docker for Mac with Kubernetes"
Telepresence
Docker released a beta version of Docker that includes Kubernetes support. I was excited to try it out on my Mac. Here are my notes and observations from experimenting with Docker for Mac with Kubernetes.
Installation
The Docker folks usually do a great job with a simple user experience, and installation was no exception. I downloaded the edge installer for Docker, which uninstalled my stable version of Docker. In the preferences pane, I enabled Kubernetes, and shortly thereafter, I had a working Kubernetes cluster.
January 10, 2018 | 3 min read
data:image/s3,"s3://crabby-images/64fc1/64fc1a608112fed768feeaaa325c5cdb88e70006" alt="Deploying Envoy with a Python Flask webapp"
Kubernetes API Gateway
In the first post in this series, Getting Started with Lyft Envoy for microservice resilience, we explored Envoy a bit, dug into how it worked and deployed an application using Kubernetes, Postgres, Flask, and Envoy.
The Application
In this tutorial, we will deploy a straightforward REST-based user service: it can create users, read information about a user, and process simple logins. Obviously, this isn’t terribly interesting by itself, but it brings several real-world concerns together:
December 15, 2017 | 17 min read
data:image/s3,"s3://crabby-images/b6fa8/b6fa81bf1cde8594deb700ad67ba8e69f1b5561c" alt="Deploying Envoy as an API Gateway for Microservices"
Kubernetes API Gateway
An API Gateway is a façade that sits between the consumers and producers of an API. Cross-cutting functionality such as authentication, monitoring, and traffic management is implemented in your API Gateway so that your services can remain unaware of these details. In addition, when multiple services are responsible for different APIs (e.g., in a microservices architecture), an API Gateway hides this abstraction detail from the consumer.
There are dozens of different options for API Gateways, depending on your requirements. The Amazon API Gateway is a hosted Gateway that runs in Amazon. You could build your own on top of a Layer 7 proxy such as Traefik, NGINX, HAProxy, or Envoy. These all have their various strengths and weaknesses.
In general, though, you want to pick an API gateway that can accelerate your development workflow. Traditional API gateways focus on the challenges of API management, so using an Kubernetes API gateway that enables rapid development of services is essential.
November 8, 2017 | 8 min read
data:image/s3,"s3://crabby-images/eb722/eb722d8e432dc1f7f9cef2e4ddf2f6baaa397d75" alt="Envoy Proxy for microservices resilience"
Kubernetes API Gateway
Using microservices to solve real-world problems always involves more than simply writing the code. You need to test your services. You need to figure out how to do continuous deployment. You need to work out clean, elegant, resilient ways for them to talk to each other.
A really interesting tool that can help with the “talk to each other” bit is the Envoy Proxy from Lyft.
Envoy Proxy Overview
October 17, 2017 | 14 min read
data:image/s3,"s3://crabby-images/7973d/7973d615b74381851260ba410c43cf5ee797c0fd" alt="Shared Development"
Telepresence
So far, we've talked about a single developer / single service workflow. But developers work as part of a larger application team that consists of multiple services. This presents two common scenarios:
How do multiple developers simultaneously develop the same service
How do you develop services that are used by other services?
September 14, 2017 | 3 min read