193 symposiums and 30,000 attendees since 2001

Michael Nygard

Agile technology leader and dynamicist

Michael Nygard
Michael strives to raise the bar and ease the pain for developers across the country. He shares his passion and energy for improvement with everyone he meets, sometimes even with their permission. Michael has spent the better part of 20 years learning what it means to be a professional programmer who cares about art, quality, and craft. He's always ready to spend time with other developers who are fully engaged and devoted to their work--the "wide awake" developers. On the flip side, he cannot abide apathy or wasted potential.

Michael has been a professional programmer and architect for nearly 20 years. During that time, he has delivered running systems to the U. S. Government, the military, banking, finance, agriculture, and retail industries. More often than not, Michael has lived with the systems he built. This experience with the real world of operations changed his views about software architecture and development forever.

He worked through the birth and infancy of a Tier 1 retail site and has often served as "roving troubleshooter" for other online businesses. These experiences give him a unique perspective on building software for high performance and high reliability in the face of an actively hostile environment.

Most recently, Michael wrote "Release It! Design and Deploy Production-Ready Software", a book that realizes many of his thoughts about building software that does more than just pass QA, it survives the real world. Michael previously wrote numerous articles and editorials, spoke at Comdex, and co-authored one of the early Java books.

Blog

Topics in Architecture

Posted Sunday, January 3, 2010

I'm working on a syllabus for an extensive course on web architecture. This will be for experienced programmers looking to become architects. Like all of my work about architecture, this covers technology, business, and strategi more »

Coupling and Coevolution

Posted Thursday, December 3, 2009

The mighty Mississippi River starts in Minnesota, at Lake Itasca. Every kid in Minnesota has to make the ritual pilgrimage to Itasca State Park at some point, where wading across North America's longest river is a rite of passage. more »

GMail Outage Was a Chain Reaction

Posted Wednesday, September 2, 2009

Google has published an explanation of the widespread GMail outage from September 1st. In this explanation, they trace the root cause to a layer of "r more »

Hadoop versus VPN

Posted Friday, July 31, 2009

I've been doing some work with Hadoop lately, and I just ran into an interesting problem with networking. This isn't a bug, per se, but a conflict in my configuration. I'm running on a laptop, using a pseudo-distr more »

An AspectJ Circuit Breaker

Posted Thursday, July 16, 2009

Spiros Tzavellas pointed me to his implementation of Circuit Breaker. His approach uses AspectJ and can be applied using a bytecode weaver or AspectJ compiler. He's also got unit tests with 8 more »

Two New Circuit Breaker Implementations

Posted Thursday, July 16, 2009

The excellent Will Sargent has created a Circuit Breaker gem that's quite nice. You can read the docs at more »

Workmen, tools, etc.

Posted Wednesday, May 20, 2009

We've all heard the old saw, "It's a poor workman that blames his tools." Let's think about that for a minute. Does it actual mean that a skilled craftsman can do great work with shoddy i more »

Minireview: Beginning Scala

Posted Monday, May 18, 2009

As you can probably tell from my recent posts, I've been learning Scala. I recently dug into another Scala book, Beginning Scala by David Pollak. Beginning Scala is a nice, gentle introduction to this more »

Units of Measure in Scala

Posted Thursday, May 7, 2009

Failure to understand or represent units has caused several major disasters, including the costly Ariane 5 disaster in 1996. This is one of those things that DSLs often get right, but mainstream programming languages just ignore. Or, worse, they more »

Kudos to Relevance and Clojure

Posted Wednesday, May 6, 2009

It's been a while since I blogged anything, mainly because most of my work lately has either been mind-numbing corporate stuff, or so highly contextualized that it wouldn't be productive to write about. Something came up last week, though, that ju more »
Read More Blog Entries »

Presentations

Failures Come In Flavors (part 1)

The typical JEE application does not reach the fabled "five nines" of availability. Far from it. It's more like "double eights". more »

