学习笔记--Docker

发布于:2024-09-05 ⋅ 阅读:(67) ⋅ 点赞:(0)

安装

1.卸载旧版

首先如果系统中已经存在旧的Docker,则先卸载:

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

2.配置Docker的yum库

首先要安装一个yum工具

yum install -y yum-utils

安装成功后,执行命令,配置Docker的yum源:

yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo

3.安装Docker

最后,执行命令,安装Docker

yum install -y docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin

4.启动和校验

# 启动Docker
systemctl start docker

# 停止Docker
systemctl stop docker

# 重启
systemctl restart docker

# 设置开机自启
systemctl enable docker

# 执行docker ps命令,如果不报错,说明安装启动成功
docker ps

5.配置镜像加速

这里以阿里云镜像加速为例。

5.1.注册阿里云账号

首先访问阿里云网站:

阿里云-计算,为了无法计算的价值

注册一个账号。

5.2.开通镜像服务

在首页的产品中,找到阿里云的容器镜像服务

点击后进入控制台:

首次可能需要选择立刻开通,然后进入控制台。

5.3.配置镜像加速

找到镜像工具下的镜像加速器

页面向下滚动,即可找到配置的文档说明:

具体命令如下:

# 创建目录
mkdir -p /etc/docker

# 复制内容,注意把其中的镜像加速地址改成你自己的
tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["https://xxxx.mirror.aliyuncs.com"]
}
EOF

# 重新加载配置
systemctl daemon-reload

# 重启Docker
systemctl restart docker

快速入门

部署Mysql

而使用Docker安装,仅仅需要一步即可,在命令行输入下面的命令(建议采用CV大法):

docker run -d \
  --name mysq3 \
  -p 3308:3306 \
  -e TZ=Asia/Shanghai \
  -e MYSQL_ROOT_PASSWORD=123 \
  mysql
docker run -d \
  --name mysql2 \
  -p 3307:3306 \
  -e TZ=Asia/Shanghai \
  -e MYSQL_ROOT_PASSWORD=123 \
  mysql



  tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["https://p2kc3337.mirror.aliyuncs.com"]
}
EOF

# 重新加载配置
systemctl daemon-reload

# 重启Docker
systemctl restart docker

Docker的镜像仓库:Dockers Hub

命令解读

小结

docker基础

常见命令

官网查阅:https://docs.docker.com/

补充:

默认情况下,每次重启虚拟机我们都需要手动启动Docker和Docker中的容器。通过命令可以实现开机自启:

# Docker开机自启
systemctl enable docker

# Docker容器开机自启
docker update --restart=always [容器名/容器id]

案例

# 第1步,去DockerHub查看nginx镜像仓库及相关信息

# 第2步,拉取Nginx镜像
docker pull nginx

# 第3步,查看镜像
docker images
# 结果如下:
REPOSITORY   TAG       IMAGE ID       CREATED         SIZE
nginx        latest    605c77e624dd   16 months ago   141MB
mysql        latest    3218b38490ce   17 months ago   516MB

# 第4步,创建并允许Nginx容器
docker run -d --name nginx -p 80:80 nginx

# 第5步,查看运行中容器
docker ps
# 也可以加格式化方式访问,格式会更加清爽
docker ps --format "table {{.ID}}\t{{.Image}}\t{{.Ports}}\t{{.Status}}\t{{.Names}}"

# 第6步,访问网页,地址:http://虚拟机地址

# 第7步,停止容器
docker stop nginx

# 第8步,查看所有容器
docker ps -a --format "table {{.ID}}\t{{.Image}}\t{{.Ports}}\t{{.Status}}\t{{.Names}}"

# 第9步,再次启动nginx容器
docker start nginx

# 第10步,再次查看容器
docker ps --format "table {{.ID}}\t{{.Image}}\t{{.Ports}}\t{{.Status}}\t{{.Names}}"

# 第11步,查看容器详细信息
docker inspect nginx

# 第12步,进入容器,查看容器内目录
docker exec -it nginx bash
# 或者,可以进入MySQL
docker exec -it mysql mysql -uroot -p

