title: “Command-line Interfaces (CLIs)” linkTitle: “Command-line Interfaces (CLIs)” description: “With popular open source packages and a robust standard library, use Go to create fast and elegant CLIs.” date: 2019-10-04T15:26:31-04:00 series: Use Cases icon: file: clis-green.svg alt: CLI icon iconDark: file: clis-white.svg alt: CLI icon

Overview {#overview .sectionHeading}

CLI developers prefer Go for portability, performance, and ease of creation

Command line interfaces (CLIs), unlike graphical user interfaces (GUIs), are text-only. Cloud and infrastructure applications are primarily CLI-based due to their easy automation and remote capabilities.

Key benefits {#key-benefits .sectionHeading}

Leverage fast compile times to build programs that start quickly and run on any system

Developers of CLIs find Go to be ideal for designing their applications. Go compiles very quickly into a single binary, works across platforms with a consistent style, and brings a strong development community. From a single Windows or Mac laptop, developers can build a Go program for every one of the dozens of architectures and operating systems Go supports in a matter of seconds, no complicated build farms are needed. No other compiled language can be built as portably or quickly. Go applications are built into a single self contained binary making installing Go applications trivial.

Specifically, programs written in Go run on any system without requiring any existing libraries, runtimes, or dependencies. And programs written in Go have an immediate startup time—similar to C or C++ but unobtainable with other programming languages.

Use Case {#use-case .sectionHeading}

Use Go for building elegant CLIs

{{backgroundquote author: Steve Domino title: senior engineer and architect at Strala link: https://medium.com/@skdomino/writing-better-clis-one-snake-at-a-time-d22e50e60056 quote: | I was tasked with building our CLI tool and found two really great projects, Cobra and Viper, which make building CLI’s easy. Individually they are very powerful, very flexible and very good at what they do. But together they will help you show your next CLI who is boss!}}

{{backgroundquote author: Francesc Campoy title: VP of product at DGraph Labs and producer of Just For Func videos link: https://www.youtube.com/watch?v=WvWPGVKLvR4 quote: | Cobra is a great product to write small tools or even large ones. It’s more of a framework than a library, because when you call the binary that would create a skeleton, then you would be adding code in between.”}}

When developing CLIs in Go, two tools are widely used: Cobra & Viper.

{{pkg “github.com/spf13/cobra” “Cobra”}} is both a library for creating powerful modern CLI applications and a program to generate applications and CLI applications in Go. Cobra powers most of the popular Go applications including CoreOS, Delve, Docker, Dropbox, Git Lfs, Hugo, Kubernetes, and many more. With integrated command help, autocomplete and documentation “[it] makes documenting each command really simple,” says Alex Ellis, founder of OpenFaaS.

{{pkg “github.com/spf13/viper” “Viper”}} is a complete configuration solution for Go applications, designed to work within an app to handle configuration needs and formats. Cobra and Viper are designed to work together.

Viper supports nested structures in the configuration, allowing CLI developers to manage the configuration for multiple parts of a large application. Viper also provides all of the tooling need to easily build twelve factor apps.

“If you don’t want to pollute your command line, or if you’re working with sensitive data which you don’t want to show up in the history, it’s a good idea to work with environment variables. To do this, you can use Viper,” suggests Geudens.

{{projects `

  • company: Comcast url: https://xfinity.com/ logoSrc: comcast.svg logoSrcDark: comcast.svg desc: Comcast uses Go for a CLI client used to publish and subscribe to its high-traffic sites. The company also supports an open source client library which is written in Go - designed for working with Apache Pulsar. ctas:
  • company: GitHub url: https://github.com/ logoSrc: github.svg logoSrcDark: github.svg desc: GitHub uses Go for a command-line tool that makes it easier to work with GitHub, wrapping git in order to extend it with extra features and commands. ctas:
  • company: Hugo url: https://gohugo.io/ logoSrc: hugo.svg logoSrcDark: hugo.svg desc: Hugo is one of the most popular Go CLI applications powering thousands of sites, including this one. One reason for its popularity is its ease of install thanks to Go. Hugo author Bjørn Erik Pedersen writes “The single binary takes most of the pain out of installation and upgrades.” ctas:
  • company: Kubernetes url: https://kubernetes.com/ logoSrc: kubernetes.svg logoSrcDark: kubernetes.svg desc: Kubernetes is one of the most popular Go CLI applications. Kubernetes Creator, Joe Beda, said that for writing Kubernetes, “Go was the only logical choice”. Calling Go “the sweet spot” between low level languages like C++ and high level languages like Python. ctas:
  • company: MongoDB url: https://mongodb.com/ logoSrc: mongodb.svg logoSrcDark: mongodb.svg desc: MongoDB chose to implement their Backup CLI Tool in Go citing Go’s “C-like syntax, strong standard library, the resolution of concurrency problems via goroutines, and painless multi-platform distribution” as reasons. ctas:
  • company: Netflix url: https://netflix.com/ logoSrc: netflix.svg logoSrcDark: netflix.svg desc: Netflix uses Go to build the CLI application ChaosMonkey, an application responsible for randomly terminating instances in production to ensure that engineers implement their services to be resilient to instance failures. ctas:
  • company: Stripe url: https://stripe.com/ logoSrc: stripe.svg logoSrcDark: stripe.svg desc: Stripe uses Go for the Stripe CLI aimed to help build, test, and manage a Stripe integration right from the terminal. ctas:
  • company: Uber url: https://uber.com/ logoSrc: uber.svg logoSrcDark: uber.svg desc: Uber uses Go for several CLI tools, including the CLI API for Jaeger, a distributed tracing system used for monitoring microservice distributed systems. ctas:

Get Started {#get-started .sectionHeading}

Go books for creating CLIs

{{books `

{{libraries `