Docker安装与运行自定义镜像-CentOS

卸载老版本的docker

yum remove docker \
                  docker-client \
                  docker-client-latest \
                  docker-common \
                  docker-latest \
                  docker-latest-logrotate \
                  docker-logrotate \
                  docker-engine

和docker相关的内容存储在 /var/lib/docker/, 包括镜像(images), 容器(containers), 卷(volumes),网络(networks)等。 这些Docker相关的包统称之为 docker-ce


安装docker engine [CentOS]

使用repository安装

安装仓库
  • 安装yum-utils (包含 yum-config-manager)
    sudo yum install -y yum-utils
    
  • 安装 reposityory
     yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
    
安装docker engine
  • 最新版本的安装

    yum install docker-ce docker-ce-cli containerd.io docker-compose-plugin
    
  • 安装某个版本

查询版本号
yum list docker-ce --showduplicates | sort -r
image-20220506153237978.png

例如:版本号就是 docker-ce-18.09.1

yum install docker-ce-<VERSION_STRING> docker-ce-cli-<VERSION_STRING> containerd.io docker-compose-plugin

启动docker

 sudo systemctl start docker

Hello-world

sudo docker run hello-world

启动 docker/getting-started 教程

 docker run -d -p 80:80 docker/getting-started

参数说明

  • -d - run the container in detached mode (in the background)
  • -p 80:80 - map port 80 of the host to port 80 in the container
  • docker/getting-started - the image to use

创建示例工程

代码编写

<span id="code">https://github.com/docker/getting-started/tree/master/app</span>

构建镜像

  • 创建Dockerfile文件。Dockerfile文件不能有任何的后缀。(此例在package.json所在目录下创建Dockerfile文件)
# syntax=docker/dockerfile:1
FROM node:12-alpine
RUN apk add --no-cache python2 g++ make
WORKDIR /app
COPY . .
RUN yarn install --production
CMD ["node", "src/index.js"]
EXPOSE 3000
`CMD` 命令表示当容器从镜像启动时运行的默认命令
  • 构建镜像
docker build -t getting-started .
`-t` flag tags our image; 最后的 . 表示Dockerfile文件所在的目录是当前目录

启动容器

docker run -dp 3000:3000 getting-started

http://ip:3000 就可以启动应用了 (防火墙注意放开3000的端口号)


更新示例工程

更新代码

重新构建

## 可以在最后增加:tagName
docker build -t getting-started .

停止旧版本

## 查找正在运行的旧版本的container id
docker ps
## 停止旧版本
docker stop <the-container-id>
## 删除旧版本
docker rm <the-container-id>

重新启动

docker run -dp 3000:3000 getting-started

推送镜像到远程仓库

  • 操作Docker Hub

    1. 注册登陆 Docker Hub.
    2. 创建仓库,仓库名与需要推送的image名需要一致
  • 本地操作

       1. 登陆上一步创建的账号
    
          ```shell
          docker login -u YOUR-USER-NAME
          ```
    
       2. 确保image名字与上一步的仓库名一致,如果有需要可以重命名
    
          ```shell
          ## 其中 :TAG_NAME 可以省略,则为 latest
          docker tag getting-started YOUR-USER-NAME/getting-started:TAG_NAME
          ```
    
       3. 推送
    
          ```shell
          docker push YOUR-USER-NAME/getting-started
          ```
    

在线运行镜像

Open your browser to Play with Docker.


容器持久化数据 —— Named Volumes

每个容器的文件是系统是相互独立的,即使是由同一个镜像启动的容器的文件也是相互隔离的。可以通过挂载volume 来实现

  1. 创建volume

    docker volume create todo-db
    
  2. 启动时挂载

     docker run -dp 3000:3000 -v todo-db:/etc/todos getting-started
    

操作完以,重新停止,删除容器,用相同的命令启动docker时,数据就不会丢失。

查询volume挂载后,数据实际存在的位置