# 第13步,删除容器
docker rm nginx
# 发现无法删除,因为容器运行中,强制删除容器
docker rm -f nginx

命令别名

  1. 修改/root/.bashrc文件

vi /root/.bashrc

  1. 添加别名

alias dps='docker ps --format "table {{.ID}}\t{{.Image}}\t{{.Ports}}\t{{.Status}}\t{{.Names}}"'

alias dis='docker images'

  1. 退出执行命令使别名生效

source /root/.bashrc

数据卷

数据卷(volume)是一个虚拟目录,是容器内目录与宿主机目录之间映射的桥梁。

/var/lib/docker/volumes这个目录就是默认的存放所有容器数据卷的目录,其下再根据数据卷名称创建新目录,格式为/数据卷名/_data。

命令

完成案例-1

  1. 删除原有的nginx容器

docker rm -f nginx

  1. 创建数据卷

docker run -d --name nginx -p 80:80 -v html:/usr/share/nginx/html nginx

  1. 然后查看数据卷

docker volume ls

  1. 查看数据卷详情

docker volume inspect html

  1. 查看/var/lib/docker/volumes/html/_data目录

ll /var/lib/docker/volumes/html/_data

  1. 进入该目录,并随意修改index.html内容

cd /var/lib/docker/volumes/html/_data

vi index.html

  1. 进入容器内部,查看/usr/share/nginx/html目录内的文件是否变化

docker exec -it nginx bash

小结

完成案例-2本地目录挂载

# 1.查看MySQL容器详细信息
docker inspect mysql
# 关注其中.Config.Volumes部分和.Mounts部分

# 1.删除原来的MySQL容器
docker rm -f mysql

# 2.进入root目录
cd ~

# 3.创建并运行新mysql容器,挂载本地目录
docker run -d \
  --name mysql0 \
  -p 3307:3306 \
  -e TZ=Asia/Shanghai \
  -e MYSQL_ROOT_PASSWORD=123 \
  -v /root/mysql/data:/var/lib/mysql \
  -v /root/mysql/conf:/etc/mysql/conf.d \
  -v /root/mysql/init:/docker-entrypoint-initdb.d \
  mysql

# 4.查看root目录,可以发现~/mysql/data目录已经自动创建好了
ls -l mysql
# 结果:
总用量 4
drwxr-xr-x. 2 root    root   20 5月  19 15:11 conf
drwxr-xr-x. 7 polkitd root 4096 5月  19 15:11 data
drwxr-xr-x. 2 root    root   23 5月  19 15:11 init

# 查看data目录,会发现里面有大量数据库数据,说明数据库完成了初始化
ls -l data

# 5.查看MySQL容器内数据
# 5.1.进入MySQL
docker exec -it mysql mysql -uroot -p123
# 5.2.查看编码表
show variables like "%char%";
# 5.3.结果,发现编码是utf8mb4没有问题
+--------------------------+--------------------------------+
| Variable_name            | Value                          |
+--------------------------+--------------------------------+
| character_set_client     | utf8mb4                        |
| character_set_connection | utf8mb4                        |
| character_set_database   | utf8mb4                        |
| character_set_filesystem | binary                         |
| character_set_results    | utf8mb4                        |
| character_set_server     | utf8mb4                        |
| character_set_system     | utf8mb3                        |
| character_sets_dir       | /usr/share/mysql-8.0/charsets/ |
+--------------------------+--------------------------------+

