Зарегистрироваться
Восстановить пароль
FAQ по входу

Jeffery Travis. Distributed Services with Go: Your Guide to Reliable, Scalable, and Maintainable Systems

  • Файл формата zip
  • размером 1,50 МБ
  • содержит документ формата epub
Jeffery Travis. Distributed Services with Go: Your Guide to Reliable, Scalable, and Maintainable Systems
The Pragmatic Programmers, LLC., 2021. — 260 p. — ISBN: 978-1680507607.
This is the book for Gophers who want to learn how to build distributed systems. You know the basics of Go and are eager to put your knowledge to work. Build distributed services that are highly available, resilient, and scalable. This book is just what you need to apply Go to real-world situations. Level up your engineering skills today.
Take your Go skills to the next level by learning how to design, develop, and deploy a distributed service. Start from the bare essentials of storage handling, then work your way through networking a client and server, and finally to distributing server instances, deployment, and testing. All this will make coding in your day job or side projects easier, faster, and more fun.
Create your own distributed services and contribute to open source projects. Build networked, secure clients and servers with gRPC. Gain insights into your systems and debug issues with observable services instrumented with metrics, logs, and traces. Operate your own Certificate Authority to authenticate internal web services with TLS. Automatically handle when nodes are added or removed to your cluster with service discovery. Coordinate distributed systems with replicated state machines powered by the Raft consensus algorithm. Lay out your applications and libraries to be modular and easy to maintain. Write CLIs to configure and run your applications. Run your distributed system locally and deploy to the cloud with Kubernetes. Test and benchmark your applications to ensure they’re correct and fast.
Dive into writing Go and join the hundreds of thousands who are using it to build software for the real world.
Contents & Extracts
Get Started
Let’s Go
How JSON over HTTP Services Fits into Distributed Systems
Set Up the Project
Build a Commit Log Prototype
Build a JSON over HTTP Server
Run Your Server
Test Your API
What You Learned
Structure Data with Protocol Buffers excerpt
Why Use Protocol Buffers?
Install the Protocol Buffer Compiler
Define Your Domain Types as Protocol Buffers
Compile Protocol Buffers
Work with the Generated Code
What You Learned
Write a Log Package
The Log Is a Powerful Tool
How Logs Work
Build a Log
What You Learned
Network
Serve Requests with gRPC excerpt
What Is gRPC?
Goals When Building a Service
Define a gRPC Service
Compile with the gRPC Plugin
Implement a gRPC Server
Register Your Server
Test a gRPC Server and Client
What You Learned
Secure Your Services
Secure Services in Three Steps
Authenticate the Server with TLS
Authenticate the Client with Mutual TLS Authentication
Authorize with Access Control Lists
What You Learned
Observe Your Systems
Three Types of Telemetry Data
Make Your Service Observable
What You Learned
Distribute
Server-to-Server Service Discovery
Why Use Service Discovery? excerpt
Embed Service Discovery
Discover Services with Serf
Request Discovered Services and Replicate Logs
Test Discovery and the Service End-to-End
What You Learned
Coordinate Your Services with Consensus
What Is Raft and How Does It Work?
Implement Raft in Our Service
Multiplex to Run Multiple Services on One Port
What You Learned
Discover Servers and Load Balance from the Client
Three Load-Balancing Strategies
Load Balance on the Client in gRPC
Make Servers Discoverable
Resolve the Servers
Route and Balance Requests with Pickers
Test Discovery and Balancing End-to-End
What You Learned
Deploy
Deploy Applications with Kubernetes Locally
What Is Kubernetes?
Install kubectl
Use Kind for Local Development and Continuous Integration
Write an Agent Command-Line Interface
Build Your Docker Image
Configure and Deploy Your Service with Helm
Advertise Raft on the Fully Qualified Domain Name
What You Learned
Deploy Applications with Kubernetes to the Cloud
Create a Google Kubernetes Engine Cluster
Create Custom Controllers with Metacontroller
Deploy to the Internet
What You Learned
Author
Travis Jeffery is a Canadian software maker and writer. He’s created software since 2001; hacked on open source projects like Jocko, Timecop, Mocha; and built several startups from the ground up, including Segment and Confluent.
  • Чтобы скачать этот файл зарегистрируйтесь и/или войдите на сайт используя форму сверху.
  • Регистрация