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

速度明显快多了!

相关文章
|
24天前
|
监控 NoSQL 时序数据库
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
183 77
|
5天前
|
搜索推荐 安全 数据安全/隐私保护
7 个最能提高生产力的 Docker 容器
7 个最能提高生产力的 Docker 容器
75 35
|
1月前
|
监控 Docker 容器
在Docker容器中运行打包好的应用程序
在Docker容器中运行打包好的应用程序
|
5天前
|
Ubuntu Linux 开发工具
docker 是什么?docker初认识之如何部署docker-优雅草后续将会把产品发布部署至docker容器中-因此会出相关系列文章-优雅草央千澈
Docker 是一个开源的容器化平台,允许开发者将应用程序及其依赖项打包成标准化单元(容器),确保在任何支持 Docker 的操作系统上一致运行。容器共享主机内核,提供轻量级、高效的执行环境。本文介绍如何在 Ubuntu 上安装 Docker,并通过简单步骤验证安装成功。后续文章将探讨使用 Docker 部署开源项目。优雅草央千澈 源、安装 Docker 包、验证安装 - 适用场景:开发、测试、生产环境 通过以上步骤,您可以在 Ubuntu 系统上成功安装并运行 Docker,为后续的应用部署打下基础。
docker 是什么?docker初认识之如何部署docker-优雅草后续将会把产品发布部署至docker容器中-因此会出相关系列文章-优雅草央千澈
|
11天前
|
存储 Kubernetes 开发者
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
Docker 是一种开源的应用容器引擎,允许开发者将应用程序及其依赖打包成可移植的镜像,并在任何支持 Docker 的平台上运行。其核心概念包括镜像、容器和仓库。镜像是只读的文件系统,容器是镜像的运行实例,仓库用于存储和分发镜像。Kubernetes(k8s)则是容器集群管理系统,提供自动化部署、扩展和维护等功能,支持服务发现、负载均衡、自动伸缩等特性。两者结合使用,可以实现高效的容器化应用管理和运维。Docker 主要用于单主机上的容器管理,而 Kubernetes 则专注于跨多主机的容器编排与调度。尽管 k8s 逐渐减少了对 Docker 作为容器运行时的支持,但 Doc
72 5
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
|
16天前
|
关系型数据库 应用服务中间件 PHP
实战~如何组织一个多容器项目docker-compose
本文介绍了如何使用Docker搭建Nginx、PHP和MySQL的环境。首先启动Nginx容器并查看IP地址,接着启动Alpine容器并安装curl测试连通性。通过`--link`方式或`docker-compose`配置文件实现服务间的通信。最后展示了Nginx配置文件和PHP代码示例,验证了各服务的正常运行。
43 3
实战~如何组织一个多容器项目docker-compose
|
11天前
|
Unix Linux Docker
CentOS停更沉寂,RHEL巨变限制源代:Docker容器化技术的兴起助力操作系统新格局
操作系统是计算机系统的核心软件,管理和控制硬件与软件资源,为用户和应用程序提供高效、安全的运行环境。Linux作为开源、跨平台的操作系统,具有高度可定制性、稳定性和安全性,广泛应用于服务器、云计算、物联网等领域。其发展得益于庞大的社区支持,多种发行版如Ubuntu、Debian、Fedora等满足不同需求。
39 4
|
26天前
|
数据建模 应用服务中间件 nginx
docker替换宿主与容器的映射端口和文件路径
通过正确配置 Docker 的端口和文件路径映射,可以有效地管理容器化应用程序,确保其高效运行和数据持久性。在生产环境中,动态替换映射配置有助于灵活应对各种需求变化。以上方法和步骤提供了一种可靠且易于操作的方案,帮助您轻松管理 Docker 容器的端口和路径映射。
81 3
|
1月前
|
存储 安全 数据安全/隐私保护
Docker 容器化应用管理更加高效,但数据安全和业务连续性成为关键。
在数字化时代,Docker 容器化应用管理更加高效,但数据安全和业务连续性成为关键。本文探讨了 Docker 应用的备份与恢复策略,涵盖备份的重要性、内容、方法及常见工具,制定备份策略,恢复流程及注意事项,并通过案例分析和未来趋势展望,强调备份与恢复在保障应用安全中的重要性。
37 2
|
1月前
|
存储 缓存 监控
Docker容器性能调优的关键技巧,涵盖CPU、内存、网络及磁盘I/O的优化策略,结合实战案例,旨在帮助读者有效提升Docker容器的性能与稳定性。
本文介绍了Docker容器性能调优的关键技巧,涵盖CPU、内存、网络及磁盘I/O的优化策略,结合实战案例,旨在帮助读者有效提升Docker容器的性能与稳定性。
100 7