linux系统会有一个主进程pid=1,派生出其他进程来控制不同服务,pid三个服务可能会相互影响,期望三个不同的服务,在运行环境中实现相互不影响,不会增加服务器成本
延伸出能否将这三种服务分别封装起来
kvm:内核层+用户层+应用程序
容器技术:内核+引擎+应用程序
内核可直接与引擎交互,进程支持,以进程的方式控制应用程序,内核中主要yum install docker工具
操作系统维度:通过namespaces(名称空间)实现,实现以下6个空间隔离才能实现完全隔离
名称空间:最重要的属性是隔离
容器隔离了6个名称空间
mount | 文件系统,挂载点(一个文件系统内,不能重复挂载指定目录 ) |
---|---|
user | 操作进程的用户和用户组 |
pid | 进程编号 |
uts | 主机名和主机域 |
ipc | 信号量、消息队列、共享内存 |
net | 网络设备,网络协议栈,端口 |
docker:用于开发、交付和运用程序开发平台,可将应用程序与基础架构分开,可快速交付软件
开源应用引擎
打包方式封装应用,依赖到一个可移植的镜像中,容器之间不会有接口
优势
Docker的劣势
打包应用程序简单部署
前端开发好打包war/jar 包—>github gitlab私有仓库(代码仓库)---->jenkins测试(应用程序封装/构建镜像)---->运维下载,使用容器技术进行/发布
打包应用程序简单部署
可脱离底层硬件任意迁移(实现应用的隔离,将应用拆分并进行解耦)
+ 持续集成和持续交付(CI/CD)
+ 部署微服务
+ 提供PAAS产品(平台即服务)
c/s客户端,服务端
server端:服务器长期运行的程序
client端:程序可用来守护经常进行通信并指示操作接口
命令行界面(CLI)
客户端(docker命令)
docker run(运行)
docker start (开启)
docker rm (删除)
docker使用客户端-服务端架构
docker客户端与docker守护进程进行对话
Docker的镜像是创建容器的基础,类似虚拟机的快照,可以理解为一个面向 Docker 容器引擎的只读模板。
通过镜像启动一个容器,一个镜像是一个可执行的包,其中包括运行应用程序所需要的所有内容包含代码,运行时间,库、环境变量、和配置文件。
Docker的容器是从镜像创建的运行实例,它可以被启动、停止和删除。所创建的每一个容器都是相互隔离、互不可见,以保证平台的安全性。
可以把容器看做是要给简易版的linux环境(包括root用户权限、镜像空间、用户空间和网络空间等)和运行在其中的应用程序。
cker仓库是用来集中保存镜像的地方,当创建了自己的镜像之后,可以使用push命令将它上传到公有仓库(Public)或者私有仓库(Private)。当下次要在另外一台机器上使用这个镜像时,只需从仓库获取。
类似于:
yum仓库 公共仓库 本地yum仓库
Docker 的镜像、容器、日志等内容全部都默认存储在 /var/lib/docker 目录下。
总结:Docker是容器管理工具,容器由镜像创建而来,镜像从仓库中获取而来,仓库分为公有、私有。
面试题
)可自定义传参-----创建镜像/容器、启动,基于镜像启动之前
)yum install -y yum-utils device-mapper-persistent-data lvm2
#yum-utils提供了yum-config-manager
#device mapper存储驱动程序需要device-mapper-persistent-data和lvm2
#Device Mapper 是Linux2.6内核中支持逻辑卷管理的通用设备映射机制,它为实现用于存储资源管理的块设备驱动提供了一个高度模块化的内核架构。
yum-config-manager --add-repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
cd /etc/yum.repos.d/
cat docker-ce.repo
yum install -y docker-ce
systemctl stop firewalld.service
systemctl disable firewalld.service
setenforce 0
vim /etc/selinux/config
SELINUX=disabled
systemctl start docker.service
systemctl enable docker.service
systemctl daemon-reload
systemctl restart docker
vim /etc/sysctl.conf
net.ipv4.ip_forward=1
sysctl -p
service network restart
sudo systemctl restart docker
docker version
docker info
docker search 服务名
例如:
docker search nginx
docker pull 服务名
例如:
docker pull nginx
docker images
docker inspect 镜像的ID
例如
docker images
docker inspect dd34e67e3371
打标签
)docker tag 仓库名:原镜像名 仓库名:新镜像名
例如:
docker tag nginx:latest nginx:test
docker images
docker images | grep nginx
docker rmi 镜像的ID
docker rmi 仓库名:镜像名
例如:
docker rmi f6d0b4767a6c
docker images
docker rmi nginx:test
docker images
镜像导出
)docker save -o 存放镜像的位置 仓库名:镜像名
例如:
docker save -o /opt/nginx_latest nginx:latest
方法一:
docker load < 本地导出的镜像名
方法二:
docker --input 本地导出的镜像名
例如:
docker load < nginx_latest
docker load --input nginx_latest
docker push [OPTIONS] NAME[:TAG]
例如:按照下面的流程就可以上传到公有云,有兴趣的可以上传
#改标签
docker tag 仓库名:镜像名 用户名/仓库名:镜像名
#登录
docker login
Username: #用户名
Password: #密码
#上传
docker push 用户名/仓库名:镜像名
status
docker ps #查看运行中的容器
docker ps -a #加-a 列出所有的容器,包括未运行的容器
docker create [选项] 镜像运行的程序
-i:让容器的标准输入保持打开
-t:让Docker分配一个伪终端
例;
docker create -it nginx:latest /bin/bash
docker start 容器ID:启动一个或多个已经被停止的容器
docker stop 容器ID:停止一个运行中的容器
docker restart 容器ID:重启容器
例:
docker start d2098fd972d5
docker ps -a
docker stop d2098fd972d5
docker ps -a
docker restart d2098fd972d5
run=create+start
start/stop/restart
命令选项 | 说明 |
---|---|
-d | 后台运行容器,并返回容器ID |
-i | 以交互模式运行容器,通常与 -t 同时使用 |
-t | 为容器重新分配一个伪输入终端,通常与 -i 同时使用 |
-c | 命令表示后面的参数将会作为字符串读入作为执行的命令 |
-v | 绑定一个卷 |
-P | 随机端口映射,容器内部端口随机映射到主机的端口 |
-p | 指定端口映射,格式为:主机(宿主)端口:容器端口 |
–name | =“名称”: 为容器指定一个名称 |
–link name:alias | 添加链接到另一个容器,格式“–link容器名:别名” |
例如:
docker run nginx
docker run -d nginx
docker run -d nginx /bin/bash -c "ls"
docker exec [选项] 容器 命令
例:
docker exec -it dee708e734b4 /bin/bash
docker exec -it 41601db9c340 /bin/bash
exit//退出容器
#容器导出
docker export 容器ID > 备份文件名
#容器导入(会生成镜像,而不会创建容器)
cat 备份文件名 | docker import - 仓库名:镜像名
例如:
docker export dee708e734b4 > nginx_up
docker export 41601db9c340 > nginx_exited
cat nginx_up | docker import - nginx:web
docker rm 容器ID
例如:
docker rm 045f4a1bab0b
//删除未运行的容器
docker rm e3035dfe95a7
//批量删除容器
docker ps -a | awk '{print "docker rm "$1}' | bash
本章讲解了docker的三大组件和工作底层原理,以及docker的部署安装,和镜像、容器的相关命令操作
docker:轻量级的虚拟机,在linux容器里运行的开源工具
引擎统一了基础设施环境—docker环境----image----封装一个简易的操作系统
引擎统一程序打包(封装)方式----docker镜像----images
引擎统一程序部署(运行)方式—docker容器----基于镜像—运行为容器(可运行的环境)
实现一次构建、多次、多次使用
容器操作
-i:让容器的标准输入保持打开
-t:分配一个伪终端
-d:后台守护进程打开