工作中必须掌握的docker知识
wptr33 2024-12-06 20:07 35 浏览
前言:
上一篇讲解了: 一文掌握centos/ubuntu安装docker
下面就讲解工作常用docker命令,以及如何使用,命令代表什么含义,下面先理解基础概念,镜像,容器,日志,数据卷,网络,容器与宿主机文件拷贝。关于Dockerfile会单独出一篇进行讲解。
- 镜像(image):
镜像是用于创建容器的静态模板或快照,包含了运行某个软件所需的所有内容,如代码、运行时环境、系统工具、系统库以及设置。
通俗理解:例如星巴克,瑞辛咖啡,它们都有一个制作咖啡的“配方”或“模板”。这个配方包含了制作咖啡所需的所有原料和以及步骤,以及如何将它们组合在一起的详细指南。那这个配方就像是docker镜像。它是静态的,不会改变(除非你决定修改配方),并且可以用来制作多个相同口味的咖啡。
- 容器(container):
容器是从镜像创建的运行实例,是一个独立、隔离的运行单元;容器包含了应用程序及其所有运行时所需的文件系统、环境变量、进程、网络配置等;容器是动态的,可以启动、停止、删除,并且可以对容器进行修改和更新(但这些修改不会影响到镜像本身)。
通俗理解:利用上面镜像的例子,现在有了制作咖啡配方,那我们按照配方上原料和步骤,制作一杯咖啡。那其实这杯咖啡就是从咖啡配方配方(镜像)创建出来的具体实例。它是动态的,可以被享用(运行),也可以被丢弃(删除)。还可以使用同一个配方(镜像)来制作多个相同口味的咖啡(容器),每个咖啡(容器)都是独立的,并且可以根据你的口味进行微调(配置)。
- 仓库(repository):
仓库就是存放镜像的地方,仓库分为公有仓库和私有仓库。(类似git,svn)。
一:帮助命令
- 1.显示docker的版本信息
docker version
- 2.显示docker的系统信息
#显示Docker的系统级信息,包括当前的镜像和容器数量
docker info
- 3.帮助命令
docker --help
二:镜像
- 1.查询镜像
docker search 名称
例如 docker search java,会搜索所有包含java的镜像。
- 2.拉取镜像
docker pull 镜像名称
例如 docker pull mysql,会从Docker Hub下载java最新版镜像。
- 3. 上传镜像仓库
docker push 镜像名称[:tag]
例如,docker push test:v0.0.1,会将本地镜像test:v0.0.1上传到镜像仓库中。
- 4.查询所有镜像
dokcer images
- 5.删除镜像
docker rmi 镜像名称/镜像id
例如,docker rmi docker-demo:v0.0.1,会删除名为镜像名称docker-demo,tag为0.0.1本地镜像。
- 6.构建镜像(使用Dockerfile创建镜像)
docker build -t 自定义镜像名称 .
例如:在当前/home/dev/demo目录下将jar打成镜像,目录下需要有docker-demo.jar,Dockerfile文件。下面构建一个名为docker-demo,标签为v0.0.5的镜像。
docker build -t docker-demo:v0.0.5 .
7.镜像打压缩包
#将一个或多个Docker镜像保存到一个tar归档文件中。
docker save -o(或者>) 镜像:tag
例如:将一个名为docker-demo,标签为v0.0.5的镜像,保存到一个docker-demo.tar归档文件。
8.加载压缩包镜像
docker load -i 镜像压缩包.tar
例如:加载一个名为docker-demo,标签为v0.0.5的镜像tar。
三:容器
容器是基于镜像创建出来的,所有需要镜像才可以创建容器。
- 1.创建容器
例如:基于docker-demo,标签为 v0.0.3镜像,创建 一个名为docker-demo容器。
docker run
-d #后台运行
--name docker-demo #容器名称
-p 8001:8001 #容器与虚拟机端口映射
docker-demo:v0.0.3 #镜像
- 2.查看容器
#查看所有容器(包含启动的容器与没启动的容器)
docker ps -a
#查看正在运行中的容器
docker ps
3.启动容器
docker start 容器id/容器名称
例如,docker start docker-demo:v0.0.3,会启动名为docker-demo,标签为 v0.0.3容器。
- 4.停止容器
docker stop 容器id/容器名称
例如,docker stop docker-demo:v0.0.3,会停止名为docker-demo,标签为 v0.0.3容器。
- 5.重启容器
docker restart 容器id/容器名称
例如,docker restart docker-demo:v0.0.3,会重启为docker-demo,标签为 v0.0.3容器。
6.删除容器
#删除指定的容器,不能删除正在运行的容器
docker rm 容器id
例如,docker rm docker-demo:v0.0.3,会删除为docker-demo,标签为 v0.0.3容器。
#如果要强制删除
docker rm -f 容器id
例如,docker rm -f docker-demo:v0.0.3,会强制删除为docker-demo,标签为 v0.0.3容器。
#删除所有的容器
docker ps -a -q|xargs docker rm
这里不演示删除所有的容器了!!!
- 7.进入容器
#进入容器会开出新的终端
docker exec -it 容器id /bin/bash
#容器直接退出
exit
#允许用户附加到正在运行的容器并与其交互
docker attach 容器id
#容器不停止退出:
ctrl +P +Q
使用 Ctrl+P+Q 可以从 docker attach 会话中分离出来,而不会停止容器的运行。而使用 exit 命令或 Ctrl+D 将会停止容器的运行
- 8.查看元数据
#获取容器对象(容器、镜像、卷、网络等)的详细信息
docker inspect 镜像id/镜像名称
四:日志
docker logs [Options] 容器id/容器名称
[Options:]
-f 或 --follow:实时跟踪容器的日志输出,类似于 tail -f。
-t 或 --timestamps:在日志输出中显示时间戳。
--since:显示自指定时间以来的日志,格式为 2023-04-01T12:00:00 或者相对时间(例如 4m 表示 4 分钟前)。
--tail:显示日志的最后几行,默认为 all
- 1.查看日志
docker logs -f 容器id/容器名称
- 2.实时查看10 行日志:
docker logs -f --tail 10 容器id/容器名称
- 3.查看自10 分钟前的日志:
docker logs --since 10m 容器id/容器名称
- 4.查看最后 10 行日志:
docker logs --tail 10 容器id/容器名称
五:拷贝
- 1.容器中文件拷贝到宿主机
docker cp <容器ID或名称>:<容器内路径> <宿主机路径>
例如,将名为docker-demo的容器中的/test.txt文件拷贝到宿主机的/data目录下。
演示:进入容器创建test.txt文件
使用命令:
docker cp docker-demo:/test.txt /data
- 2.宿主机文件拷贝到容器中
docker cp <宿主机路径> <容器ID或名称>:<容器内路径>
例如,将宿主机的/data目录下test1.txt拷贝到名为docker-demo的容器中
演示:宿主机的/data目录下创建test1.txt
使用命令:
docker cp /data/test1.txt docker-demo:/
六:数据卷
- 1.定义:
Docker数据卷是一个可用于持久化存储数据的特殊目录或文件。这些数据卷可以绕过容器的文件系统,直接存储在宿主机的文件系统中,或者在某些情况下,也可以存储在远程存储设备上。数据卷的设计目的就是为了解决容器数据的持久化和共享问题。
- 持久性:数据卷的内容在容器重启后仍然存在,不会因为容器的删除而丢失。如数据库、日志系统等,可以使用数据卷来保存数据。
- 共享性:多个容器可以挂载同一个数据卷,实现数据的共享和通信。
- 独立于容器生命周期:数据卷的生命周期独立于容器的生命周期,即使容器被删除,数据卷也会保留下来。
- 高效性:数据卷直接在宿主机的文件系统中存储,因此访问速度较快,且不会占用容器的存储空间。
- 数据备份和恢复:通过将数据卷备份到远程存储或另一个容器中,可以实现数据的备份和恢复操作。
- 数据迁移:使用数据卷可以方便地将容器的数据迁移到另一个环境或主机上,而无需重新构建或复制整个容器。
注意事项:
- 数据一致性:当多个容器挂载同一个数据卷时,需要确保数据的一致性,避免数据冲突。
- 权限问题:在挂载数据卷时,需要注意容器和宿主机之间的权限问题,确保容器能够正确访问数据卷。
- 备份和恢复:定期备份数据卷中的数据,以防止数据丢失或损坏。
- 2.创建数据卷:
docker volume create 数据卷名称
例如:创建数据卷名为my-volume
- 3.查看数据卷:
docker volume ls
- 4.挂载数据卷:
在创建容器时,可以使用-v或--mount选项将数据卷挂载到容器的指定目录上。
例如:创建一个mariadb数据库容器
#创建容器,并挂载数据卷 -v
docker run
--restart=always
-d
--name mariadb-volume
-v /home/mariadb/mariadb.cnf:/etc/mysql/mariadb.cnf
-v /home/mariadb/data:/var/lib/mysql
-v /home/mariadb/log:/var/log
-p 3306:3306
-e MYSQL_ROOT_PASSWORD=123456
mariadb
#解释:
--restart=always 表示始终运行的服务
-d 表示后台运行
--name 表示容器名称
-v 表示挂载
-p 表示容器端口与宿主机绑定
宿主机与容器挂载之后:(持久化)数据就不怕丢失了
- 5.删除数据卷:
#注意:如果数据卷正在被容器使用,则无法删除)。
docker volume rm 数据卷名称
七:网络
Docker 网络是 Docker 容器之间进行通信的桥梁,也是容器与外部网络进行交互的通道。Docker 提供了多种网络模式来满足不同的网络需求。
- 默认网络模式(bridge):这是 Docker 的默认网络模式。Docker 安装时会创建一个名为 docker0 的虚拟网桥,并为每个容器分配一个唯一的 IP 地址。
- 主机模式(host):在这种模式下,容器直接使用宿主机的网络命名空间,与宿主机共享 IP 地址和端口。
- 自定义网络:Docker 允许用户创建自定义网络,以便在一个隔离的网络环境中连接多个容器。
- 1.查看所有网络
docker network ls
- 2.自定义创建网络
docker network create 网络别名
例如,docker network create test_net会创建一个名为test_net的新网络。
- 3.删除指定的网络
docker network rm 网络别名
例如,docker network rm test_net会删除名为test_net的网络 。(容器正在使用,不能删除)
- 4.查看网络的详细信息
docker network inspect 网络别名
例如,docker network inspect test_net会查看名为test_net的网络的详细信息。
- 5.删除所有未使用的网络
docker network prune 网络别名
相关推荐
- MySQL进阶五之自动读写分离mysql-proxy
-
自动读写分离目前,大量现网用户的业务场景中存在读多写少、业务负载无法预测等情况,在有大量读请求的应用场景下,单个实例可能无法承受读取压力,甚至会对业务产生影响。为了实现读取能力的弹性扩展,分担数据库压...
- 3分钟短文 | Laravel SQL筛选两个日期之间的记录,怎么写?
-
引言今天说一个细分的需求,在模型中,或者使用laravel提供的EloquentORM功能,构造查询语句时,返回位于两个指定的日期之间的条目。应该怎么写?本文通过几个例子,为大家梳理一下。学习时...
- 一文由浅入深带你完全掌握MySQL的锁机制原理与应用
-
本文将跟大家聊聊InnoDB的锁。本文比较长,包括一条SQL是如何加锁的,一些加锁规则、如何分析和解决死锁问题等内容,建议耐心读完,肯定对大家有帮助的。为什么需要加锁呢?...
- 验证Mysql中联合索引的最左匹配原则
-
后端面试中一定是必问mysql的,在以往的面试中好几个面试官都反馈我Mysql基础不行,今天来着重复习一下自己的弱点知识。在Mysql调优中索引优化又是非常重要的方法,不管公司的大小只要后端项目中用到...
- MySQL索引解析(联合索引/最左前缀/覆盖索引/索引下推)
-
目录1.索引基础...
- 你会看 MySQL 的执行计划(EXPLAIN)吗?
-
SQL执行太慢怎么办?我们通常会使用EXPLAIN命令来查看SQL的执行计划,然后根据执行计划找出问题所在并进行优化。用法简介...
- MySQL 从入门到精通(四)之索引结构
-
索引概述索引(index),是帮助MySQL高效获取数据的数据结构(有序),在数据之外,数据库系统还维护者满足特定查询算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构...
- mysql总结——面试中最常问到的知识点
-
mysql作为开源数据库中的榜一大哥,一直是面试官们考察的重中之重。今天,我们来总结一下mysql的知识点,供大家复习参照,看完这些知识点,再加上一些边角细节,基本上能够应付大多mysql相关面试了(...
- mysql总结——面试中最常问到的知识点(2)
-
首先我们回顾一下上篇内容,主要复习了索引,事务,锁,以及SQL优化的工具。本篇文章接着写后面的内容。性能优化索引优化,SQL中索引的相关优化主要有以下几个方面:最好是全匹配。如果是联合索引的话,遵循最...
- MySQL基础全知全解!超详细无废话!轻松上手~
-
本期内容提醒:全篇2300+字,篇幅较长,可搭配饭菜一同“食”用,全篇无废话(除了这句),干货满满,可收藏供后期反复观看。注:MySQL中语法不区分大小写,本篇中...
- 深入剖析 MySQL 中的锁机制原理_mysql 锁详解
-
在互联网软件开发领域,MySQL作为一款广泛应用的关系型数据库管理系统,其锁机制在保障数据一致性和实现并发控制方面扮演着举足轻重的角色。对于互联网软件开发人员而言,深入理解MySQL的锁机制原理...
- Java 与 MySQL 性能优化:MySQL分区表设计与性能优化全解析
-
引言在数据库管理领域,随着数据量的不断增长,如何高效地管理和操作数据成为了一个关键问题。MySQL分区表作为一种有效的数据管理技术,能够将大型表划分为多个更小、更易管理的分区,从而提升数据库的性能和可...
- MySQL基础篇:DQL数据查询操作_mysql 查
-
一、基础查询DQL基础查询语法SELECT字段列表FROM表名列表WHERE条件列表GROUPBY分组字段列表HAVING分组后条件列表ORDERBY排序字段列表LIMIT...
- MySql:索引的基本使用_mysql索引的使用和原理
-
一、索引基础概念1.什么是索引?索引是数据库表的特殊数据结构(通常是B+树),用于...
- 一周热门
-
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
程序员的开源月刊《HelloGitHub》第 71 期
-
详细介绍一下Redis的Watch机制,可以利用Watch机制来做什么?
-
假如有100W个用户抢一张票,除了负载均衡办法,怎么支持高并发?
-
Java面试必考问题:什么是乐观锁与悲观锁
-
如何将AI助手接入微信(打开ai手机助手)
-
redission YYDS spring boot redission 使用
-
SparkSQL——DataFrame的创建与使用
-
一文带你了解Redis与Memcached? redis与memcached的区别
-
如何利用Redis进行事务处理呢? 如何利用redis进行事务处理呢英文
-
- 最近发表
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)