docker 安装使用 mssql2017
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
3.创建数据库
用mssql客户端工具链接数据库,如果连不上请检查端口及防火墙。
创建数据库手动选择目录会报错找不到目录,这个问题开始以为是目录没有挂载成功,最后手动填写目录创建成功!(这里填写的是容器内的路径)
查看容器目录文件和centos挂载的目录文件,可以看到文件挂载目录数据库文件(zoneteach * )是存在的。
到这里已经可以通过客户端工具正常使用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守护进程启动时就已经停止了的容器
上一篇: C++实现各进制数之间的转换