docker基础+docker安装sqlserver、oracle

docker介绍 {#docker介绍}

  • docker是什么

    • docker是一个开源的 应用容器引擎
  • docker能发挥什么作用———— 一次创建或配置,可以在任意地方正常运行。

    • docker可以让开发者打包他们的应用和依赖包,到一个轻量级、可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化。
      • Docker镜像中包含了运行环境和配置,所以Docker可以简化部署多种应用实例工作。比如Web应用、后台应用、数据库应用、大数据应用比如Hadoop集群、消息队列等等都可以打包成==一个镜像(类)==部署。
      • Docker确保了执行环境的一致性,使得应用的迁移更加容易
  • docker和虚拟机的区别

    2023-09-05_15-56-01_screenshot.png
  • docker的组成

    • docker通过镜像(类)创建容器(实例)
      • Image(镜像):相当于类
      • Container(容器):相当于实例
      • Repository(仓库):Docker存放Images的地方

安装docker {#安装docker}

  • https://zhuanlan.zhihu.com/p/430652941
  • 删除旧版本docker
    sudo apt-get remove docker docker-engine docker.io containerd runc
    sudo rm -rf /var/lib/docker
    sudo rm -rf /var/lib/containerd
  • 安装docker
    curl -fsSL https://get.docker.com | bash -s docker --mirror Aliyun
  • 测试是否安装成功
    sudo systemctl start hello-world
    sudo docker run hello-world
  • 配置加速器
    • /etc/docker/daemon.json 中写入如下内容(如果文件不存在请新建该文件)

      #可以使用下面这个,比较快一些
      {
          "registry-mirrors": ["https://docker.mirrors.ustc.edu.cn/","https://hub-mirror.c.163.com","https://registry.docker-cn.com"],
          "insecure-registries": ["10.0.0.12:5000"]
      }
      

      配置完成后需要重启Docker服务

      sudo systemctl daemon-reload
      # daemon-reload: 重新加载某个服务的配置文件,使修改的配置文件生效
      sudo systemctl restart docker
      
      docker info
      # 查看镜像地址与所配置的镜像地址是否匹配,如过匹配,则说明配置成功
      

      {{< figure src="/ox-hugo/2023-09-05_16-06-37_screenshot.png" >}}

docker命令 {#docker命令}

镜像 {#镜像}

  • 查看镜像
    • sudo docker image ls -a
  • 删除镜像
    • sudo docker image rm imageid
  • 重命名镜像
    • sudo docker image tag 镜像id 镜像名

容器 {#容器}

  • 查看docker容器
    • docker container ls -a
    • 如果STATUS显示为UP,则说明映像正在容器中运行
  • 重命名容器
    • sudo docker rename 容器id 容器名
  • 创建并启动容器:docker run
    • 注意该只能用于启动未创建的容器,如果启动已经创建的容器,用docker start
  • 进入容器:docker exec -it 容器名 脚本名
    • docker exec -it oracle11g bash
    • 前面的docker介绍中已经用图示说明了docker包含要运行的应用程序(app)以及应用程序的运行环境(bin、lib),因此当你进入容器后,实际上就是进入了包含app、bin、lib的环境
      • 例如进入oracle的container,就包含要运行的oracle程序以及oracle的命令行sqlplus等辅助工具,在容器中运行sqlplus,连接oracle主程序,就可以在sqlplus中使用oracle的功能了

docker安装sqlsrver {#docker安装sqlsrver}

下载sqlserver映像 {#下载sqlserver映像}

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

运行sqlserver映像 {#运行sqlserver映像}

- sudo docker run -e "ACCEPT_EULA=Y" -e "MSSQL_SA_PASSWORD=553912917@qq.com" \
   -p 1433:1433 --name sqlserver2017 --hostname sqlserver2017 \
   -d \
   mcr.microsoft.com/mssql/server:2017-latest
  • 一定要注意 sqlserver的密码一定要包含特殊字符,否则容器无法启动
参数 说明
-e "ACCEPT_EULA=Y" 将 ACCEPT_EULA 变量设置为任意值,以确认接受最终用户许可协议。 SQL Server 映像的必需设置。
-e "MSSQL_SA_PASSWORD=<YourStrong@Passw0rd>" 指定至少包含 8 个字符且符合 SQL Server 密码要求的强密码。 SQL Server 映像的必需设置。
-e "MSSQL_COLLATION=<SQL_Server_collation>" 指定自定义 SQL Server 排序规则,而不使用默认值 SQL_Latin1_General_CP1_CI_AS。
-p 1433:1433 将主机环境中的 TCP 端口(第一个值)映射到容器中的 TCP 端口(第二个值)。
在此示例中,SQL Server 侦听容器中的 TCP 1433,此容器端口随后会对主机上的 TCP 端口 1433 公开。
--name sql1 为容器指定一个自定义名称,而不是使用随机生成的名称。 如果运行多个容器,则无法重复使用相同的名称。
--hostname sql1 用于显式设置容器主机名。 如果未指定主机名,则主机名默认为容器 ID,这是随机生成的系统 GUID。
-d 在后台运行容器(守护程序)。
mcr.microsoft.com/mssql/server:2017-latest SQL Server Linux 容器映像。
  • 使用命令行连接sqlserver容器
    • sudo docker exec -it sqlserver2017 bash
  • 在容器内使用sqlcmd连接sqlserver
    • 先创建软链接 ln -s /opt/mssql-tools/bin/sqlcmd /usr/bin/sqlcmd
    • /opt/mssql-tools/bin/sqlcmd -S localhost -U SA -P "553912917@qq.com"
      • -S:[-S server or Dsn if -D is provided]
      • -U:[-U login id]
      • -P:[-P password]

docker安装oracle {#docker安装oracle}

  • 查看已经安装的images


    截图_选择区域_20230905165401.png
    • 发现其中有名为 oracle_11g 的image,我们的目标就是以这个image为蓝本,生成一个container
  • 第一次创建并启动container用docker run

    • sudo docker run -d -it -p 1521:1521 --name oracle_11g --restart=always oracle_11g
      • -p:指定端口号
      • --name:指定生成的container的name
      • -d:Run container in background and print container ID
      • -it:Allocate a pseudo-TTY、Keep STDIN open even if not attached
    • 阿里的镜像密码都是helowin
    • 进入容器后要执行su root命令切换为管理员权限才能修改/etc/profile,这个/etc/profile不是你本机的/etc/profile而是oracle镜像的/etc/profile
      • vi /etc/profile
        把下面的内容加入到文件中
        export ORACLE_HOME=/home/oracle/app/oracle/product/11.2.0/dbhome_2
        export ORACLE_SID=helowin
        export PATH=$ORACLE_HOME/bin:$PATH
        
        保存后执行 source /etc/profile 加载环境变量
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,142评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,298评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,068评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,081评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,099评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,071评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,990评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,832评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,274评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,488评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,649评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,378评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,979评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,625评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,643评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,545评论 2 352