docker 安装使用 mssql2017

1.拉取镜像

官方文档参考 : https://docs.microsoft.com/zh-cn/sql/linux/quickstart-install-connect-docker?view=sql-server-2017&pivots=cs1-bash

执行命令

-latest

2.创建容器

挂载目录 : 本地目录 /work/mssql_data/ 容器目录 /var/opt/mssql/data/db/ ,数据库文件肯定是不能放在容器里面的(你要是随便玩玩就当我没说),并且添加 privileged 参数给权限(可能碰到无法创建数据库提示)。

664c 是镜像Id的前四位,拉取的版本不一样镜像Id也不一样

//创建容器
docker run -e : --name mssql_2017v1 --restart always -d 644c
docker exec -it cfc6 /bin/bash   进入容器 cfc6是容器Id

docker 安装使用 mssql2017

3.创建数据库

用mssql客户端工具链接数据库,如果连不上请检查端口及防火墙。

创建数据库手动选择目录会报错找不到目录,这个问题开始以为是目录没有挂载成功,最后手动填写目录创建成功!(这里填写的是容器内的路径)

docker 安装使用 mssql2017

查看容器目录文件和centos挂载的目录文件,可以看到文件挂载目录数据库文件(ZoneTeach * )是存在的。

docker 安装使用 mssql2017

到这里已经可以通过客户端工具正常使用mssql2017

SQL Server Management Studio 客户端地址:

https://docs.microsoft.com/zh-cn/sql/ssms/download-sql-server-management-studio-ssms?view=sql-server-2017

4.相关参数

privileged 参数

启用该参数,container内的root拥有真正的root权限。
否则,container内的root只是外部的一个普通用户权限。
privileged启动的容器,可以看到很多host上的设备,并且可以执行mount。
甚至允许你在docker容器中启动docker容器。

restart 参数

Docker容器的重启策略
no,默认策略,在容器退出时不重启容器
on-failure,在容器非正常退出时(退出状态非0),才会重启容器
on-failure:3,在容器非正常退出时重启容器,最多重启3次
always,在容器退出时总是重启容器
unless-stopped,在容器退出时总是重启容器,但是不考虑在Docker守护进程启动时就已经停止了的容器

上一篇:openshift pod对外访问网络解析


下一篇:CentOS7 yum lamp 虚拟主机配置 lamp各组件简单影响性能的参数调整--for 一定的环境需求