学习笔记--Docker

安装

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 \mysqltee /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表示后台运行

第三步:浏览器检查

第四步:移除

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/51934.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

深入理解 JavaScript DOM 操作

一、DOM 操作分类 &#xff08;一&#xff09;元素查找 根据 ID 值查找&#xff1a;getElementById()&#xff0c;返回符合条件的第一个对象。 var aa document.getElementById("aa");console.log(aa);根据类名查找&#xff1a;getElementsByClassName()&#xff…

IntelliJ IDEA 自定义字体大小

常用编程软件自定义字体大全首页 文章目录 前言具体操作1. 打开设置对话框2. 设置编辑器字体3. 设置编译软件整体字体 前言 IntelliJ IDEA 自定义字体大小&#xff0c;统一设置为 JetBrains Mono 具体操作 【File】>【Settings...】>【Editor】>【Font】 统一设置…

C++:list篇

前言: 观看C的list前需要对链表有一些了解&#xff0c;如C语言的链表结构。本片仅介绍list容器中常用的接口函数概念以及使用。 list的概念&#xff1a; 简而言之&#xff0c;C的list是一个双向带哨兵位的链表容器模板 list的构造&#xff1a; 1.list():默认构造 2.li…

spring之异常和测试相关注解

原文地址 ControllerAdvice和ExceptionHandler 通常组合使用&#xff0c;用于处理全局异常&#xff0c;示例代码如下&#xff1a; ControllerAdvice Configuration Slf4j public class GlobalExceptionConfig {private static final Integer GLOBAL_ERROR_CODE 500;Excepti…

认识git和git的基本使用,本地仓库,远程仓库和克隆远程仓库

本地仓库 #安装git https://git-scm.com/download/win #git是什么&#xff1f;有什么用&#xff1f; git相当于一个版本控制系统&#xff0c;版本控制是一种记录一个或若干文件内容变化&#xff0c;以便将来查阅特定版本修订情况的系统。 作用: 记录&#xff08;项目&#…

[Qt5] 使用QtConcurrent::run在异步线程中执行耗时函数

&#x1f4e2;博客主页&#xff1a;https://loewen.blog.csdn.net&#x1f4e2;欢迎点赞 &#x1f44d; 收藏 ⭐留言 &#x1f4dd; 如有错误敬请指正&#xff01;&#x1f4e2;本文由 丶布布原创&#xff0c;首发于 CSDN&#xff0c;转载注明出处&#x1f649;&#x1f4e2;现…

Java-树形图工具类TreeUtil