Failures Come In Flavors (part 2)

What can we do about the dismal uptime of typical applications? We are asked to provide "five nines", but only reach 88%, on average. Come learn how to prevent the Stability Antipatterns from biting you. more »

The 90-Minute Startup

Cloud computing is taking the world by storm. Amazon's Web Services, EC2, and S3 provide completely virtual infrastructure, letting startup and existing companies create sites and web applications faster than ever before. In this session, Michael will us more »

Design for Operations

If your software fails in production, nobody will care how great the development project was, or how well the system passed QA. Production operations, the domain of your systems' least-appreciated stakeholders, is where the rubber meets the road. Come l more »

Software Architecture for the Cloud

Servers, storage, networking, backups... more »

Architect for Scale

Is your system small, medium, large, or super-size? Is traffic on it's way up? Architecture patterns and structures that work at one scale seldom work across all of them. more »

Maximizing Your Capacity

Capacity gets lost in dribs and drabs. Small waste adds up, and huge wastes can hide all over your code. Lost capacity can tip your system from cash cow to money pit. more »

DSLs in Scala: Internal and External

We're no longer working in a single language. Programming today is about both consuming and creating languages. We've all heard a lot about domain specific languages (DSLs). more »

Agile Operations

Is "Agile" restricted to "development"? Maybe not. A growing number of companies are exploring the idea of agile operations. more »

High Performance Persistence with Redis

Redis is one of the fresh crop of "NoSQL" storage solutions. It's a distributed key-value store that knows how to deal with data structures. Oh, and it happens to also be incredibly fast. more »

Failures Come In Flavors (part 1)

close

Michael Nygard By Michael Nygard

The typical JEE application does not reach the fabled "five nines" of availability. Far from it. It's more like "double eights". Come see why enterprise applications and web sites are only serving users 88% of the time instead of 99.999%.

Part 1 of 2



The bad news: applications are more complex and error-prone than ever. Site development projects are really enterprise application integration projects in disguise. SOA portends far-flung interdependencies among unreliable services. Failures will spread wider and wider, reaching across your company and even crossing boundaries between companies.

How do monumentally costly failures begin, develop, and spread?

Can they be averted?

Once you hit Release 1.0, your system will be living in the real world. It has to survive everything the messy, noisy real world can throw at it: from flash mobs to Slashdot. Once the public starts beating on your system, it has to survive--without you.

Did you know that just having your database behind a firewall can bring down your system? Ill show you that and many other risks to your system. You will learn the biggest risks to your system and how to counter them with stability design patterns. We'll talk about the best way to define the term "availability" and why the textbooks get it all wrong.

In this session, you will learn why the path to success begins with a failure-oriented mindset. I'll talk about numerous antipatterns that have caused and accelerated millions of dollars worth of system failures. I'll share some of my scars and war stories with you (don't worry, they're all suitable for polite company) in the hopes that you can avoid some of these costly disasters.


Failures Come In Flavors (part 2)

close

Michael Nygard By Michael Nygard

What can we do about the dismal uptime of typical applications? We are asked to provide "five nines", but only reach 88%, on average. Come learn how to prevent the Stability Antipatterns from biting you. Apply these Stability Patterns to contain damage, recover from shocks, and survive disasters.

Part 2 of 2



In part 1, we looked at common sources of system failure: those commonly created structures that exacerbate problems.

Now, we'll take on Stability Patterns that not only stop the antipatterns, but also add resilience to your system. Apply your new failure-oriented mindset to unchain yourself from the pager and save your company from embarrassing--and costly--disasters.

These patterns combat entire classes of failure modes, making your system robust against even unforeseen problems.

Books on design and architecture only tell you how to meet functional requirements. They help your software pass Quality Assurance. But painful experience has shown that "feature complete" is not even close to "production ready." After this talk, you'll be prepared to use your failure-oriented mindset to make your system a success.


