首页 教程 开发工具 Docker--Docker Container(容器) 之 操作实例

Docker--Docker Container(容器) 之 操作实例

容器的基本操作

容器的操作步骤其实很简单,根据拉取的镜像,进行启动,后可以查看容器,不用时停止容器,删除容器

下面简单演示操作步骤

1.创建并运行容器

例如,创建一个名为"my-nginx"的交互式Nginx容器,并将容器端口80映射到主机端口8080,可以使用以下命令:

docker run -it --name my-nginx -p 8080:80 nginx

2.查看容器

  • docker ps:列出当前正在运行的容器。
  • docker ps -a:列出所有容器,包括已经停止的。

按照我们在linux执行的命令,通常是使用ls来进行查看对应的目录,而容器其实也是可以这样操作的:
Docker--Docker Container(容器) 之 操作实例

docker container ls 等价于 docker ps

只不过是我们习惯用docker ps 的命令了;

3.停止容器

使用docker stop命令可以停止一个正在运行的容器。例如,停止名为"my-nginx"的容器:

docker stop my-nginx

另外,docker kill命令也可以用来停止容器,但它会立即发送SIGKILL信号给容器,可能会导致数据丢失或状态不一致,因此通常不建议使用。

对于容器ID,能直接通过ID前三位直接进行操作:
Docker--Docker Container(容器) 之 操作实例

4.删除容器

使用docker rm命令可以删除一个已经停止的容器。例如,删除名为"my-nginx"的容器:

docker rm my-nginx

如果需要一次性删除所有已经停止的容器,可以使用以下命令:

docker rm $(docker ps -a -q)

容器的批量处理技巧

docker ps + 选项

  • -a 所有容器
  • -f 根据给定条件进行过滤
  • -q 静默获取容器id

注:docker ps 等价于 docker container ls

例如:根据名称过滤得到一个容器编号:
Docker--Docker Container(容器) 之 操作实例

根据状态信息获取对应的容器:
Docker--Docker Container(容器) 之 操作实例
获取停止运行状态的容器:
Docker--Docker Container(容器) 之 操作实例
获取容器的全部id:
Docker--Docker Container(容器) 之 操作实例

容器的运行方式

attached模式

在这种模式下,容器在前台运行,并且容器的日志会实时地展现到宿主机的命令行窗口中。

  • 定义:attached模式是指Docker容器在前台运行,并且与宿主机的命令行窗口保持连接的状态。
  • 特点:
  1. 实时日志输出:容器的日志会实时地输出到宿主机的命令行窗口中,方便用户进行实时监控和调试。
  2. 交互性强:用户可以在宿主机的命令行窗口中直接对容器进行操作,如输入命令、查看文件等。
  3. 占用端口:attached模式会占用宿主机的命令行窗口,直到用户手动停止容器或关闭窗口。

使用场景
attached模式更适用于容器和程序的调试阶段。在调试过程中,开发人员需要实时监控容器的日志输出,以便及时发现和解决问题。同时,开发人员还需要在容器中执行一些命令来查看文件、修改配置等,attached模式提供了这样的交互环境。

例子:
在启动Docker容器时,如果不加-d或–detach参数,则容器会以attached模式运行。例如,使用以下命令启动一个Nginx容器:

docker container run -p 80:80 nginx

Docker--Docker Container(容器) 之 操作实例

detached模式

detach模式是指Docker容器在后台运行,并且与当前的命令行窗口或终端分离的状态。

特点:

  • 后台运行:容器在detach模式下会在后台运行,不会占用当前的命令行窗口或终端。
  • 日志输出:虽然容器在后台运行,但其日志仍然会输出到Docker的日志系统中,可以通过docker logs命令查看。
  • 资源占用:detach模式下的容器会占用系统资源,如CPU、内存和磁盘等,但不会影响当前命令行窗口或终端的使用。

使用场景
detach模式更适用于需要长时间运行的服务或应用程序,如Web服务器、数据库等。这些服务或应用程序通常不需要频繁的用户交互,因此可以在后台运行,并释放当前的命令行窗口或终端资源。

例如
在启动Docker容器时,使用-d或–detach参数可以使容器以detach模式运行。例如,使用以下命令启动一个Nginx容器:

docker run -p 8080:80--name mynginx3 -d nginx:1.23.4

Docker--Docker Container(容器) 之 操作实例

根据命令查看日志信息:

docker logs 8e7

Docker--Docker Container(容器) 之 操作实例

可以将其转化为attach模式,一旦访问服务器地址就有日志信息:

docker attach 8e7

Docker--Docker Container(容器) 之 操作实例

interative模式

interactive模式是指Docker容器在运行时,用户可以通过命令行与容器内部进行实时交互的状态。

特点:

  • 实时交互:用户可以在命令行中直接输入命令,并实时查看容器的响应和输出。
  • 灵活性强:用户可以根据需要随时调整容器的配置、查看文件、安装软件等。
  • 适用于开发和调试:interactive模式特别适用于需要频繁与容器内部进行交互的场景,如开发、测试和调试等。

在启动Docker容器时,使用-it参数可以使容器以interactive模式运行。其中,-i表示保持标准输入流打开,-t表示分配一个伪终端。例如,使用以下命令启动一个基于Ubuntu镜像的容器,并进入其内部的bash命令行环境:

