通常在本机开发环境中需要搭建所有的服务,还要修改本地的
hosts
,实在是不胜其烦。如今有了docker,完全不用污染本地环境,且看老司机带你搭建一个asp.net core的开发环境集群。愿你走出虚拟机,归来仍是干净的开发机。
教程比较长,所以分成多篇连载。
First things first:需要安装一个数据库,如今有了mssql on linux,真是太棒了,原来mssqlserver中的测试数据都可以无缝迁移过来。
docker的安装细节大家自己找找看。
- 进入
bash
,执行以下命令
cd ~
mkdir mssql
cd mssql
vim Dockerfile
- 输入以下Dockerfile脚本
# mssql-server-linux
# Maintainers: Microsoft Corporation (LuisBosquez and twright-msft on GitHub)
# GitRepo: https://github.com/Microsoft/mssql-docker
# Base OS layer: Latest Ubuntu LTS.
FROM microsoft/mssql-server-linux
# 设置证书
ENV ACCEPT_EULA Y
# 设置sa帐户的密码
ENV SA_PASSWORD Sql123123.
# Default SQL Server TCP/Port.
EXPOSE 1433
# Copy all SQL Server runtime files from build drop into image.
#COPY ./data /data
# 挂载一个数据卷,用于放置脚本和备份数据
VOLUME /data
# Run SQL Server process.
CMD /opt/mssql/bin/sqlservr.sh
保存并退出:wq
-
生成镜像
docker build -t mssql .
,最后一个点别忘了。 -
创建一个目录以供
mssql
挂载:mkdir mssqldata
-
启动容器
docker run -d -v /(!绝对路径!)/mssqldata:/data mssql
,以后就使用该容器提供的数据库服务,不要轻易删除,可以stop/restart。 -
容器正常运行以后,可以直接进入SqlCmd操作数据库:
docker exec -it <container_id|container_name> /opt/mssql-tools/bin/sqlcmd -S localhost -U sa -P <your_password>
(ps:SqlCmd是一种命令行管理工具,还可以通过VS Code使用图形化管理)
很多情况下,要通过Sql脚本恢复数据库,这时候就不能直接进入SqlCmd了。
我们先把sql脚本复制数据卷对应的本机目录下,我上面指定的是/(!绝对路径!)/mssqldata
。
首先,复制一个sql脚本到数据卷中/(!绝对路径!)/mssqldata/testdb.sql
,我的testdbd.sql
中包含了data & scheme
。(mssqlserver生成sql脚本的过程大家应该是知道的。)
注意!
如果脚本中有创建mdf
文件的语句:
CONTAINMENT = NONE
ON PRIMARY
( NAME = N'TestDb', FILENAME = N'C:xxxTestDb.mdf' , SIZE = 4096KB , MAXSIZE = UNLIMITED, FILEGROWTH = 1024KB )
LOG ON
( NAME = N'TestDb_log', FILENAME = N'C:xxxTestDb_log.ldf' , SIZE = 1024KB , MAXSIZE = 2048GB , FILEGROWTH = 10%)
GO
那么应该把地址改成数据卷的地址,本例中改为FILENAME = N'/data/TestDb.mdf‘
,还有一个ldf
文件可别忘了。
这样做是为了保证镜像干净。
-
进入数据库容器:
docker exec -it <container_id|container_name> /bin/bash
(PS:命令docker ps -a
可以查看到该容器的id和name,或者在启动容器的时候指定name) -
/opt/mssql-tools/bin/sqlcmd -S localhost -U sa -P <your_password> -i /data/testdb.sql
,此处的-i
参数就表示执行后面的sql脚本。前面已经把sql脚本放在了数据卷中,所以在容器的/data
中就能拿到了。
完成了mssql on linux的安装和数据恢复,后面就要使用此docker容器作为数据库服务了。如果你对docker的基本命令还不熟悉的话,建议去官网看看文档,多练几遍就可以了,没什么难度。
感慨一句,mssql on linux的docker镜像文档里明确指出里需要至少3.25GB的内存,但是实际上没那么夸张,跑了一个数据库实例也才使用600MB,相对于mssqlserver
已经好太多了。
接下来,会讲解如何使用docker-compose搭建集群。