docker volume inspect todo-db
image-20220507113026889.png

容器持久化数据 —— Bind Mounts

用的代码是上述示例工程的代码

docker run -dp 3000:3000 -w /code/app -v "$(pwd):/code/app" node:12-alpine sh -c "yarn install && yarn run dev"
  • -dp 3000:3000 - same as before. Run in detached (background) mode and create a port mapping
  • -w /app - sets the “working directory” or the current directory that the command will run from
  • -v "$(pwd):/app" - bind mount the current directory from the host in the container into the /app directory (主机地址与容器地址的映射关系:前是本机地址,:后是容器里的工作目录)
  • node:12-alpine - the image to use. Note that this is the base image for our app from the Dockerfile
  • sh -c "yarn install && yarn run dev" - the command. We’re starting a shell using sh (alpine doesn’t have bash) and running yarn install to install all dependencies and then running yarn run dev. If we look in the package.json, we’ll see that the dev script is starting nodemon.

基于多个容器的app

如果想把示例app的数据存储到mysql中。这时的app像这样。

multi-app-architecture.png

因为容器之间是相互隔离的,两个容器之间要进行信息交互就得通过网络(两个容器需要在同一个网络一起)。There are two ways to put a container on a network: 1) Assign it at start or 2) connect an existing container.

创建网络

 docker network create todo-app

启动mysql

启动mysql并连接到上一步创建的网络中

docker run -d  --network todo-app --network-alias mysql  -v todo-mysql-data:/var/lib/mysql  -e MYSQL_ROOT_PASSWORD=root   -e MYSQL_DATABASE=todos  mysql:5.7

其中--network 表示运行的网络是 todo-app

其中的 --network-alias 对网络起了一个别名,后续可以直接使用这个别名。

验证mysql是否启动成功

docker exec -it <mysql-container-id> mysql -u root -p

寻找mysql容器的ip地址

mysql容器已经运行起来了,怎么找到mysql容器的ip地址呢(每个容器都有它自己的ip地址)?

我们可以运用 nicolaka/netshoot 这个容器来寻址。

  • 启动netshoot

    docker run -it --network todo-app nicolaka/netshoot
    
  • 进入容器后,可以使用 dig 这个命令来查询mysql的ip地址。(dig是一个很有用的DNS工具)

    dig mysql
    

    运行结果:

    ;; ANSWER SECTION:
     mysql.           600 IN  A   172.23.0.2
    

    这条记录就是ip解析结果。虽然mysql不是一个正常的主机名,之所以能解析到是因为上一步的--network-alias设置了mysql。这使我们的app如果想连到mysql的话,这需要运用这个主机名mysql就可以。

启动基于mysql的app

docker run -dp 3000:3000 \
   -w /app -v "$(pwd):/app" \
   --network todo-app \
   -e MYSQL_HOST=mysql \
   -e MYSQL_USER=root \
   -e MYSQL_PASSWORD=root \
   -e MYSQL_DB=todos \
   node:12-alpine \
   sh -c "yarn install && yarn run dev"

打开浏览器增加一些纪录时,这时候的数据会存到mysql中。

也可以直接启动上面章节构建的镜像

docker run -dp 3000:3000 --network todo-app -e MYSQL_HOST=mysql -e MYSQL_USER=root -e MYSQL_PASSWORD=root  -e MYSQL_DB=todos   getting-started

使用docker-compose启动app

安装docker-compose

  • 下载可执行文件 release page
  • 下载的文件重命名为docker-cmpose
  • 移动到/usr/bin/docker-compose目录
  • 赋予可执行权限 chmod +x /usr/bin/docker-compose
  • 验证版本号 docker-compose version

创建docker-compose.yml文件

  • 默认情况下,这个工程的名字是这个文件所在文件夹的名字

  • 在项目的根目录下创建docker-compose.yml文件

  • 在这个文件的最开头部分定义版本号,不同版本号的兼容情况可以查看compose version

     version: "3.7"
    
  • 接下来定义启动app需要的不同的services (or containers)

     version: "3.7"
    
     services:
    

