百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

Docker常用命令行总结

wptr33 2024-11-22 22:00 24 浏览

容器和云是当下最流行的技术,这也是任何IT工作者都应该掌握技能。如果你还没有学过Docker,那么本文就是给你准备的。本文中将抛开常见教程中的预先的一大堆理论说明,直接从上手操作开始。如果你学会了文中所列举的命令,则证明已经初步学会了docker入门技能,更多知识你可以在此基础上再深入学习。

容器管理

容器,就是Linux被严格限制资源约束(cgroups),安全约束(Unix权限,capabilities,SELinux,AppArmor,seccomp等)和命名空间(PID,网络,mount,等等)限制出来的应用。docker是最常见的一种容器技术,Docker由Docker daemon(监听程序)、Docker镜像(层)和Docker存储(卷)和Docker网络的构成。一个容器就是指由docker运行时基于docker镜像创建的一个docker实例。

创建容器

要创建一个容器,使用create命令, [镜像名]替换为需要运行的镜像的名称。

docker create [镜像名]

当按下enter按键时,Docker默认会本地镜像库中搜索,如果没有,会去访问Docker Hub中搜索该镜像,其下载本地系统并创建一个停止的容器。

比如,我们创建一个golang容器。

创建和运行容器

要创建和运行容器,请使用run命令,[镜像名]替换为需要运行的镜像的名称将。该命令会从本地、Docker Hub中搜索指定的镜像,并下载到本地,创建一个容器并启动该容器。

docker run [镜像名]

启动停止的容器

要在启动的一个容器(已停止),可以运行start命令。start命令后可以使用 [容器名]或容器ID替换。可以使用docker ps -a 查看本地容器列表(包括已停止的容器)。

docker start [容器名/ID]

停止容器

要停止一个运行中的容器,可以使用stop命令。容器停止后,可以用start命令将其启动。

docker stop [容器名/ID]

重启容器

要重启一个容器,可以使用restart命令。命令可以将正在运行中的容器停止,然后再重新启动。

docker restart [容器名/ID]

暂停容器

如果需要在正在运行的容器中临时暂停该过程,可以使用pause命令。

docker pause [容器名/ID]

恢复暂停的容器

暂停容器后,可以使用unpause命令恢复已暂停的容器。

docker unpause [容器名/ID]

列出正在运行的容器

如果需要查看系统上正在运行的容器的列表,请运行以下命令。

docker ps 或者

docker container ls

上面的命令只会列出当前正在运行的容器,如果要列出本机所有的容器,可以使用:

docker ps -a

CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES

fc6da76218aa golang "bash" 2 minutes ago Created kind_shirley

删除容器

删除一个容器,可以使用rm命令。要删除容器,请确保容器已经停止,否则会报错。

docker rm [容器名/ID]

卸载容器

为了系统中删除一个容器,可以运行以下命令。用要删除的容器[容器名]的名称或ID替换。

docker rm [容器名/ID]

容器操作

如果要对容器执行操作,有两种方法,分别是exec命令和attach命令。

exec命令,用来在运行的容器中执行命令,比如

docker exec -it [容器名/ID] /bin/bash

会打开一个伪终端,可以在终端中执行命令。

attach命令,用来连接到正在运行中的容器:

docker attach --sig-proxy=false [容器名/ID]

attach到容器后,Ctrl+C可以退出,但是退出时,容器也会停止,为了退出时不影响容器运行,可以使用--sig-proxy=false参数,这样ctrl+C[D]后容器会继续运行。

查看容器日志

要查看当前容器的执行情况,需要查看容器日志。可以用attach到容器,可直接查看。当然更常用的方法是用logs命令

docker logs [容器名/ID]

logs 可以附带一些参数:

-f: 表示实时打印容器日志,想象为tail -f

--since 日期:表示打印制定日期以来的日志。

--tail N数字:表示打印最后N条日志,想象为tail -n

查看容器的配置

容器的所有配置信息实际上是一个json文件,可以使用inspect命令,查看该容器的所有信息。

docker inspect [容器名/ID]

镜像管理

容器镜像是包含Docker容器的操作系统,应用程序和初始状态的文件。可以从Dockerfiles构建,也可以用已经运行的容器创建。

在docker中,镜像是一个标准的Tar包,包中包含了:

Rootfs:容器上像操作系统的标准根(/)的目录。例如,带有/usr,/var,/home等的目录。

JSON文件:用来指定如何运行rootfs。例如,容器启动时在rootfs中运行的命令或入口点;为容器设置的环境变量;容器的工作目录;和其他一设置。

基于rootfs,其上面的json可以是互相依赖的,这样就把docker镜像分成了一个个的层:

以Dockerfile构建镜像

甲dockerfile是docker用来创建并建立一个容器的镜像的命令的列表。可以通过运行以下命令从dockerfile构建镜像。

docker build -f [dockerfile路径]

从容器构建镜像

还可以从正在运行的容器为基础构建镜像。这也是快速备份正容器的快照的方法。

docker commit [容器名] [镜像名]

从Docker Hub拉取镜像

可使用以下命令将镜像从Docker Hub下载到本地系统。

docker image pull [镜像名]

将镜像推送到Docker Hub

将容器镜像推送到Docker Hub之前,必须在Docker Hub上创建一个帐户,然后在终端登录,在终端中运行docker login命令:

docker login

然后按要求输入用户名和密码。认证成功后,可以使用以下命令将镜像推送到Docker Hub。

docker image push [镜像名]

列出容器镜像

如果需要查看系统上的镜像列表,请运行以下命令:

docker image ls

或者直接用

docker image

从系统中删除镜像

如果要从系统中删除镜像,请使用remove命令。

docker image remove [镜像名]

卷管理

