- 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.
- 構(gòu)建高質(zhì)量的C#代碼
- Mastercam 2017數(shù)控加工自動編程經(jīng)典實例(第4版)
- 來吧!帶你玩轉(zhuǎn)Excel VBA
- 分布式多媒體計算機系統(tǒng)
- 中國戰(zhàn)略性新興產(chǎn)業(yè)研究與發(fā)展:智能制造
- Hybrid Cloud for Architects
- 人工智能實踐錄
- 學會VBA,菜鳥也高飛!
- Machine Learning with the Elastic Stack
- 過程控制系統(tǒng)
- 所羅門的密碼
- Mastering Exploratory Analysis with pandas
- Deep Learning Essentials
- 菜鳥起飛電腦組裝·維護與故障排查
- 分布式Java應用