The 90-Minute Startup

close

Michael Nygard By Michael Nygard

Cloud computing is taking the world by storm. Amazon's Web Services, EC2, and S3 provide completely virtual infrastructure, letting startup and existing companies create sites and web applications faster than ever before.

In this session, Michael will use cloud computing to create and deploy a fully-functional web site. You will learn how to create and run your own virtual infrastructure in the clouds.



It used to take weeks and months to stand up a new site. You had to buy hardware, rent (or build) space, rack, stack, and cable it, and then you'd finally get to start installing operating systems, databases, and so on.

These days, none of that is necessary. You can run a real business on the net without ever owning anything. Best of all, you can be up and running in a single day.

A day? Trivial you say? OK, we'll make it an hour and a half, with time for questions.


Design for Operations

close

Michael Nygard By Michael Nygard

If your software fails in production, nobody will care how great the development project was, or how well the system passed QA. Production operations, the domain of your systems' least-appreciated stakeholders, is where the rubber meets the road. Come learn how to build your systems to thrive in Operations.



We will explore the most critical foundations for success in Operations: transparency, control, deployments, and configuration.

Along the way, we'll see some of the organizational dysfunction that prevents smooth, successful operations. You'll learn what you can do today to avoid these dysfunctions, even if you've inherited a legacy of distrust between Development and Operations.

If you don't want to wear a pager for the rest of your life, this session is for you.


Software Architecture for the Cloud

close

Michael Nygard By Michael Nygard

Servers, storage, networking, backups... they're all vanishing into the "clouds". Cloud Computing is the emerging architecture for massive, scalable infrastructure that your company doesn't have to own or operate.

In this session, Michael will discuss the ingredients of real cloud computing and how you can apply it to your applications. He will show several architectures and discuss applications that fit each of these models. Finally, he will also talk about some of the pitfalls and problems that cloud computing customers can encounter.



The term "Cloud Computing" can be applied to everything from Software-as-a-Service (formerly known as Application Service Provider) to virtual infrastructure, grid computing, and even remote backup services. Some of these make sense, but some are just bandwagon-jumping and buzzword bingo.

From the "zero servers" web startup to the corporate IT department battling server-sprawl, cloud computing has many manifestations. This session will differentiate among the various types of cloud computing and describe applicable use cases.


Architect for Scale

close

Michael Nygard By Michael Nygard

Is your system small, medium, large, or super-size? Is traffic on it's way up?

Architecture patterns and structures that work at one scale seldom work across all of them. A communication style that's appropriate for small websites will probably fail badly if you apply it to world-wide networks of computers. Likewise, structures that work for large-scale systems are probably too complex and expensive to be worth it for small sites.



In this talk, Michael will discuss the notion of "design envelopes" for architectures. He will explore several common scaling strategies and map them to different system scales.

During this session, Michael will present reference architectures for systems at a variety of scales. It's sometimes possible to scale smoothly from range to range, but it can be extremely disruptive if you don't plan for it.

Along the way, he'll also address the different dimensions of scalability problems: traffic, content, data volume, and operations.


Maximizing Your Capacity

close

Michael Nygard By Michael Nygard

Capacity gets lost in dribs and drabs. Small waste adds up, and huge wastes can hide all over your code. Lost capacity can tip your system from cash cow to money pit. Making the most out of your hardware investment is essential, no matter how big or small your business might be.

We constantly hear the myth that "CPU is cheap", or "disk is cheap". Yet, wasting just 250 milliseconds per transaction means you need 4 extra servers to handle a million transactions per day.

In this session, Michael shows you how to maximize the capacity in the hardware you've already got, by eliminating common errors and applying some straightforward design patterns.



Capacity measures how much revenue your system can generate during a given period of time. Design choices that reduce your capacity directly reduce the company's top-line revenue numbers. Further, by increasing operational costs, they hurt the bottom line, too.

