Network Programming with Go: Code Secure and Reliable Network Services from Scratch
- 5h 56m
- Adam Woodbeck
- No Starch Press
- 2021
Build simple, reliable, network software
Combining the best parts of many other programming languages, Go is fast, scalable, and designed for high-performance networking and multiprocessing. In other words, it’s perfect for network programming.
Network Programming with Go will help you leverage Go to write secure, readable, production-ready network code. In the early chapters, you’ll learn the basics of networking and traffic routing. Then you’ll put that knowledge to use as the book guides you through writing programs that communicate using TCP, UDP, and Unix sockets to ensure reliable data transmission.
As you progress, you’ll explore higher-level network protocols like HTTP and HTTP/2 and build applications that securely interact with servers, clients, and APIs over a network using TLS.
You'll also learn:
- Internet Protocol basics, such as the structure of IPv4 and IPv6, multicasting, DNS, and network address translation
- Methods of ensuring reliability in socket-level communications
- Ways to use handlers, middleware, and multiplexers to build capable HTTP applications with minimal code
- Tools for incorporating authentication and encryption into your applications using TLS
- Methods to serialize data for storage or transmission in Go-friendly formats like JSON, Gob, XML, and protocol buffers
- Ways of instrumenting your code to provide metrics about requests, errors, and more
- Approaches for setting up your application to run in the cloud (and reasons why you might want to)
Network Programming with Go is all you’ll need to take advantage of Go’s built-in concurrency, rapid compiling, and rich standard library.
Covers Go 1.15 (Backward compatible with Go 1.12 and higher)
About the Author
Adam Woodbeck is a senior software engineer at Barracuda Networks, where he implemented a distributed cloud environment in Go to supplant the previous cloud infrastructure, profoundly increasing its scalability and performance. He’s since served as the architect for many network-based services in Go.
In this Book
-
Introduction
-
An Overview of Networked Systems
-
Resource Location and Traffic Routing
-
Reliable TCP Data Streams
-
Sending TCP Data
-
Unreliable UDP Communication
-
Ensuring UDP Reliability
-
Unix Domain Sockets
-
Writing HTTP Clients
-
Building HTTP Services
-
Caddy: A Contemporary Web Server
-
Securing Communications with TLS
-
Data Serialization
-
Logging and Metrics
-
Moving to the Cloud