TreeUtil 工具类,包括列表转树形结构、遍历、查找和删除节点等功能。 import java.util.*;public class TreeUtil {/*** 将列表转换为树形结构。** @param target 扁平化的节点列表* @param getId 获取节点ID的函数* @param getParentId 获取节点父ID的函数* @…

物联网(IoT)支持的小型水处理厂实时硬件在环(HIL)仿真

这篇论文的标题是《Real-Time Hardware-In-The-Loop Simulation of IoT-Enabled Mini Water Treatment Plant》&#xff0c;作者是 Mohamad Taib Miskon 等人&#xff0c;发表在 2024 年 IEEE 自动控制与智能系统国际会议&#xff08;I2CACIS&#xff09;上。以下是该论文的主要…

【Agent】Agent Q: Advanced Reasoning and Learning for Autonomous AI Agents

1、问题背景 传统的训练Agent方法是在静态数据集上进行监督预训练&#xff0c;这种方式对于要求Agent能够自主的在动态环境中可进行复杂决策的能力存在不足。例如&#xff0c;要求Agent在web导航等动态设置中执行复杂决策。 现有的方式是用高质量数据进行微调来增强Agent在动…

学习日志29

论文阅读&#xff1a;IBM Q Experience as a versatile experimental testbed for simulating open quantum systems 引言部分&#xff1a; 引言部分首先介绍了开放量子系统的理论研究的重要性&#xff0c;这些理论描述了量子系统与其环境相互作用的动力学。这种理论对于理解量…

C++复习day01

这篇博客主要复习C语言的数组和指针 1.指针数组和数组指针 问&#xff1a;指针数组和数组指针&#xff0c;哪一个是指针&#xff0c;哪一个是数组&#xff1f; 我们来类比一下&#xff0c;整型数组是存放整型的数组&#xff0c;那么指针数组就是一个存放指针的数组&#xff0…

经验笔记:进程、线程与协程的理解与应用

经验笔记&#xff1a;进程、线程与协程的理解与应用 1. 引言 在软件开发中&#xff0c;特别是在涉及并发编程的场景下&#xff0c;进程、线程和协程是非常重要的概念。理解它们各自的定义、特点以及彼此之间的联系对于有效地设计和实现高效的应用程序至关重要。 2. 定义与特…

vector 常见函数

目录 一.vector 构造函数 二 . Iterators 迭代器&#xff08;random access iterator&#xff09; 三.Capacity: 空间 3.1 resize 3.2 reserve 四.Element access: 元素访问 方式 4.1 operator[] 类似于数组的 [] 4.2 front 和back 五.Modifiers: 六.vector 的 二…

【工业AI】寻优算法的思考

遗传算法GA 本质上来讲&#xff0c;就是找随机点x&#xff0c;通过公式或者回归模型构成的映射函数获得y。 区别于其他搜索寻优算法之处在于&#xff1a;遗传算法的一轮一轮迭代中&#xff0c;新的随机点x的生成&#xff0c;是靠交叉变异01而来的。 初始的DNA_size不管设置为多…

vue3+ts文件流导出xlsx表格需要token

封装方法post请求 import { ElLoading } from element-plus; import axios from axios; export const exportFilePost (params: any) > {const loadingInstance ElLoading.service({background: rgba(255, 255, 255, 0),});axios.post(params.url, params.data, {headers…

redis内存数据库的专业术语雪崩、击穿、穿透的名词解释

redis作为一个内存数据库&#xff0c;其作用主要体现在可以提供高速的访问处理。 redis在内存层面工作&#xff0c;一个字&#xff0c;快。 这也是redis区别于其他类型数据库的一个主要特点。 与之配合使用的是后端持久化存储数据库&#xff0c;比如结构化的数据库mysql mysql的…

18、Gemini-Pentest-v2

难度 中 目标 root权限 一个flag 靶机启动环境为VMware kali 192.168.152.56 靶机 192.168.152.63 信息收集 web测试 访问80端口 上面介绍了一下这个系统是一个内部系统&#xff0c;让员工查看他们的个人资料还可以导出为PDF 页面还有一个链接是UserList可以访问但是页面什…

ES数据写入过程

1. 写入请求 当一个写入请求&#xff08;如 Index、Update 或 Delete 请求&#xff09;通过REST API发送到Elasticsearch时&#xff0c;通常包含一个文档的内容&#xff0c;以及该文档的索引和ID。 2. 请求路由 协调节点&#xff1a;首先&#xff0c;请求会到达一个协调节点…

微服务日常总结

1.当我们在开发中&#xff0c;需要连接多个库时&#xff0c;可以在yml中进行配置。 当在查询的时候&#xff0c;跨库时&#xff0c;需要通过DS 注解来指定&#xff0c;需要yml配置需要保持一致。 2. 当我们想把数据存入到clob类型中&#xff0c;需要再字段 的占位符后面加上j…

Python 用pandas连接Postgresql库

pandas确实蛮强的&#xff0c;记录使用的代码 from sqlalchemy import create_engine import pandas as pd import os# 从环境变量中读取数据库连接信息 user os.getenv(DB_USER, xxx) # 数据库用户名 password os.getenv(DB_PASSWORD, xxx) # 数据库密码…