This session will discuss myths about capacity. It will help you eliminate some common design errors that sap your system's capacity, and it will show you some design patterns that can maximize it.


DSLs in Scala: Internal and External

close

Michael Nygard By Michael Nygard

We're no longer working in a single language. Programming today is about both consuming and creating languages.

We've all heard a lot about domain specific languages (DSLs). So much so, in fact, that it seems like more people are talking about it than doing it. In this session, Michael will present a real domain with familiar problems. He'll then demonstrate both an internal DSL and an external DSL that solve the same problem. Along the way, we'll cover fluent interfaces, composing multiple DSLs, and the very cool parser combinators.

If you've ever left a DSL talk wondering when we're ever going to get past the "coffee ordering DSL" or the "Waffle House breakfast DSL", then you will want to see this session.



This session walks through the creation of a domain model with an internal DSL based on a fluent interface in Scala. Although this is not an introduction to Scala, the necessary Scala concepts will be covered sufficiently for anyone to follow.

After demonstrating the domain and the internal DSL, Michael will use parser combinators to build a grammar in just a few lines of code. This grammar will lex and parse the input files, along with constructing domain objects for further use.

Prerequisite: None.


Agile Operations

close

Michael Nygard By Michael Nygard

Is "Agile" restricted to "development"? Maybe not. A growing number of companies are exploring the idea of agile operations. We'll look at how agile concepts translate to the historically rigid realm of the operations group, including issues about deployment, monitoring, change control, and production availability.



Agile software development has successfully entered the mainstream. As we learn more about agile development, we're bumping up against challenges in other parts of the company: budgeting, QA, and operations, to name a few.

The operations group has often been viewed as a roadblock on the path to production. (In much the same way as development groups have been viewed as a barrier to application creation!) We're now seeing companies experimenting with practices to support rapid feedback, automated change, and whole team integration between development and operations.


High Performance Persistence with Redis

close

Michael Nygard By Michael Nygard

Redis is one of the fresh crop of "NoSQL" storage solutions. It's a distributed key-value store that knows how to deal with data structures. Oh, and it happens to also be incredibly fast. Like, microseconds per write.



This session shows how to get Redis set up in standalone and replicated mode and how to start using it for persistence. It will also show some techniques to structure your data to achieve consistency without transactions.



Michael's NFJS Schedule

Milwaukee, WI
Feb 26 - 28, 2010

Boston, MA
Mar 5 - 7, 2010

Minneapolis, MN
Mar 12 - 14, 2010

Reston, VA
Apr 30 - May 2, 2010

St. Louis, MO
May 21 - 23, 2010

Denver, CO
Jun 14 - 17, 2010


Books

by Michael T. Nygard

Release It!: Design and Deploy Production-Ready Software (Pragmatic Programmers) Buy from Amazon
List Price: $34.95
Price: $23.07
You Save: $11.88 (34%)
  • Whether it's in Java, .NET, or Ruby on Rails, getting your application ready to ship is only half the battle. Did you design your system to survivef a sudden rush of visitors from Digg or Slashdot? Or an influx of real world customers from 100 different countries? Are you ready for a world filled with flakey networks, tangled databases, and impatient users?

    If you're a developer and don't want to be on call for 3AM for the rest of your life, this book will help.

    In Release It!, Michael T. Nygard shows you how to design and architect your application for the harsh realities it will face. You'll learn how to design your application for maximum uptime, performance, and return on investment.

    Mike explains that many problems with systems today start with the design.


by Bryan Morgan, Michael Morrison, Michael T. Nygard, Dan Joshi, Tom Trinko, and Mike Cohn

Java Developer's Reference Buy from Amazon
Price: $59.99
  • Java Professional Developer's Reference contains cross references and jump tables to help the reader locate the Java function. The reader is given a complete reference to the Java language installation, other language migrations and integration, the Java compiler, Java application development, the Java interpreter and applet viewer, HTML browers and more.