Ubantu docker学习笔记(四)docker容器操作

简介: Ubantu docker学习笔记(四)docker容器操作

前面几节的学习,我们都是针对于我们的镜像,现在来到我们的容器啦!

我们可以在我们镜像(快照)的基础上,来对容器进行运行

一、容器运行

docker run 镜像名

其实这里的run有两个意思,一个时creat(创建容器)还有一个是start(开始容器执行)

举个列子

docker run centos cal

docker ps -a

可以看到我们是去传递了一个cal,然后再去打印

我们也可以去指定参数然后再去打印

1.进入centos

docker run centos cal /bin/bash

2.打印

cal

退出,查看

1.对终端进行操作

也就是进入我们的交互环境,我们可以在这个容器上创建一个环境变量,并直接通过他的容器号来进行捕获

docker run -d  -it -e key=1000  centos

记住你前面的容器号

docker exec -it  6f env

2.自动重启容器

1.运行一个正常的容器

docker run -it centos

2.运行一个可重启的容器

docker run -it --restart=always centos

3.查看容器状态

docker ps -a

3.自定义容器名

docker run -d --name=xiaotang centos

4.开启容器端口

这里我们以nginx为例子

docker run -d -p 80:80 nginx
docker ps -a

验证连通性(也可以用ipaddr去找到自己本机地址访问)

curl -I 127.0.0.1:80

停止容器

docker stop 491cec(启动nginx返回的端口号)

验证连通性

curl -I 127.0.0.1:80

5.与宿主机共享目录的容器

提前创建目录

cd
mkdir test
touch /root/test/a.txt /root/test/b.txt
ls /root/test/

运行容器

docker run -it -v /root/test/:/root/test/ --privileged centos  /bin/bash

:前:宿主机目录

:后:容器目录

–privileged:让其有真正的用户权限

ls /root/test/

二、进入容器

1.容器三种状态

(1)运行状态

docker run -d -p 80:80 --name=testnginx nginx
docker ps -a

(2)停止状态

docker pause testnginx 
docker ps -a

继续开始

docker unause testnginx 
docker ps -a

(3)终止状态

docker stop testnginx 
docker ps -a

2.docker attach和docker exec

这里主要对我们如何进入容器内部,通常不使用ssh,因为ssh违背了一个容器里面只有一个进程的要求,咱们介绍下面这两种docker的原生方式

(1)docker attach

启动一个后台运行的容器

docker run -it -d centos /bin/bash
docker attach 11(你运行的容器id)

退出的话有有两种

1.exit会直接退出
2.ctrl+p+q(退出容器但是不终止容器)

(2)docker exec

命令选项 描述
-detach , -d 根据给定的条件进行过滤
-env,-e 设置环境变量(仅本次会话)
–interractive,-i 控制台交互
–tty, -t 命令行交互的形式
–user,-u 设置用户名

启动一个后台运行的容器

docker run -it -d centos /bin/bash
docker exec 38c4(你运行的容器id) ls

这里最大的不同来了,如果我们使用exec命令来进入

docker exec  -it 38c4  /bin/bash

exit之后我们的镜像不会停止

三.停止容器删除

1.停止容器

暂停:docker pause 容器id
继续:docker unpause 容器id
强制停止:docker kill 容器id
查看运行id:docker ps -q
批量终止:docker stop 'docker ps -q'

2.删除容器

删除:docker rm 容器id
删除终止状态(正则表达式):sudo docker rm `docker ps -a|grep Exited|awk '{print $1}'`
删除终止状态(筛选):sudo docker rm $(sudo docker ps -qf status=exited)
删除所有终止状态的容器:sudo docker container prune
删除所有:docker rm -f 'docker ps -a -p'
grep:匹配
awk:扫描

停止并删除所有

docker stop $(docker ps -q) & docker rm $(docker ps -aq)

四.容器资源限制

1.内存资源

-m,–memory

设置容器可使用的最大内存,最小值是 4MB。

–memory-swap

设置容器可使用内存+Swap 的最大值。