# 6.查看数据
# 6.1.查看数据库
show databases;
# 结果,hmall是黑马商城数据库
+--------------------+
| Database           |
+--------------------+
| hmall              |
| information_schema |
| mysql              |
| performance_schema |
| sys                |
+--------------------+
5 rows in set (0.00 sec)
# 6.2.切换到hmall数据库
use hmall;
# 6.3.查看表
show tables;
# 结果:
+-----------------+
| Tables_in_hmall |
+-----------------+
| address         |
| cart            |
| item            |
| order           |
| order_detail    |
| order_logistics |
| pay_order       |
| user            |
+-----------------+
# 6.4.查看address表数据
+----+---------+----------+--------+----------+-------------+---------------+-----------+------------+-------+
| id | user_id | province | city   | town     | mobile      | street        | contact   | is_default | notes |
+----+---------+----------+--------+----------+-------------+---------------+-----------+------------+-------+
| 59 |       1 | 北京     | 北京   | 朝阳区    | 13900112222 | 金燕龙办公楼   | 李佳诚    | 0          | NULL  |
| 60 |       1 | 北京     | 北京   | 朝阳区    | 13700221122 | 修正大厦       | 李佳红    | 0          | NULL  |
| 61 |       1 | 上海     | 上海   | 浦东新区  | 13301212233 | 航头镇航头路   | 李佳星    | 1          | NULL  |
| 63 |       1 | 广东     | 佛山   | 永春      | 13301212233 | 永春武馆       | 李晓龙    | 0          | NULL  |
+----+---------+----------+--------+----------+-------------+---------------+-----------+------------+-------+
4 rows in set (0.00 sec)

自定义镜像

包装自己的java程序

镜像就是包含了应用程序、程序运行的系统函数库、运行配置等文件的文件包。构建镜像的过程其实就是把上述文件打包的过程。

Dockerfile

Dockerfile就是一个文本文件个个的指令(lnstruction),用指令来说明要执行什么操作来构建镜像。将来Docker可以根据Dockerfile帮我们构建镜像;

官网文档:https://docs.docker.com/engine/reference/builder

构建镜像运行java程序

  1. 基础镜像

需要下载,可以使用课程提供的基础镜像

docker load -i jdk.tar

  1. 添加一个redis容器

docker pull redis

  1. 我们将课前资料提供的docker-demo.jar包以及Dockerfile拷贝到虚拟机的/root/demo目录

  1. 执行命令,构建镜像
# 进入镜像目录
cd /root/demo
# 开始构建
docker build -t docker-demo .

命令说明:

  • docker build : 就是构建一个docker镜像
  • -t docker-demo :-t参数是指定镜像的名称(repository和tag)
  • . : 最后的点是指构建时Dockerfile所在路径,由于我们进入了demo目录,所以指定的是.代表当前目录,也可以直接指定Dockerfile目录:

# 直接指定Dockerfile目录

docker build -t docker-demo:1.0 /root/demo

  1. 尝试运行该镜像

docker run -d --name dd -p 8080:8080 docker-demo

dd:是自定义运行镜像名字

  1. 查看日志

docker logs dd

  1. 网址输入192.168.5.11:8080/hello/count

小结

网络

自定义创建网络

举例:

//查看网络
docker network ls

//创建一个网络
docker network create 自定义的网络名字

//查看本机的所有网段
ip addr

//容器加入网络
docker nerwork connect 网络名 容器名

//查看容器详细信息,可查看容器的网络网段信息
docker inspect 容器名

//再容器创建的时候加入网络,这样就不会创建默认网桥,只会存在你创建的网桥
docker run -d --name 容器名 -p 8080:8080 --network 网络名 docker-demo

项目部署

后端部署

第一步:将java项目打jar包;

第二步:将jar包和Dockerfile传给虚拟机

第三步:构建镜像

docker build -t hmall .

PS:镜像构建中是如何找到dockerfile文件的:如docker build -t hmall .

在Docker中,当你运行docker build命令来构建镜像时,Docker会查找当前上下文(context)中的Dockerfile文件。这个上下文通常是你运行docker build命令所在的目录,除非你用-f或--file选项指定了另一个位置。

在你给出的命令docker build -t hmall .中:

  • -t hmall:这个参数用于给构建的镜像命名并打标签。在这个例子中,构建的镜像将被命名为hmall。
  • .(点):这个参数表示Docker构建的上下文是当前目录。Docker会打包当前目录(以及其子目录)中的所有内容,并将其发送到Docker守护进程(daemon)以进行构建。但是,实际上只有Dockerfile和构建过程中引用的文件会被添加到镜像中。

Docker会在指定的上下文(在这个例子中是当前目录)中查找名为Dockerfile(没有扩展名)的文件。如果找不到该文件,Docker会返回一个错误。