通过docker run或docker create命令可以将默认的Docker Volumes附加到容器,这样创建的数据在镜像重建过程中保持不变。

创建Docker卷

要创建docker卷,可以对卷,使用create命令

docker volume create [卷名]

删除Docker卷

运行rm命令以删除Docker卷。请记住,如果删除一个卷,则将删除该卷中存储的所有数据。

docker volume rm [卷名]

查看卷信息

有时需要查看有关创建的卷的各种详细信息,可以对卷使用inspect命令

docker volume inspect [卷名]

列出所有Docker卷

如果需要查看系统上所有卷的列表,可以对卷使用ls命令

docker volume ls

网络管理

Docker网络决定了容器之间如何相互连接以及如何与Internet连接。可以为各种软件应用程序堆栈创建专用网络,以确保数据安全。

创建Docker网络

docker network的create命令会在当前系统上创建一个桥接网络,该桥接网络将容器彼此连接并共享主机的网络和Internet连接。

docker network create [网络名]

将容器连接到网络

为了将容器连接到新网络,请使用connect命令。

docker network connect [网络名] [容器名]

断开容器与网络的连接

要断开容器与网络的连接,请使用disconnect命令。

docker network disconnect [网络名] [容器名]

查看网络信息

如果需要检查网络上的详细信息,可以对网络使用inspect命令

docker network inspect [网络名]

列出所有网络

可对网络使用ls命令,会列出系统上的所有的docker网络信息。

docker network ls

删除网络

从系统中删除网络。,可以对网络使用rm命令。

docker network rm [网络名]

总结

本文,我们列出了常见的docker命令,如果你已经可以熟练的使用这些命令,则说明你docker技术已经入门。可以接下来进一步深入学习了,比如容器编排K8S集群等。

相关推荐

高性能并发队列Disruptor使用详解

基本概念Disruptor是一个高性能的异步处理框架,是一个轻量的Java消息服务JMS,能够在无锁的情况下实现队列的并发操作Disruptor使用环形数组实现了类似队列的功能,并且是一个有界队列....

Disruptor一个高性能队列_java高性能队列

Disruptor一个高性能队列前言说到队列比较熟悉的可能是ArrayBlockingQueue、LinkedBlockingQueue这两个有界队列,大多应用在线程池中使用能保证线程安全,但其安全性...

谈谈防御性编程_防御性策略

防御性编程对于程序员来说是一种良好的代码习惯,是为了保护自己的程序在不可未知的异常下,避免带来更大的破坏性崩溃,使得程序在错误发生时,依然能够云淡风轻的处理,但很多程序员入行很多年,写出的代码依然都是...

有人敲门,开水开了,电话响了,孩子哭了,你先顾谁?

前言哎呀,这种情况你肯定遇到过吧!正在家里忙活着,突然——咚咚咚有人敲门,咕噜咕噜开水开了,铃铃铃电话响了,哇哇哇孩子又哭了...我去,四件事一起来,人都懵了!你说先搞哪个?其实这跟我们写Java多线...

面试官:线程池如何按照core、max、queue的执行顺序去执行?

前言这是一个真实的面试题。前几天一个朋友在群里分享了他刚刚面试候选者时问的问题:"线程池如何按照core、max、queue的执行循序去执行?"。我们都知道线程池中代码执行顺序是:co...

深入剖析 Java 中线程池的多种实现方式

在当今高度并发的互联网软件开发领域,高效地管理和利用线程资源是提升程序性能的关键。Java作为一种广泛应用于后端开发的编程语言,为我们提供了丰富的线程池实现方式。今天,就让我们深入探讨Java中...

并发编程之《彻底搞懂Java线程》_java多线程并发解决方案详解

目录引言一、核心概念:线程是什么?...

Redis怎么实现延时消息_redis实现延时任务

一句话总结Redis可通过有序集合(ZSET)实现延时消息:将消息作为value,到期时间戳作为score存入ZSET。消费者轮询用ZRANGEBYSCORE获取到期消息,配合Lua脚本保证原子性获取...

CompletableFuture真的用对了吗?盘点它最容易被误用的5个场景

在Java并发编程中,CompletableFuture是处理异步任务的利器,但不少开发者在使用时踩过这些坑——线上服务突然雪崩、异常悄无声息消失、接口响应时间翻倍……本文结合真实案例,拆解5个最容易...

接口性能优化技巧,有点硬_接口性能瓶颈

背景我负责的系统到2021年初完成了功能上的建设,开始进入到推广阶段。随着推广的逐步深入,收到了很多好评的同时也收到了很多对性能的吐槽。刚刚收到吐槽的时候,我们的心情是这样的:...

禁止使用这5个Java类,每一个背后都有一段"血泪史"

某电商平台的支付系统突然报警:大量订单状态异常。排查日志发现,同一笔订单被重复支付了三次。事后复盘显示,罪魁祸首竟是一行看似无害的SimpleDateFormat代码。在Java开发中,这类因使用不安...

无锁队列Disruptor原理解析_无锁队列实现原理

队列比较队列...

Java并发队列与容器_java 并发队列

【前言:无论是大数据从业人员还是Java从业人员,掌握Java高并发和多线程是必备技能之一。本文主要阐述Java并发包下的阻塞队列和并发容器,其实研读过大数据相关技术如Spark、Storm等源码的,...

线程池工具及拒绝策略的使用_线程池处理策略

线程池的拒绝策略若线程池中的核心线程数被用完且阻塞队列已排满,则此时线程池的资源已耗尽,线程池将没有足够的线程资源执行新的任务。为了保证操作系统的安全,线程池将通过拒绝策略处理新添加的线程任务。...

【面试题精讲】ArrayBlockingQueue 和 LinkedBlockingQueue 区别?

有的时候博客内容会有变动,首发博客是最新的,其他博客地址可能会未同步,认准...