–memory-swapiness

默认情况下,用户可以设置一个0-100 的值,代表允许内存与交换分区置换的比例。

–memory-reservation

设置一个内存使用的 son limit (非强制性限制),如果 Dcker 发现主机内存不足,会执行 OOM操作。这个值必须小于–memory 设置的值。

–kernel-memory

容器能够使用的内核内存的大小,最小值为 4MB。

–oom-kill-disable

设置是否运行 OOM 的时候终止容器进程。宿主机会在内存不足时,随机关闭一些进程,而该参数会保护容器进程不被关闭。只有通过设置-memory 限制容器内存,才可以使用该参数,否则容器会耗尽宿主机内存,而且导致宿主机应用被终止。

下面我们用一个压力模拟的镜像来试一试

docker run -it -m 300M --memory-swap=400M progrium/stress --vm 1 --vm-bytes 380M

以上示例运行了一个容器,分配可用最大内存为 300MB,可用 Swap 为100MB。其中,–vm 1参数表示启动一个内存工作线程,–vm-bytes 380M参数表示每个线程分配380MB内存。可以看到系统不断地给容器分配内存、释放内存,一直循环。由于使用的内存是 380MB,在最大使用量(400MB之内,容器正常运行。下面看看超出的情况

docker run -it -m 300M --memory-swap=400M progrium/stress --vm 1 --vm-bytes 450M

这里我们可以看到超出之后,直接停止了

2.限制CPU资源

限制cpu资源,主要通过修改每一个容器处理cpu的时间片来进行,然后我们可以通过-c来设置权重,比如说我设置CPU1=200,CPU2=300,那么他们使用率的比值就是2:3,下面我们通过一个列子来说明一下

docker run -it -d -c 200 --name CPU1 progrium/stress --cpu 228
docker run -it -d -c 300 --name CPU2 progrium/stress --cpu 281
docker stats

下面的2:3是不是就很明显了呢!

同时我们还有–cpuset-cpus可以去指定某一颗cpu,让其cpu跑满,这里我们用agileek/cpuset-test来测试一下

跑完之后记得删除镜像喔

docker stop $(docker ps -q) & docker rm $(docker ps -aq)
docker pull agileek/cpuset-test
docker run -it -d --cpuset-cpus=1 agileek/cpuset-test
top

跑完之后记得删除镜像喔

docker stop $(docker ps -q) & docker rm $(docker ps -aq)

3.限制容器Block I/O

在这里的话,docker可以去限制我们磁盘的读写,并去配置,下免我们来看看参数吧

命令选项 描述
–device-read-bps 限制读某个设备的 bps
–device-write-bps 限制写入某个设备的 bps
–device-read-iops 限制读某个设备的iops
–device-write-iops 限制写入某个设备的iops

下面我们又来举例子吧!

docker run -it -d --name test01 --blkio-weight 800 centos
docker run -it -d --name test02 --blkio-weight 400 centos
这样test01 就是test012的两倍!
如果出现下面这个恭喜你,不很遗憾,你的Ubuntu不支持
Your kernel does not support Block I/O weight or the cgroup is not mounted. Weight discarded.

下面我们重新来个例子,限制读写

docker run -it --device-write-bps /dev/sda:20MB centos
time dd if=/dev/zero of=test bs=1M count=800 oflag=direct

上面的话我们创建了一个写入不超过20MB的容器,然后我们通过time dd来模拟读写

下面我们再来看看创建一个不限制读写得容器

docker run -it centos
time dd if=/dev/zero of=test bs=1M count=800 oflag=direct

速度明显快多了!

相关文章
|
17天前
|
JavaScript 前端开发 数据安全/隐私保护
阿里云云效操作报错合集之流水线中获取不到CI_COMMIT_REF_NAME变量,导致docker镜像打包失败,什么原因
本合集将整理呈现用户在使用过程中遇到的报错及其对应的解决办法,包括但不限于账户权限设置错误、项目配置不正确、代码提交冲突、构建任务执行失败、测试环境异常、需求流转阻塞等问题。阿里云云效是一站式企业级研发协同和DevOps平台,为企业提供从需求规划、开发、测试、发布到运维、运营的全流程端到端服务和工具支撑,致力于提升企业的研发效能和创新能力。
|
9天前
|
边缘计算 物联网 开发者
什么是容器Docker?
什么是容器?容器,也叫Docker,是一个开源的容器化平台,用于开发、测试和部署应用程序。通过将软件打包为标准化的单元(容器),使得应用程序可以在任何地方一致地运行,不论是在开发者的本地机器上,还是在云计算平台上。Docker容器包含了应用程序运行所需的一切,包括代码、运行时、系统工具、系统库等,从而解决了“在我这里可以正常工作,但在服务器上不行”的问题。
33 1
|
13天前
|
安全 关系型数据库 开发者
Docker Compose凭借其简单易用的特性,已经成为开发者在构建和管理多容器应用时不可或缺的工具。
Docker Compose是容器编排利器,简化多容器应用管理。通过YAML文件定义服务、网络和卷,一键启动应用环境。核心概念包括服务(组件集合)、网络(灵活通信)、卷(数据持久化)。实战中,编写docker-compose.yml,如设置Nginx和Postgres服务,用`docker-compose up -d`启动。高级特性涉及依赖、环境变量、健康检查和数据持久化。最佳实践涵盖环境隔离、CI/CD、资源管理和安全措施。案例分析展示如何构建微服务应用栈,实现一键部署。Docker Compose助力开发者高效驾驭复杂容器场景。
30 1
|
13天前
|
存储 监控 安全
Docker Compose:轻松实现容器编排的利器
【7月更文挑战第2天】 1. **基础与概念**:服务(多容器实例)、网络(灵活通信)、卷(数据持久化)和配置(安全管理)。 2. **实战指南**:安装Compose,编写`docker-compose.yml`文件,启动应用,并介绍依赖、环境变量、健康检查和数据持久化。 3. **最佳实践**:环境隔离、CI/CD集成、资源管理、日志监控、安全策略及案例分析,展示完整应用栈搭建。
36 1
|
5天前
|
Java 应用服务中间件 持续交付
Java面试题:简述Docker等容器化技术的原理及其在Java应用部署中的作用。
Java面试题:简述Docker等容器化技术的原理及其在Java应用部署中的作用。
12 0
|
13天前
|
缓存 Linux 开发工具
docker的centos容器使用yum报错
docker的centos容器使用yum报错
53 0
|
17天前
|
缓存 运维 Devops
阿里云云效操作报错合集之在构建过程中,Docker尝试从缓存中获取某个文件(或计算缓存键)时遇到了问题,该如何处理
本合集将整理呈现用户在使用过程中遇到的报错及其对应的解决办法,包括但不限于账户权限设置错误、项目配置不正确、代码提交冲突、构建任务执行失败、测试环境异常、需求流转阻塞等问题。阿里云云效是一站式企业级研发协同和DevOps平台,为企业提供从需求规划、开发、测试、发布到运维、运营的全流程端到端服务和工具支撑,致力于提升企业的研发效能和创新能力。
|
17天前
|
Java API Docker
使用Spring Boot和Docker进行容器化部署
使用Spring Boot和Docker进行容器化部署
|
17天前
|
运维 Serverless 文件存储
函数计算产品使用问题之在利用Docker镜像部署应用时,容器内的应用如何能访问函数计算配置的NAS挂载
函数计算产品作为一种事件驱动的全托管计算服务,让用户能够专注于业务逻辑的编写,而无需关心底层服务器的管理与运维。你可以有效地利用函数计算产品来支撑各类应用场景,从简单的数据处理到复杂的业务逻辑,实现快速、高效、低成本的云上部署与运维。以下是一些关于使用函数计算产品的合集和要点,帮助你更好地理解和应用这一服务。
|
关系型数据库 MySQL Linux
docker 常用操作命令
docker 镜像的增、查、删、改; docker 容器的增、查、删、改;
docker 常用操作命令