- Docker High Performance(Second Edition)
- Allan Espinosa Russ McKendrick
- 447字
- 2021-06-24 14:32:40
Importance of configuration management
The Docker Engine has several parameters to tune, such as cgroups, memory, CPU, filesystems, networking, and so on. Identifying which Docker containers run on which Docker hosts is another aspect of configuration. Getting the combination of parameters to optimize our application will take time.
Replicating all the preceding configuration items to another Docker host is difficult to perform manually. We might not remember all the steps required to create a host, and it is an error-prone and slow process. Creating documentation to capture this process doesn't help either because such artifacts tend to get stale over time.
If we cannot provision new Docker hosts in a timely and reliable manner, we will have no space to scale out our Docker application. Therefore, it's important to prepare and configure our Docker hosts in a consistent and fast manner. Otherwise, Docker's ability to create container packages for our application will become useless quite quickly.
Configuration management is a strategy to manage the changes happening in all aspects of our application, and it reports and audits the changes made to our system. This does not only apply when developing our application. For our case, it records all the changes to our Docker hosts. Docker, in a sense, accomplishes the following aspects of configuration management for our application:
- Docker containers reproduce any environment for our application, from development to staging, testing, and production.
- Building Docker images is a simple way to make application changes and have them deployed to all environments.
- Docker enables all team members to get information about our application and make the needed changes to deliver the software efficiently to customers. By inspecting the Dockerfile, they can know which part of the application needs to be updated and what it needs in order to run properly.
- Docker tracks any change in our environment to a particular Docker image. Then, it traces it back to the corresponding version of the Dockerfile. It traces what the change is, who made it, and when it was made.
However, what about the Docker host running our application? Just as a Dockerfile allows us to manage our application's environment in version control, configuration management tools can describe our Docker hosts in code. It simplifies the process to create Docker hosts. In the case of scaling out our Docker application, we can recreate a new Docker host from scratch easily. When there is a hardware failure, we can bring up new Docker hosts somewhere else from their known configuration. Configuration management enables us to manage our Docker deployments in scale.
In the next section, we will be setting up Chef as the configuration management system for our Docker infrastructure.
- Big Data Analytics with Hadoop 3
- 智能傳感器技術與應用
- Design for the Future
- 腦動力:C語言函數速查效率手冊
- Getting Started with Clickteam Fusion
- 協作機器人技術及應用
- Ceph:Designing and Implementing Scalable Storage Systems
- Grome Terrain Modeling with Ogre3D,UDK,and Unity3D
- 計算機組網技術
- INSTANT Adobe Story Starter
- 工業機器人操作
- 手把手教你學Photoshop CS3
- C#編程兵書
- 細節決定交互設計的成敗
- 站酷志:資深設計師的Photoshop創意課