docker run -it ubuntu bash

这条命令会启动一个基于Ubuntu镜像的容器,并为用户分配一个伪终端,用户可以在其中执行Linux命令,与容器进行交互。

容器自动重启

容器可以通过配置选项参数来让其自动重启:
docker run --restart=no [容器名] :默认值不自动重启
docker run --restart=always [容器名] :always 容器退出时总是重启
docker run --restart=on-failure:3 [容器名] : on-failure 若容器的退出状态非 0,则docker 自动重启容器,还可以指定重启次数,若超过指定次数未能启动容器则放弃;

下面演示自动重启的例子:
先运行一个容器,并将docker run --restart=always [容器名] :always 选项加上:

docker run --name mynginx5 -d -p 8080:80--restart always nginx:1.23.4

此时,容器在后台运行:
Docker--Docker Container(容器) 之 操作实例
容器被kill之后仍然在运行:
Docker--Docker Container(容器) 之 操作实例
最后释放空间:

docker stop mynginx5 docker rm mynginx5

设置容器的环境变量

在运行容器时,可以使用docker run命令的-e参数来设置环境变量。这种方式允许在创建和启动容器时动态地传递环境变量

下面来演示一下:

启动一个 nginx 容器,配置环境变量,TEST=1:

docker run--name mynginx5 -d -p 8080:80-e TEST=1 nginx:1.23.4

进入容器并查看:

root@VM-8-12-ubuntu:~# docker exec -it mynginx5 bash root@34b076bc51da:/# env 丨 grep TEST TEST=1 root@34b076bc51da:/# exit exit

释放空间:

root@VM-8-12-ubuntu:~# docker stop mynginx5 mynginx5 root@VM-8-12-ubuntu:~# docker rm mynginx5 mynginx5

注意:

  • 环境变量的命名:环境变量的命名应遵循一定的规范,避免使用与操作系统或应用程序保留的环境变量名相冲突的名称。
  • 环境变量的值:环境变量的值应避免包含敏感信息,如密码、密钥等。如果必须包含敏感信息,应确保这些信息的安全存储和传输。
  • 环境变量的作用范围:设置的环境变量只在容器内部生效,不会影响到宿主机或其他容器。如果需要在多个容器之间共享环境变量,可以考虑使用Docker网络、Docker Configs或Docker Secrets等功能。
评论(0)条

提示:请勿发布广告垃圾评论,否则封号处理!!

    猜你喜欢
    【MySQL】用户管理

    【MySQL】用户管理

     服务器/数据库  2个月前  2.15k

    我们推荐使用普通用户对数据的访问。而root作为管理员可以对普通用户对应的权限进行设置和管理。如给张三和李四这样的普通用户权限设定后。就只能操作给你权限的库了。

    Cursor Rules 让开发效率变成10倍速

    Cursor Rules 让开发效率变成10倍速

     服务器/数据库  2个月前  1.21k

    在AI与编程的交汇点上,awesome-cursorrules项目犹如一座灯塔,指引着开发者们驶向更高效、更智能的编程未来。无论你是经验丰富的老手,还是刚入行的新人,这个项目都能为你的编程之旅增添一抹亮色。这些规则文件就像是你私人定制的AI助手,能够根据你的项目需求和个人偏好,精确地调教AI的行为。突然间,你会发现AI不仅能理解Next.js的最佳实践,还能自动应用TypeScript的类型检查,甚至主动提供Tailwind CSS的类名建议。探索新的应用场景,推动AI辅助编程的边界。

    探索Django 5: 从零开始,打造你的第一个Web应用

    探索Django 5: 从零开始,打造你的第一个Web应用

     服务器/数据库  2个月前  1.12k

    Django 是一个开放源代码的 Web 应用程序框架,由 Python 写成。它遵循 MVT(Model-View-Template)的设计模式,旨在帮助开发者高效地构建复杂且功能丰富的 Web 应用程序。随着每个版本的升级,Django 不断演变,提供更多功能和改进,让开发变得更加便捷。《Django 5 Web应用开发实战》集Django架站基础、项目实践、开发经验于一体,是一本从零基础到精通Django Web企业级开发技术的实战指南《Django 5 Web应用开发实战》内容以。

    MySQL 的mysql_secure_installation安全脚本执行过程介绍

    MySQL 的mysql_secure_installation安全脚本执行过程介绍

     服务器/数据库  2个月前  1.08k

    mysql_secure_installation 是 MySQL 提供的一个安全脚本,用于提高数据库服务器的安全性

    【MySQL基础篇】概述及SQL指令:DDL及DML

    【MySQL基础篇】概述及SQL指令:DDL及DML

     服务器/数据库  2个月前  482

    数据库是长期存储在计算机内的、有组织的、可共享的、统一管理的大量数据的集合。数据库不仅仅是数据的简单堆积,而是遵循一定的规则和模式进行组织和管理的。数据库中的数据可以包括文本、数字、图像、音频等各种类型的信息。

    Redis中的哨兵(Sentinel)

    Redis中的哨兵(Sentinel)

     服务器/数据库  2个月前  309

    ​ 上篇文章我们讲述了Redis中的主从复制(Redis分布式系统中的主从复制-CSDN博客),本篇文章针对主从复制中的问题引出Redis中的哨兵,希望本篇文章会对你有所帮助。