Docker基本概念与实践(二)-容器

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: Docker容器简介1.容器为docker的一个核心概念,简单来说容器为镜像的运行实例,但镜像为静态的只读文件,而容器则是带有运行时需要的可写文件层2.

Docker容器简介

1.容器为docker的一个核心概念,简单来说容器为镜像的运行实例,但镜像为静态的只读文件,而容器则是带有运行时需要的可写文件层
2.如果认为虚拟机是完整一套系统(包含内核 系统环境 应用等),那么docker容器为独立运行的一个或一组应用,以及它们必须的运行环境
3.docker容器十分轻便,用户可轻易的删除或创建
4.docker容器是基于镜像创建的,

容器与镜像的区别

具体参考 https://www.cnblogs.com/bethal/p/5942369.html

容器(container)的定义和镜像(image)几乎一模一样,也是一堆层的统一视角,唯一区别在于容器的最上面那一层是可读可写的。

img_561084df4579a72875769a693e170d95.png
镜像与容器
容器 = 镜像 + 可读写层

下面左图可以看到许多镜像文件的只读层。除了最下面的一层,其他层都有指针指向下一层,这些层为docker内部的实现细节,统一文件系统(union file system)技术能够将不同的层整合成一个文件系统,为这些层提供了一个统一的视角,这样就隐藏了多层的存在,在用户的角度看来,只存在一个文件系统。

img_a122cf90640807efcd6c55cfafbbfc08.png

例如在我的服务器上

#主机文件系统这些层的文件在 /var/lib/docker 下,查看结构,如果没有tree命令,sudo yum install tree -y
sudo tree -L 1 /var/lib/docker/
img_c854f59343fefb2de468e463e816be64.png
文件系统结构

元数据md(metadata)为这个层的额外信息,它不仅能够让Docker获取运行和构建时的信息,还包括父层的层次信息。需要注意,只读层和读写层都包含元数据。

img_43598930924ad63546603c3ea8ab5cd0.png

每个层包括一个指向父层的指针,若没有则说明在最顶层

img_59b8203b11682d57d3481db8e36c8781.png

基于镜像创建容器

docker run imagename
  • 它会在所有的镜像层之上增加一个可写层。这个可写层有运行在CPU上的进程,而且有两个不同的状态【运行态(Running)和退出态(Exited)。这就是Docker容器。当我们使用docker run启动容器,Docker容器就进入运行态,当我们停止Docker容器时,它就进入退出态】

  • 可以用一个镜像启动多个容器 这些容器启动后都是活动且彼此相互隔离

使用create创建容器
#查看所有容器,包括没启动的
docker ps -a

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

#创建容器,例如创建一个基于ubuntu系统的容器,本地有镜像直接用,没有的话则会先拉取再创建
docker create -it ubuntu:latest

#停止容器
docker stop 容器id/容器名

#重新启动已存在的容器
docker start 容器id/容器名

#删除容器(非运行状态) 加 -f 会发送sigkill信号给容器 终止运行中的应用 
docker rm 容器id/容器名

#删除所有容器
docker rm $(docker ps -a -q) 

#查看容器占用情况
docker stats

#运行容器,
docker run 容器id/容器名

#容器id为随机码,而容器名看似无意义,可自定义更改容器名,更改后可用新的容器名做相应容器操作
docker rename oldname newname
img_f69b730bb2b90d2b186ec0d91a59099b.png

启动容器

启动容器有两种方式

1.基于镜像新建一个容器并启动 --docker run
2.在终止状态下的容器重新启动 处于终止状态的容器 通过docker start xxx(容器名) docker start xxx(重启) 启动 
区别:一个是新建并启动 一个是启动已有的,docker run相当于执行了两步操作:将镜像放入容器中(docker create),然后将容器启动,使之变成运行时容器(docker start)。
docker run = docker create + docker start
#docker run启动容器,例如基于ubuntu镜像启动 并输出hello world,跟在宿主机下执行 /bin/echo 'hello world' 无差别  
docker run ubuntu /bin/echo 'hello world' 

