官术网_书友最值得收藏!

Separating dependencies

In the last chapter, I dockerized the legacy NerdDinner app and got it running but without a database. The original application expected to use SQL Server LocalDB on the same host where the app is running. LocalDB is an MSI-based installation, and I can add it to the Docker image, just by downloading the MSI and installing it with RUN commands in the Dockerfile. But this means that when I start a container from the image, it has two functions hosting a web application and running a database.

Having two functions in one container is not a good idea; what would happen if you wanted to upgrade your website without changing the database? Or, what if you needed to do some maintenance on the database, which didn't impact the website? What if you need to scale out the website? By coupling the two functions together, you've added a deployment risk, test effort, and administration complexity and reduced your operational flexibility.

Instead, I'm going to package the database in a new Docker image and run it in a separate container using Docker's network layer to access the database container from the website container. SQL Server is a licensed product, but the free variant, SQL Server Express, is available from Microsoft as an image on the Docker Hub and comes with a production license. I can use that as the base for my image, building on it to prepare a pre-configured database instance, with the schema deployed and ready to connect to the web application.

主站蜘蛛池模板: 金昌市| 贡嘎县| 临武县| 新沂市| 札达县| 子洲县| 岚皋县| 江孜县| 泾川县| 新竹市| 张北县| 霍山县| 临沂市| 鸡西市| 河津市| 白山市| 新昌县| 寿宁县| 迁安市| 泸西县| 项城市| 黑河市| 吴旗县| 郁南县| 平原县| 延边| 兴文县| 东辽县| 正蓝旗| 大邑县| 阳城县| 三江| 常州市| 剑河县| 天台县| 宁明县| 定襄县| 建阳市| 齐河县| 梧州市| 象州县|