定义自己应用的 service

  • 定义第一个service名字(app)和镜像,其中service名字任意取,这个名字会自动成为一个network alias。这对我们定义mysql服务很有效

     version: "3.7"
    
     services:
       app:
         image: node:12-alpine
    
  • 通常来说,紧接着image下面会设置command,但是对它们出现的先后顺序并没有要求

    version: "3.7"
    
     services:
       app:
         image: node:12-alpine
         command: sh -c "yarn install && yarn run dev"
    
  • 设置端口号,设置端口号有两种方式:一种是短语法;一种是长语法

     version: "3.7"
    
     services:
       app:
         image: node:12-alpine
         command: sh -c "yarn install && yarn run dev"
         ports:
           - 3000:3000
    
  • 定义工作目录与volume ,volume的定义也有两种方式:shortlong。在这里定义volumes时可以直接运用相对路径

     version: "3.7"
    
     services:
       app:
         image: node:12-alpine
         command: sh -c "yarn install && yarn run dev"
         ports:
           - 3000:3000
         working_dir: /app
         volumes:
           - ./:/app
    
  • 定义镜像的环境变量

     version: "3.7"
    
     services:
       app:
         image: node:12-alpine
         command: sh -c "yarn install && yarn run dev"
         ports:
           - 3000:3000
         working_dir: /app
         volumes:
           - ./:/app
         environment:
           MYSQL_HOST: mysql
           MYSQL_USER: root
           MYSQL_PASSWORD: root
           MYSQL_DB: todos
    

定义mysql service

  • 将mysql service 服务命名为mysql,这样自动生成的network alias也是mysql;指定mysql服务的镜像为mysql:5.7

     version: "3.7"
    
     services:
       app:
         # The app service definition
       mysql:
         image: mysql:5.7
    
  • 定义mysql service 的named volumes。

    基于Compose的volumes并不像使用docker run 会自动创建named volumes。当在使用Compose时需要在配置文件顶层中申明volumes:。而在具体的服务下的volumes:是用来指定这个服务的挂载点的。

     version: "3.7"
    
     services:
       app:
         # The app service definition
       mysql:
         image: mysql:5.7
         volumes:
           - todo-mysql-data:/var/lib/mysql
    
     volumes:
       todo-mysql-data:
    
  • 定义mysql的环境变量

     version: "3.7"
    
     services:
       app:
         # The app service definition
       mysql:
         image: mysql:5.7
         volumes:
           - todo-mysql-data:/var/lib/mysql
         environment:
           MYSQL_ROOT_PASSWORD: secret
           MYSQL_DATABASE: todos
    
     volumes:
       todo-mysql-data:
    

完整的docker-compose.yml文件

version: "3.7"

services:
  app:
    image: node:12-alpine
    command: sh -c "yarn install && yarn run dev"
    ports:
      - 3000:3000
    working_dir: /app
    volumes:
      - ./:/app
    environment:
      MYSQL_HOST: mysql
      MYSQL_USER: root
      MYSQL_PASSWORD: secret
      MYSQL_DB: todos

  mysql:
    image: mysql:5.7
    volumes:
      - todo-mysql-data:/var/lib/mysql
    environment:
      MYSQL_ROOT_PASSWORD: root
      MYSQL_DATABASE: todos

volumes:
  todo-mysql-data:

使用docker-compose关闭app

进入docker-compose.yml文件所在的目录,运行

docker-compose down

默认情况下容器(containers)与网络(network)会被停止与删除。但是创建的volumes不会被删除,如果想要删除的话加入--volumes参数。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,233评论 6 495
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,357评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,831评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,313评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,417评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,470评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,482评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,265评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,708评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,997评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,176评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,827评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,503评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,150评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,391评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,034评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,063评论 2 352

推荐阅读更多精彩内容