#启动bash终端,允许用户交互,在容器内做shell命令操作,其中-t 让docker分配个伪终端并绑定在容器做标准输出
docker run -t -i ubuntu /bin/bash

#查看日志
docker logs 容器id/名

#如果日志太多想看最新10m的
docker logs 容器id/名 -f --since=10m
img_e7e386eb74ff2cd7aa9c2ebb9abc2cc9.png
docker run背后的操作
img_3301c45676b27df49ed03ebc9cfbfacf.png
img_1e55b8533a58e919f90cc63b153121ab.png

守护态运行容器

#更多时候 需让容器在后台以守护态(Daemonized)形式运行 加上 -d 实现,如后台运行每隔1s输出‘hello world’
docker run -d ubuntu /bin/sh -c "while true; do echo hello world; sleep 1; done"

#查看容器具体信息 包含启动容器时执行的命令(COMMAND)
docker inspect 容器id/容器名

#查看运行容器的日志 
docker logs 容器id/容器名
img_d4bc89ec75b68535f9410580c8c47739.png
img_5b1e98cf95e6069c83a4e90ef8b3baa6.png
#例如启用tomcat8镜像命名为webapp,将容器的8080端口映射到主机的8080端口,后台运行
docker run -p 8080:8080 --name webapp -d tomcat:8

进入容器

进入docker容器主要有三种方式
1.docker attach命令
2.docker exec命令 
3.nsenter工具等。
#方式1 不推荐,因为当多个窗口同事attach到一个容器 所有窗口都会同步显示 当某个窗口因命令阻塞 其它窗口也无法执行操作
docker attach 容器id/容器名

#方式2 1.3后版本的新特性,可在容器内部运行命令,例如先启动一个之前基于ubuntu镜像创建过的容器,再进入,最后退出
docker start f9ac49f4e209
sudo docker exec -ti f9ac49f4e209 /bin/bash
img_91f5e9653ba20753084e76b12995fa59.png

导入与导出容器

