欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

docker 安装使用 mssql2017

程序员文章站 2024-01-22 17:04:52
1.拉取镜像 官方文档参考 : https://docs.microsoft.com/zh-cn/sql/linux/quickstart-install-connect-docker?view=sql-server-2017&pivots=cs1-bash 执行命令 2.创建容器 挂载目录 : 本 ......

1.拉取镜像

官方文档参考 :

执行命令

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

 

2.创建容器

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

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

//创建容器
docker run -e 'accept_eula=y' -e 'mssql_sa_password=12@@3456!@#$$zxc' --privileged=true -v /work/mssql_data/:/var/opt/mssql/data/db/ -p 1433:1433 --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 客户端地址:

 

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守护进程启动时就已经停止了的容器