Docker----快速入门

一、Docker介绍

Docker是一个容器化技术,它可以将一个软件及其依赖的环境打包到一个容器中,该容器是可移植的,这使得Docker完成了"一次编译,到处运行"的目的。

Docker由daemon,client和registry组成,其中daemon是守护进程,是运行在主机操作系统上的后台服务,我们通过客户端发送的命令,最终都是由daemon来接受和执行的。

client则是我们与Docker进行交互的工具,我们输入docker命令时就是在使用客户端。

registry是一个集中存储和分发Docker镜像的地方,最著名的就是Docker Hub,我们可以通过仓库来拉取镜像,也可以将自己构建的镜像推送到仓库进行共享。

它们之间的关系为用户通过client来输入命令,client将命令发送给daemon,daemon则根据命令来操作registry中的镜像或者本地的镜像,然后daemon根据镜像(image)来创建对应的容器(container)

关于image和container,两者的关系类似于Java中类和对象的关系,镜像是只读的文件,是静态的,它包含了某个软件运行时的所有数据,包含代码,配置环境,库,环境变量等。

而容器则可以看做镜像的具体实现这个容器是隔离的,可以创建和销毁的。

二、相关命令

1.daemon相关

1.启动docker :systemctl start docker

2.停止docker:systemctl stop docker

3.重启docker:systemctl restart docker

4.查看docker:systemctl status docker

5.设置为开机启动:systemctl enable docker

2.image相关

1.查看本地镜像

docker images docker -q

显示结果是这样的:

复制代码
REPOSITORY   TAG       IMAGE ID       CREATED       SIZE
redis        latest    466e5b1da2ef   2 weeks ago   137MB

其中REPOSITORY是镜像名称,TAG表示版本号,IMAGE ID就是镜像号,CREATED表示这个镜像在云端仓库上的创建时间,SIZE就是大小喽。

2.搜索镜像:

docker search 软件名

3.拉取镜像

docker pull 软件名:版本号

4.删除本地镜像

docker rmi imageId

3.container相关

1.查看容器

docker ps:查看正在运行的容器

docker ps -a:查看docker全部的容器

2.创建容器

docker run -id/t--name=容器名 镜像名:版本

-i:表示容器一直运行

-t:分配一个终端,进行交互式运行,也就是立即进入。这时候需要在后面加上/bin/bash

-d:后台创建一个容器,守护式,使用exec进入,使用exit退出。

3.进入容器

docker exec -it 容器名 /bin/bash

4.启动容器

docker start 容器名字

5.停止容器

docker stop 容器名字

6.删除容器

docker rm 容器名字

7.查看容器信息

docker inspect 容器名字

三、Docker数据卷

1.概述

数据卷本质是宿主机中的一个目录或者文件,当容器目录和数据卷目录绑定后,对方的修改会立即同步,一个数据卷可以被多个容器同时挂载,同时一个容器也可以被多个数据卷挂载。它的作用有3,1是将容器数据持久化,2是外部机器和容器间接通信,3是容器之间的数据交换。

2.配置数据卷

在创建/启动容器时,使用

docker run ..... -v 宿主机目录:容器内目录 ...镜像名:版本 /bin/bash

注意:1.目录必须是绝对路径。2.如果目录不存咋,则会自动创建。3.可以挂载多个数据卷。

3.数据卷容器

数据卷容器是多容器数据交换的另一种方式,使用时:1.创建启动数据卷容器。docker run -it --name=数据卷容器名 -v/volumn 镜像名:版本号 /bin/bash

2.使用数据卷容器名:docker run -it --name=容器名 --volumes -from 数据卷容器名 镜像名:版本号 /bin/bash

相关推荐
绝无仅有12 小时前
某东互联网大厂的Redis面试知识点分析
后端·面试·架构
shixian103041113 小时前
Dify Docker Compose 安装指南
docker·容器·eureka
曦樂~13 小时前
【Docker】Compose
docker·容器·eureka
加上音乐13 小时前
windows—wsl2—docker配置代理以push/pull
windows·docker·容器
serendipity_hky14 小时前
【微服务 - easy视频 | day04】Seata解决分布式事务
java·spring boot·分布式·spring cloud·微服务·架构
hour_go15 小时前
DeepHunt微服务故障定位系统核心技术解析1
微服务·云原生·架构
绝无仅有15 小时前
某东电商平台的MySQL面试知识点分析
后端·面试·架构
程序员古德15 小时前
25年11月软考架构真题《论无服务器架构(Serverless)》考后复盘总结
云原生·架构·serverless
milanyangbo16 小时前
从同步耦合到异步解耦:消息中间件如何重塑系统间的通信范式?
java·数据库·后端·缓存·中间件·架构
洛卡卡了17 小时前
当上传不再只是 /upload,我们是怎么设计大文件上传的
后端·面试·架构