如果你想要指定一个不同位置或名称的Dockerfile,你可以使用-f或--file选项。例如:


docker build -t hmall -f /path/to/Dockerfile .

在这个例子中,Docker会在/path/to/目录中查找名为Dockerfile的文件,并使用该文件来构建镜像。同时,.仍然指定了构建上下文为当前目录,但是只有Dockerfile和构建过程中明确引用的文件会被发送到Docker守护进程。

第四步:看8080端口是否占用,可是删除原有的8080端口

第五步:创建容器

docker run -d --name hm(自定义容器名字) -p 8080:8080 --network kussm(自定义网络名字) hmall

PS:docker中镜像与容器的关系

Docker中的镜像与容器之间存在着密切的关系,以下是它们之间关系的详细解释:

  1. 定义与功能:
    • Docker镜像:Docker镜像是Docker容器的构建块,它是一个只读的模板,包含了运行应用程序所需的文件系统、代码和依赖项。镜像可以看作是一个软件包,其中包含了构成应用程序的所有组件。
    • Docker容器:Docker容器是Docker镜像的运行实例,它是一个独立的、可执行的进程,具有自己的文件系统、网络和进程空间。容器是可启动、停止、暂停和删除的,它们提供了一个隔离的运行环境,使得应用程序可以在其中运行,而不受主机环境的影响。
  1. 关系描述:
    • 镜像与容器的关系:Docker镜像和容器之间是一种“类与实例”的关系。镜像可以看作是一个类,而容器则是这个类的实例。在Docker中,用户可以通过Docker镜像来创建Docker容器。
    • 依赖关系:每个Docker容器都基于一个特定的镜像。镜像提供了容器运行所需的文件系统和依赖项,而容器则在镜像的基础上启动、运行应用程序。
  1. 特点:
    • 镜像的特点:
      • 只读性:镜像是只读的,意味着它不可修改。每次对镜像的修改都会生成一个新的镜像。
      • 完整性:镜像包含了一个完整的文件系统,其中包含了应用程序运行所需的所有文件、目录和配置。
      • 依赖项:镜像还包含了应用程序的运行时依赖项,例如库文件、依赖软件和环境变量等。
    • 容器的特点:
      • 独立性:每个容器都是一个独立的、可重复的、可部署的单元。
      • 可移植性:容器可以在不同的环境中进行共享、复制和传递。
      • 隔离性:容器提供了隔离的运行环境,使得应用程序可以在其中运行,而不受主机环境的影响。
  1. 构建与运行:
    • 镜像的构建:Docker镜像的构建是通过一个叫做Dockerfile的文本文件进行的。Dockerfile中包含了一系列的指令,用于定义和描述如何构建镜像。
    • 容器的运行:一旦镜像构建完成,可以通过Docker命令将其部署为容器。容器是镜像的运行实例,可以独立运行,并提供一个隔离的运行环境。

综上所述,Docker镜像与容器之间是一种“类与实例”的关系,镜像是用来创建容器的模板,而容器则是镜像的运行实例。它们共同构成了Docker容器化的环境,使得开发人员能够更轻松地构建、交付和运行应用程序。

第六步:查看日志,浏览器访问检查

docker logs -f hm

前端部署

第一步:将前端文件传入虚拟机中

第二步:查看官网文档,查询配置挂载路径

配置挂载路径

docker run -d \
  --name nginx \
  -p 18080:18080 \
  -p 18081:18081 \
  -v /root/nginx/html:/usr/share/nginx/html \
  -v /root/nginx/nginx.conf:/etc/nginx/nginx.conf \
  --network kussm \
  nginx

第三步:浏览器访问18080端口

DockerCompose

DockerCompose通过一个单独的docker-compose.yml模板文件(YAML格式)来定义一组相关联的应用容器,帮助我们实现多个相互关联的Docker容器的快速部署。

对比

命令

开始部署使用

之前因为有相同的容易,所以先将之前的容器和镜像删除

第一步:先准备好compose.yml文件,配置好信息,传递进虚拟机

第二步:运行compose

docker compose up -d //-d表示后台运行

第三步:浏览器检查

第四步:移除