导出容器
#导出容器是导出一个已创建的容器到一文件 不管此时容器是否处于运行状态,使用docker export导出 这边eloquent_nobel为容器名 ubuntu_garwer.tar为自定义导出文件名
sudo docker export eloquent_nobel > ubuntu_garwer.tar  
img_86f313b19a1809fa9ecb9e7305f618c3.png
导出容器
导入容器
#使用docker import命令导出 成为镜像 注意空格,,
cat ubuntu_garwer.tar | sudo docker import - mybuntu:v1.0
img_fa3702e322b8c8b845ee9476a23a4577.png
导入容器
目录
相关文章
|
28天前
|
监控 NoSQL 时序数据库
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
198 77
|
9天前
|
搜索推荐 安全 数据安全/隐私保护
7 个最能提高生产力的 Docker 容器
7 个最能提高生产力的 Docker 容器
78 35
|
9天前
|
Ubuntu Linux 开发工具
docker 是什么?docker初认识之如何部署docker-优雅草后续将会把产品发布部署至docker容器中-因此会出相关系列文章-优雅草央千澈
Docker 是一个开源的容器化平台,允许开发者将应用程序及其依赖项打包成标准化单元(容器),确保在任何支持 Docker 的操作系统上一致运行。容器共享主机内核,提供轻量级、高效的执行环境。本文介绍如何在 Ubuntu 上安装 Docker,并通过简单步骤验证安装成功。后续文章将探讨使用 Docker 部署开源项目。优雅草央千澈 源、安装 Docker 包、验证安装 - 适用场景:开发、测试、生产环境 通过以上步骤,您可以在 Ubuntu 系统上成功安装并运行 Docker,为后续的应用部署打下基础。
docker 是什么?docker初认识之如何部署docker-优雅草后续将会把产品发布部署至docker容器中-因此会出相关系列文章-优雅草央千澈
|
15天前
|
存储 Kubernetes 开发者
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
Docker 是一种开源的应用容器引擎,允许开发者将应用程序及其依赖打包成可移植的镜像,并在任何支持 Docker 的平台上运行。其核心概念包括镜像、容器和仓库。镜像是只读的文件系统,容器是镜像的运行实例,仓库用于存储和分发镜像。Kubernetes(k8s)则是容器集群管理系统,提供自动化部署、扩展和维护等功能,支持服务发现、负载均衡、自动伸缩等特性。两者结合使用,可以实现高效的容器化应用管理和运维。Docker 主要用于单主机上的容器管理,而 Kubernetes 则专注于跨多主机的容器编排与调度。尽管 k8s 逐渐减少了对 Docker 作为容器运行时的支持,但 Doc
83 5
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
|
20天前
|
关系型数据库 应用服务中间件 PHP
实战~如何组织一个多容器项目docker-compose
本文介绍了如何使用Docker搭建Nginx、PHP和MySQL的环境。首先启动Nginx容器并查看IP地址,接着启动Alpine容器并安装curl测试连通性。通过`--link`方式或`docker-compose`配置文件实现服务间的通信。最后展示了Nginx配置文件和PHP代码示例,验证了各服务的正常运行。
45 3
实战~如何组织一个多容器项目docker-compose
|
26天前
|
人工智能 运维 监控
阿里云ACK容器服务生产级可观测体系建设实践
本文整理自2024云栖大会冯诗淳(花名:行疾)的演讲,介绍了阿里云容器服务团队在生产级可观测体系建设方面的实践。冯诗淳详细阐述了容器化架构带来的挑战及解决方案,强调了可观测性对于构建稳健运维体系的重要性。文中提到,阿里云作为亚洲唯一蝉联全球领导者的容器管理平台,其可观测能力在多项关键评测中表现优异,支持AI、容器网络、存储等多个场景的高级容器可观测能力。此外,还介绍了阿里云容器服务在多云管理、成本优化等方面的最新进展,以及即将推出的ACK AI助手2.0,旨在通过智能引擎和专家诊断经验,简化异常数据查找,缩短故障响应时间。
阿里云ACK容器服务生产级可观测体系建设实践
|
6天前
|
存储 人工智能 调度
容器服务:智算时代云原生操作系统及月之暗面Kimi、深势科技实践分享
容器技术已经发展成为云计算操作系统的关键组成部分,向下高效调度多样化异构算力,向上提供统一编程接口,支持多样化工作负载。阿里云容器服务在2024年巴黎奥运会中提供了稳定高效的云上支持,实现了子弹时间特效等创新应用。此外,容器技术还带来了弹性、普惠的计算能力升级,如每分钟创建1万Pod和秒级CPU资源热变配,以及针对大数据与AI应用的弹性临时盘和跨可用区云盘等高性能存储解决方案。智能运维方面,推出了即时弹性节点池、智能应用弹性策略和可信赖集群托管运维等功能,进一步简化了集群管理和优化了资源利用率。
|
25天前
|
关系型数据库 MySQL Docker
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
89 24
|
15天前
|
Unix Linux Docker
CentOS停更沉寂,RHEL巨变限制源代:Docker容器化技术的兴起助力操作系统新格局
操作系统是计算机系统的核心软件,管理和控制硬件与软件资源,为用户和应用程序提供高效、安全的运行环境。Linux作为开源、跨平台的操作系统,具有高度可定制性、稳定性和安全性,广泛应用于服务器、云计算、物联网等领域。其发展得益于庞大的社区支持,多种发行版如Ubuntu、Debian、Fedora等满足不同需求。
40 4
|
26天前
|
人工智能 Cloud Native 调度
阿里云容器服务在AI智算场景的创新与实践
本文源自张凯在2024云栖大会的演讲,介绍了阿里云容器服务在AI智算领域的创新与实践。从2018年推出首个开源GPU容器共享调度方案至今,阿里云容器服务不断推进云原生AI的发展,包括增强GPU可观测性、实现多集群跨地域统一调度、优化大模型推理引擎部署、提供灵活的弹性伸缩策略等,旨在为客户提供高效、低成本的云原生AI解决方案。