Docker 运行 SQL Server 容器映像

随着.Net Core迭代,大家也都用上了Linux用上了Docker。跟.Net经常配套使用的SQL SERVER以前一直是windows only,但是从SQL Server 2017开始已经支持运行在Docker上,也就说现在SQL Serer已经可以运行在Linux/Docker下了。
下来将演示SQL Server 2019运行在Docker下

  • 先决条件 

  1. 任何受支持的 Linux 分发或用于 Mac/Windows 的 Docker 上的 Docker 引擎 1.8+。 

  2. 有关详细信息,请参阅 Install Docker(安装 Docker)。 Docker overlay2 存储驱动程序。 这是大多数用户的默认设置。 如果发现自己未使用此存储提供程序并且需要进行更改,请参阅 docker 文档中有关配置 overlay2 的说明和警告。

  3. 至少 2 GB 的磁盘空间。

  4. 至少 2 GB 的 RAM。 Linux 上的 SQL Server 的系统要求。

 

  • 拉取并运行 2019 容器映像

 

Linux Docker 从 Microsoft 容器注册表中拉取 SQL Server 2019容器映像

sudo docker pull mcr.microsoft.com/mssql/server:2019-latest

 Windows Docker Desktop下从 Microsoft 容器注册表中拉取 SQL Server 2019容器映像,以管理员身份运行CMD或PowerShell执行一下命令

docker pull mcr.microsoft.com/mssql/server:2019-latest

待结束后,执行以下命令即可看到我们拉取成功的镜像

docker images   

 

 

 

要使用 Docker 运行容器映像,可以从 Bash Shell (Linux/macOS) 或提升的 PowerShell 命令提示符使用以下命令,Linux下使用sudo提升运行权限

docker run -v /d/MSSQL:/var/opt/mssql --name sqlserver -e 'ACCEPT_EULA=Y' -e 'SA_PASSWORD=2019@123' -p 17951:1433 -d mcr.microsoft.com/mssql/server:2019-latest

如下图已运行成功

 

 

 参数说明:

 

参数说明
-e 'ACCEPT_EULA=Y' 设置此参数说明同意 SQL SERVER 使用条款 , 否则无法使用
-e 'SA_PASSWORD=密码' 此处设置 SQL SERVER 数据库 SA 账号的密码
-p 17951:1433 将宿主机 17951端口映射到容器的 1433 端口
--name sqlserver 设置容器名为 mssql
-v /d/MSSQL:/var/opt/mssql 将windnows宿主机目录D:\MSSQL 映射到容器 /var/opt/mssql , 方便备份数据
-d 在后台运行

查看 Docker 容器

docker ps -a

应会看到与以下屏幕截图类似的输出

 

 

 

连接到 SQL Server

使用客户端工具Microsoft SQL Server Management 连接

 

 

 连接成功

 

我们在客户端Microsoft SQL Server Management 创建测试数据Test,可以在我们本地映射的目录D:\MSSQL\data看到

 

 

 

 

 如需还原数据库我们可将xxx.bak,文件拷贝至D:\MSSQL\data在客户端工具中还原即可,如下图

使用命令在容器内部交互

使用 docker exec -it 命令在运行的容器内部交互,下来我们将结束通过命令在容器内部交互还原数据 /查询/备份等。

docker exec -it sqlserver bash

 

 

 使用命令在内部连接,在容器内部使用 sqlcmd 进行本地连接。 默认情况下,sqlcmd 不在路径之中,因此需要指定完整路径。

/opt/mssql-tools/bin/sqlcmd -S localhost -U SA -P [数据库密码]

 

 如果成功,应会显示 sqlcmd 命令提示符:1>

在 sqlcmd 命令提示符中,粘贴以下 Transact-SQL 命令以创建测试数据库:

CREATE DATABASE MyDB

 

在下一行中,编写一个查询以返回服务器上所有数据库的名称

SELECT Name from sys.Databases

前两个命令并没有立即执行。 在新行中键入 GO 以执行以前的命令

GO      

插入数据

接下来创建一个新表 MyTable,然后插入两个新行。

在 sqlcmd 命令提示符中,将上下文切换到新的MyDB 数据库:

USE MyDB

创建名为 MyTable的新表:

CREATE TABLE MyTable (id INT, name NVARCHAR(50), quantity INT)

并为MyTable表插入数据

INSERT INTO MyTable VALUES (1, 'banana', 150); INSERT INTO MyTable VALUES (2, 'orange', 154);

要执行上述命令的类型 GO

GO 

 

在Microsoft SQL Server Management中查看数据

 

 在容器内部查询数据

SELECT * FROM MyTable WHERE id =1;

执行以上命令

GO 

 

 要结束 sqlcmd 会话,请键入 QUIT

今天就分享至此,感谢你的阅读。

 

posted @ 2020-09-19 21:03  醉代码  阅读(2241)  评论(0编辑  收藏  举报