Sign In Start Free Trial
Account

Add to playlist

Create a Playlist

Modal Close icon
You need to login to use this feature.
  • Book Overview & Buying Go Programming Cookbook
  • Table Of Contents Toc
Go Programming Cookbook

Go Programming Cookbook - Second Edition

By : Torres
3.4 (11)
close
close
Go Programming Cookbook

Go Programming Cookbook

3.4 (11)
By: Torres

Overview of this book

Go (or Golang) is a statically typed programming language developed at Google. Known for its vast standard library, it also provides features such as garbage collection, type safety, dynamic-typing capabilities, and additional built-in types. This book will serve as a reference while implementing Go features to build your own applications. This Go cookbook helps you put into practice the advanced concepts and libraries that Golang offers. The recipes in the book follow best practices such as documentation, testing, and vendoring with Go modules, as well as performing clean abstractions using interfaces. You'll learn how code works and the common pitfalls to watch out for. The book covers basic type and error handling, and then moves on to explore applications, such as websites, command-line tools, and filesystems, that interact with users. You'll even get to grips with parallelism, distributed systems, and performance tuning. By the end of the book, you'll be able to use open source code and concepts in Go programming to build enterprise-class applications without any hassle.
Table of Contents (16 chapters)
close
close

Implementing basic consensus using Raft

Raft is a consensus algorithm. It allows distributed systems to keep a shared and managed state (https://raft.github.io/). Setting up a Raft system is complex in many ways – for one, you need consensus for an election to occur and succeed. This can be difficult to bootstrap when you're working with multiple nodes and can be difficult to get started. It is possible to run a basic cluster on a single node/leader. However, if you want redundancy, at least three nodes are needed to prevent data loss in the case of a single node failure. This concept is known as quorum, where you must maintain (n/2)+1 available nodes to ensure new logs can be committed to the Raft cluster. Basically, if you can maintain quorum, the cluster remains healthy and usable.

This recipe implements a basic in-memory Raft cluster, constructs a state machine that can transition between certain allowed states, and connects the distributed state machine...

Visually different images
CONTINUE READING
83
Tech Concepts
36
Programming languages
73
Tech Tools
Icon Unlimited access to the largest independent learning library in tech of over 8,000 expert-authored tech books and videos.
Icon Innovative learning tools, including AI book assistants, code context explainers, and text-to-speech.
Icon 50+ new titles added per month and exclusive early access to books as they are being written.
Go Programming Cookbook
notes
bookmark Notes and Bookmarks search Search in title playlist Add to playlist download Download options font-size Font size

Change the font size

margin-width Margin width

Change margin width

day-mode Day/Sepia/Night Modes

Change background colour

Close icon Search
Country selected

Close icon Your notes and bookmarks

Confirmation

Modal Close icon
claim successful

Buy this book with your credits?

Modal Close icon
Are you sure you want to buy this book with one of your credits?
Close
YES, BUY

Submit Your Feedback

Modal Close icon
Modal Close icon
Modal Close icon