云原生之Docker

docker

初识Docker

什么是Docker

docker是一个快速交付应用,运行应用的技术。可以将程序及其依赖、运行环境一起打包为一个镜像,可以部署在任意Linux操作系统。运行时利用沙箱机制形成隔离容器,各个应用互不干扰。

Docker与虚拟机

  • Docker将不同操作系统的函数库、程序和依赖打包在一个镜像文件中
  • 虚拟机使用Hypervisor等技术模拟计算机硬件,在模拟的硬件上安装完整的操作系统

Docker的优点:

  • Docker打包的只是阉割版的操作系统的函数库,而虚拟机需要安装整个操作系统,因此,Docker的磁盘占用一般远低于虚拟机,性能也比虚拟机好。
  • 在启动时,Docker启动的是一个进程,而虚拟机需要先启动操作系统,因此,Docker的启动速度也更快。

Docker相关术语及架构

镜像和容器

镜像:Docker将应用程序及其所需的依赖、函数库、环境、配置等文件打包在一起,称为镜像
容器:镜像中的应用程序运行后形成的进程就是容器,Docker会给容器做隔离,对外不可见

DockerHub

DockerHun是一个Docker镜像的托管平台,这样的平台称为Docker Registry

Docker架构

Docker是一个CS架构,由两部分组成

服务端:Docker守护进程,负责处理Docker指令,管理镜像、容器等
客户端:通过命令或RestApI向Docker服务端发送指令,可以在本地或服务端发送指令

Docker命令

镜像操作命令

bash 复制代码
docker build # 构建镜像
docker push # 推送镜像到服务
docker pull # 从服务拉取镜像
docker save # 保存镜像为一个压缩包
docker load # 加载压缩包为镜像
docker images # 查看镜像
docker rmi # 删除镜像

容器操作命令

bash 复制代码
docker run # 通过镜像创建并运行容器
docker pause # 让一个处于运行状态的容器进入暂停状态
docker unpause # 让一个处于暂停状态的容器进入运行状态
docker stop # 让一个处于运行状态的容器进入停止状态
docker start # 让一个处于停止状态的容器进入运行状态
docker exec # 进入容器执行命令
docker logs # 查看容器的运行日志
docker ps # 查看所有运行的容器及状态

暂停和停止的区别是暂停只是将进程挂起不再执行,而停止会释放内存和其他资源

数据卷命令

Docker容器内的资源会在容器删除时全部释放,因此如果进行服务的升级和重新打包部署时我们将丢失容器内的全部数据.可以通过数据卷挂载将容器内目录挂载在宿主机目录上以保存和修改数据。

bash 复制代码
docker volume create # 创建数据卷
docker volume ls # 数据卷列表
docker volume inspect # 检查数据卷
docker volume rm # 删除数据卷
docker volume prune # 删除未使用的数据卷

可以在容器运行时通过-v 数据卷名或宿主机目录名:容器内目录名 来进行数据卷的挂载。

自定义镜像

镜像结构

镜像是分层结构,每一层称为一个Layer,大致可分为三部分:

  • BaseImage层:包含基本的系统函数库、环境变量、文件系统
  • Entrypoint:入口,是镜像中应用启动的命令
  • 其他:在BaseImage基础上添加依赖、安装程序、完成整个应用的安装和配置

Dockerfile

Dockerfile是一个文本文件,包含多个指令,用指令说明执行什么操作来构建镜像,每一个指令形成一层Layout

指令 说明 示例
FROM 设置基础镜像 FROM centos:6
ENV 设置环境变量,可在后面指令使用 ENV key value
COPY 拷贝本地文件到镜像的指定目录 COPY ./mysql-5.7.rpm /tmp
RUN 执行Linux的shell命令,一般是安装过程的命令 RUN yum install gcc
EXPOSE 指定容器运行时监听的端口,是给镜像使用者看的 EXPOSE 8080
ENTRTPOINT 镜像中应用的启动命令,容器运行时调用 EXTRTPOINT java -jar xx.jar

更多命令参见Docker官方文档

DockerCompose

DockerCompose可以基于Compose文件帮助我们快速的部署分布式应用,而无需手动一个个创建和运行容器

Compose文件是一个文本文件,可以通过指定定义集群的每个容器如何运行

dockerfile 复制代码
version: "3.8"
services: 
	mysel:
		image: mysql:5.7.25
		environment:
		 MYSQL_ROOT_PASSWORD: 123
		volumes:
		- /tmp/mysql/data:/var/lib/mysql
		- /tmp/mysql/conf/hmy.cnf:/etc/mysql/config.d/hmy.cnf

安装

Linux下安装

bash 复制代码
curl -L https://github.com/docker/compose/releases/download/1.29.1/docker-compose-'uname -s'-'uname -m' > /user/local/bin/docker-compose

修改文件权限

bash 复制代码
chmod +x /usr/local/bin/docker-compose

常用命令

bash 复制代码
docker-compose up #创建并启动容器
docker-compose restart #重新启动一个或几个容器
相关推荐
蝸牛ちゃん3 小时前
云计算三大服务模式深度解析:IaaS、PaaS、SaaS
云原生·系统架构·云计算·软考高级·saas·paas·iaas
阿里云云原生3 小时前
GPU 降成本免运维,睿观 AI 助手选择函数计算
云原生·serverless
潘晓可4 小时前
Docker部署Nginx代理多个服务:公网域名与内网IP场景全解
nginx·docker·nginx proxy
KKKingWei5 小时前
Kubernetes Dashboard UI 部署安装
云原生·容器·kubernetes
素雪风华6 小时前
Jenkins+Gitee+Docker容器化部署
java·docker·gitee·jenkins·springboot·持续部署
麟城Lincoln6 小时前
【Linux-云原生-笔记】系统引导修复(grub、bios、内核、系统初始化等)
linux·笔记·云原生·bios·grub·系统修复·系统引导
KubeSphere 云原生6 小时前
云原生周刊:镜像兼容性
云原生
蓝天居士7 小时前
docker常用命令集(2)
docker·容器
panamera127 小时前
云端docker小知识
运维·docker·容器