The infrastructure is code: A story of COBOL and Go

COBOL remains the dominant language of mainframes. What can Go learn from its history to dominate the cloud?
213 readers like this.
Listen to the Command Line Heroes Podcast

Old challenges are new again. In this week's Command Line Heroes podcast (Season 3, Episode 5), that thought comes with a twist of programming languages and platforms.

COBOL dominates the mainframe

One of the most brilliant minds in all of computer science is Grace Murray Hopper. Every time we don't have to write in binary to talk to computers, I recommend saying out loud: "Thank you, Rear Admiral Grace Murray Hopper." Try it next time, for she is the one who invented the first compiler (the software that translates programming code to machine language).

Editor’s note: this article previously stated COBOL was the first compiled language, which it is not. Read more on the early days of compiled languages.

Hopper was essential to the invention and adoption of high-level programming languages, including COBOL. She helped create the COmmon Business-Oriented Language (COBOL for short) in 1959. As Ritika Trikha put it on HackerRank:

"Grace Hopper, the mother of COBOL, helped champion the creation of this brand-new programming language that aimed to function across all business systems, saving an immense amount of time and money. Hopper was also the first to believe that programming languages should read just like English instead of computer jargon. Hence why COBOL's syntax is so wordy. But it helped humanize the computing process for businesses during an era when computing was intensive and prevalent only in research facilities."

In the early 1960s, mainframes were a wild new architecture for sharing powerful amounts of computation. And in the era of mainframe computing, COBOL dominated the landscape.

COBOL in today's world

But what about today? With the decline of mainframes and the rise of newer and more innovative languages designed for the web and cloud, where does COBOL sit?

As last week's episode of Command Line Heroes mentioned, in the late 1990s, Perl (as well as JavaScript and C++) was outpacing COBOL. And, as Perl's creator, Larry Wall stated then: "COBOL is no big deal these days since demand for COBOL seems to be trailing off, for some strange reason."

Fast forward to 2019, and COBOL has far from "trailed off." As David Cassel wrote on The New Stack in 2017:

"About 95% of ATM swipes use COBOL code, Reuters reported in April, and the 58-year-old language even powers 80% of in-person transactions. In fact, Reuters calculates that there's still 220 billion lines of COBOL code currently being used in production today, and that every day, COBOL systems handle $3 trillion in commerce."

Given its continued significance in the business world, knowing COBOL can be a great career move. Top COBOL programmers can expect to make six figures due to the limited number of people who specialize in the language.

Go dominates in the cloud, for now

That story of COBOL's early dominance rings a bell for me. If we survey the most influential projects of this cloud computing era, you'd be hard-pressed to miss Go sitting at the top of the pack. Kubernetes and much of its related technology—from Etcd to Prometheus—are written in Go. As RedMonk explored back in 2014:

"Go's rapidly closing in on 1% of total commits and half a percent of projects and contributors. While the trend is obviously interesting, at first glance, numbers well under one percent look inconsequential relative to overall adoption. To provide some context, however, each of the most popular languages on Ohloh (C, C++, Java, JavaScript) only constitute ~10% of commits and ~5% of projects and contributors. That means Go, a seemingly very minor player, is already used nearly one-tenth as much in FOSS as the most popular languages in existence."

In two of my previous jobs, my team (re)wrote infrastructure software in Go to be part of this monumental wave. Influential projects continue to live in the space that Go can fill, as Uday Hiwarale explained well in 2018:

"Things that make Go a great language [are] its simple concurrency model, its package-based code management, and its non-strict (type inference) typing system. Go does not support out-of-the box object-oriented programming experience, but [its] support structures (structs) …, with the help of methods and pointers, can help us achieve the same [outcomes]."

It looks to me like Go could be following in COBOL's footsteps, but questions remain about where it's going. In June 2019, RedMonk ranked Go in 16th place, with a future that could lead either direction.

What can Go learn from COBOL?

If Go were to see into its future, would it look like COBOL's, with such staying power?

The stories told this season by Command Line Heroes illustrate how languages are born, how communities form around them, how they rise in popularity and standardize, and how some slowly decline. What can we learn about the lifespan of programming languages? Do they have a similar arc? Or do they differ?

I think this podcast is well worth subscribing so that you don't miss a single one. I would love to hear your thoughts in the comments below.

What to read next

Is Perl going extinct?

Command Line Heroes explores the meteoric rise of Perl, its fall from the spotlight, and what's next in the programming language's lifecycle.

I'm happiest at a microphone
Matt was an EMC storage expert, VMware vExpert, and former fan of other proprietary technologies. He now focuses on open source and DevRel adoption.

5 Comments

Spelling mistake:
object-priented programming
You meant:
object-oriented programming

History correction: Actually, COBOL was the SECOND such language compiler. FORTRAN came out nearly a full two YEARS before COBOL. Both were magnificent improvements, and both are still being used.

Thank you for correcting me on that fact! I did seem to hop over FORTRAN. I’ll add a note.

In reply to by William B Peckham (not verified)

I actually still write in COBOL, work on some new programs this weekend. runs on win10, GUI interface, MariaDB (moved from MySQL), Linux server. Works great....

Creative Commons LicenseThis work is licensed under a Creative Commons Attribution-Share Alike 4.0 International License.