🐱 个人主页:不叫猫先生
🙋♂️ 作者简介:前端领域新星创作者、阿里云专家博主,专注于前端各领域技术,共同学习共同进步,一起加油呀!
💫系列专栏:vue3从入门到精通、TypeScript从入门到实践
📢 资料领取:前端进阶资料以及文中源码可以找我免费领取
🔥 前端学习交流:博主建立了一个前端交流群,汇集了各路大神,互相交流学习,期待你的加入!(文末有我wx或者直接私信)
Docker是基于Go语言实现的开源应用容器引擎,通过对应用组件的封装、分发、部署、运行等生命周期的管理,使用户的应用及其运行环境能够做到 一次封装,到处运行。
Docker 使用客户端-服务器 (C/S) 架构模式。Docker 客户端会与 Docker 守护进程进行通信。Docker 守护进程会处理复杂繁重的任务,例如建立、运行、发布你的 Docker 容器。Docker 客户端和守护进程可以运行在同一个系统上,当然你也可以使用 Docker 客户端去连接一个远程的 Docker 守护进程。我们了解Docker内部构建,需要先了解几个概念:
Docker守护进程:Docker 守护进程运行在主机上。用户并不直接和守护进程进行交互,而是通过 Docker 客户端间接和其通信。
Docker客户端:接收用户的指令并与背后的 Docker 守护进程通信。
Images(镜像):是一个只读模板,镜像可以用来创建 Docker 容器,一个镜像可以创建很多容器,每一个镜像由一系列的层 (layers) 组成。
Containers(容器):Docker 利用容器(Container)独立运行的一个或一组应用,容器是用镜像创建的运行实例,镜像与容器的关系类比面向对象中的类和对象。它可以被启动、开始、停止、删除。每个容器都是相互隔离的、保证安全的平台。
Repository(仓库):仓库是集中存放镜像文件的场所。仓库(Repository)和仓库注册服务器(Registry)是有区别的,仓库注册服务器上往往存放着多个仓库,每个仓库中又包含了多个镜像,每个镜像有不同的标签(tag)。仓库分为公开仓库(Public)和私有仓库(Private)两种形式,最大的公开仓库是 Docker Hub。
容器类似于 VM,但是它们具有被放宽的隔离属性,可以在应用程序之间共享操作系统(OS)。 因此,容器被认为是轻量级的。容器与 VM 类似,具有自己的文件系统、CPU、内存、进程空间等。可以把容器看做是不用安装操作系统的虚拟机,容器化技术比虚拟机更加灵活,更加小巧,更加极致的利用物理机资源。具有优势如下:
systemctl start docker
docker search 镜像名称
docker pull 镜像名称 //默认下载latest
docker pull 镜像名称:5.7 //指定版本下载
docker images
docker image ls
docker rmi 镜像名称
docker run [可选参数] image
参数:
-p:端口映射(宿主机端口:容器端口,即将主机端口映射到容器端口)
-v:容器目录映射到本地目录(宿主机文件目录:容器文件目录,将宿主机文件挂载到容器目录)
-d:后台启动容器
-it:以交互式模式启动容器
–name:容器名称
比如:
docker run -it
--name verdaccio
-p 4873:4873
-v /root/verdaccio/conf:/root/verdaccio/conf
-v /root/verdaccio/storage:/root/verdaccio/storage
verdaccio/verdaccio
docker ps //查看正在运行的容器
docker ps -a //查看正在运行的容器和历史运行过的容器
docker rm 容器id
docker start 容器id //启动容器
docker restart 容器id //重启容器
docker stop 容器id //停止当前正在运行的容器
docker kill 容器id //强制停止当前容器
docker exec -it 容器id /bin/bash //进入当前容器后开启一个新的终端,可以在里面操作
docker attach 容器id //进入容器正在执行的终端
docker stop 容器id //停止某个运行中的容器
docker ps -a -q // 停止全部容器
exit//如果要正常退出不关闭容器,请按Ctrl+P+Q进行退出容器
docker logs --tail 300 -f jz-project
docker commit 容器id 你命名的镜像名称
docker build -t 你命名的镜像名称 dockerfile所在目录