In the world of enterprises, every new technological revolution is looked at through two lenses. One is that of a silver bullet by some sections of the enterprises with an attitude of “let’s go do this” or that of in-difference to a fad that “this won’t work.” Interestingly, Docker in particular and containers in general have managed to gain both of these types of followers. In most cases, unfortunately, both of these approaches when it comes to Docker are incorrect. Though it’s the future of software development and delivery, containerization is a few years away from maturity and full enterprise Docker usage is not yet a reality.
The “Docker Cliff” is one of the defining images that summarizes what “Docker in Enterprises” feels like.
Containers in Dev vs. Prod pic.twitter.com/YqDHvigW8r
— Michael Ducy (@mfdii) February 10, 2016
Hype Around Enterprise Docker Usage
As with any new technological movement, the hype around Docker has been one of the leading factors contributing to confusion around “what Docker really is” and “how to use Docker in enterprises.” At the outset, it seems like the way to go: standardize the working environments in an enterprise, build everything locally and just deploy onto standardized environments that attain parity across the enterprise footprint.
That said, it’s just not that easy. Containers solves some specific problems in some very specific settings that are drastically different from large enterprises, and it’s important that all of the current state situations are considered carefully before getting swept away by the hype and attempting enterprise Docker usage.
That said, the future definitely belongs to containers. New applications and new architectures need to invest, consider and forge ahead on some combinations of vagrant+docker especially around services that don’t need large monolithic infrastructure and need to scale dynamically.
Enterprise Docker Usage Is Difficult
Let’s look at a typical enterprise setting:
- Architecture and applications that have evolved over the years if not decades
- Service offerings that have morphed over those years
- Aging, behind the fire-wall infrastructure
- Projects and Program based technological investment vs. investments around technical debts
- Code refactoring that is next to impossible
- Multiple data center application deployments with very little expertise all around the stack in-house
- Lack of technical skills and capabilities in-house in the workforce
- Outlook towards big-bang solutions
When you take a setting like this, containers which come from a paradigm where everything is immutable; everything is a service, and code above all else finds itself in a synergy-less environment. The above list just shows how much enterprises need to evolve and re-imagine before they embark on this journey.
Enterprise Docker Usage: Fundamental Barriers for Entry
With all of the above being applicable, there’s still one over-arching reason why “getting Docker right” will still be a huge challenge: the “system” that drives all things in enterprises. As is true in most cases, it’s not the people, process or technology that’s a problem, it’s the system that combines all of them.
Large enterprises struggle with delivery as they cannot visualize flow, cannot get past the concept of large batch-planning with target dates and find it very hard to take small risks to get better. The urge is to focus on thinking such as “projects need to get delivered for business” or “large testing cycles means more quality” and less on looking at data, looking at work in motion and making small adjustments across the entire pipeline. This system just is not conducive for embracing Docker.
The simplest and the easiest way to get containers wrong is to try to make it work in production by a certain date. The movement you go down this path, the docker cliff is just insurmountable.
How to Get Started with Enterprise Docker Usage
Like with all things DevOps, start very small and start on local. Pick a product and try to re-imagine all things around it that will enable containers to be used right. Invest in the concept of “many-small servers” over one large server. Look at your existing virtualization technologies and re-use automation that is available there to ensure that you are not solving all of the problems at one shot.
Start on your local, build a pipeline to consistently repeat the container strategy through the promotion process and then try to implement in production. There will be a ton of learnings along the way and try to solve them one-after the other and get it right vs. getting into production.
One simple guide:
Getting Started
There are many excellent use cases to get started using Docker in Enterprise environments. A way to get started is to identify an internal application that immediately benefit the Enterprise by implementing Docker containers. Internal applications are great candidates because they enable your deploy team to become familiar with building a pipeline that can deploy from development to production without the impact to any existing external customers. Depending on the internal application, the systems and processes can be put into place to use Docker at scale and apply the correct monitoring tools in place to ensure stability and uptime.
Docker Pipeline
Building a pipeline for your application using containers is similar with one change: the artifact deployed will be a Docker container. Central repositories exist such as Docker Hub that contain container artifacts that can be tagged as public or private. The deploy process can retrieve the latest or specified version and deploy that into the target environment. For localized environments, using Docker containers adds a unique advantage. It simplifies the process for engineers while adding less requirements for installation. Docker containers can easily be started and disposed in a local environment with less dependency issues and an assurance of consistency across all developer machines.
Maintenance
Virtually every modern monitoring service and tool used in Enterprise has Docker compatibility making maintenance of your docker containers an easy new task for your support team. Mounting volumes to your docker containers enables the data to remain separate and managed independently with the existing Enterprises processes to ensure reliability and security of your data. It is recommended to mount all logging directories and enable your docker containers to focus on the application layer, to scale for the desired resource usage.
Enterprise Docker Usage in Production
Docker in enterprises and in production is hard! Very hard! And Docker will not solve all of the problems in a large enterprise but if done right, they will form a very important piece to your organizations capabilities especially around services/applications that are small and need rapid changes and those that can move to or stay in cloud.
This journey to get Docker to cloud can also be a way to get your organization to start a transformative journey to automate your software delivery and re-imagine all of the processes around it. This journey has to be all in where everyone from corporate leadership to production to operations is involved and invested. If done right, this could be a way to setting a foundation from which the enterprise can derive great benefits.
If you have any comments or questions, reach out to us @liatrio or @ravi_kalaga.