docker server 容器连接sql_Docker 运行 SQL Server 容器映像

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

下来将演示SQL Server 2019运行在Docker下

先决条件

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

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

至少 2 GB 的磁盘空间。

至少 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:

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

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值