前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Docker 安装部署Sql Server

Docker 安装部署Sql Server

作者头像
小世界的野孩子
发布2019-08-01 13:08:54
2.4K0
发布2019-08-01 13:08:54
举报

前言

  在如今,容器化概念越来越盛行,.Net Core项目也可以跨平台部署了,那么思考下Sql Server能不能呢?当然是可以的啦。本文今天就是介绍Docker部署配置和连接Sql Server。本文基于Centos7。

配置Docker链接Sql Server

  前提条件(至少2 GB的磁盘空间。至少2 GB的RAM)。我们现在开始配置安装:

  查询并找到Docker Hub 上Microsoft SQL Server的介绍。

  然后根据这个上docker拉取镜像

代码语言:javascript
复制
 docker pull mcr.microsoft.com/mssql/server:2017-latest

  查看镜像并允许此镜像

代码语言:javascript
复制
docker images
sudo docker run -e "ACCEPT_EULA=Y" -e "SA_PASSWORD=MyPassWord123"  -p 1433:1433 --name sql1  -d mcr.microsoft.com/mssql/server:2017-latest

  然后查看是否允许成功

代码语言:javascript
复制
Docker ps -a

  出现下图这样既允许成功,显示UP(如果失败的话通过docker logs 容器名进行查看错误日志)

  然后这里我们就配置了SQL Server,接下来我们实际进入容器内操作。

代码语言:javascript
复制
sudo docker exec -it sql1 "bash"

/opt/mssql-tools/bin/sqlcmd -S localhost -U SA -P "MyPassWord123"

  然后现在就可以进行日常的数据库操作了,输入命令后执行Go结束

    创建库

代码语言:javascript
复制
CREATE DATABASE TestDB

    使用库、创建表

代码语言:javascript
复制
USE TestDB

CREATE TABLE Inventory (id INT, LastName NVARCHAR(50), FirstName NVARCHAR(50))

    查询表

代码语言:javascript
复制
Select * from  Inventory

    查询用户创建的表

代码语言:javascript
复制
select name from sysobjects where type = 'U'

  系统表sysobjects保存的都是数据库对象,其中type表示各种对象的类型,具体包括:

  U = 用户表

  S = 系统表

  C = CHECK 约束

  D = 默认值或 DEFAULT 约束

  F = FOREIGN KEY 约束

  L = 日志

  FN = 标量函数

  IF = 内嵌表函数

  P = 存储过程

  PK = PRIMARY KEY 约束(类型是 K)

  RF = 复制筛选存储过程

  TF = 表函数

  TR = 触发器

  UQ = UNIQUE 约束(类型是 K)

  V = 视图

  X = 扩展存储过程及相关的对象信息。

其他配置

  一、更改sa的登录密码

代码语言:javascript
复制
sudo docker exec -it sql1 /opt/mssql-tools/bin/sqlcmd  -S localhost -U SA -P "MyPassWord123"  -Q 'ALTER LOGIN SA WITH PASSWORD="MyPassWord456"'

  二、保留数据

    • 将主机目录装载为数据卷
代码语言:javascript
复制
docker run -e 'ACCEPT_EULA=Y' -e 'MSSQL_SA_PASSWORD=MyPassWord456' -p 1433:1433 -v  /var/opt/mssql -d mcr.microsoft.com/mssql/server:2017-latest
    • 使用数据卷容器
代码语言:javascript
复制
docker run -e 'ACCEPT_EULA=Y' -e 'MSSQL_SA_PASSWORD=MyPassWord456' -p 1433:1433 -v sqlvolume:/var/opt/mssql -d mcr.microsoft.com/mssql/server:2017-latest

  三、删除或退出容器

删除容器:docker rm 容器名

    删除镜像:docker rmi 镜像名

    退出容器;Ctrl+D


本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-07-31 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 配置Docker链接Sql Server
  •   查询并找到Docker Hub 上Microsoft SQL Server的介绍。
    • 其他配置
    相关产品与服务
    容器服务
    腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档