看了这篇Docker指令详解,网友直呼:我收藏了你呢?

2024-04-11 03:58

本文主要是介绍看了这篇Docker指令详解,网友直呼:我收藏了你呢?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Docker的使用

    • 为什么要使用Docker?
    • Docker的安装
      • Ubuntu
    • Docker常用指令
    • Docker的使用入门
    • 实例:配置 tomcat环境

为什么要使用Docker?

  • 可移植性部署。当我们在不同的环境工作时,需要为用到的工具配置环境,步骤较为繁杂,使用Docker可以一键让当前环境变为我们想要的环境,并根据业务需求指示,实时扩展或拆除应用程序和服务。
  • 轻量级。我们使用虚拟机需要真的去部署一个OS,需要占用大量资源,而Docker的镜像往往只有几十M。Docker 非常适合于高密度环境以及中小型部署,而您可以用更少的资源做更多的事情。
  • 更快速。为基于虚拟机管理程序的虚拟机提供了可行、经济、高效的替代方案,因此您可以利用更多的计算能力来实现业务目标。

本文主要讲docker的指令使用,不涉及太多原理。

Docker的安装

Ubuntu

卸载旧版本

sudo apt update
sudo apt-get remove docker docker-engine docker.io containerd runc 
sudo apt autoremove

2.安装需要的包

sudo apt update
sudo apt install apt-transport-https ca-certificates software-properties-common curl

3.添加 GPG 密钥,并添加 Docker-ce 软件源,这里还是以中国科技大学的 Docker-ce 源为例

curl -fsSL https://mirrors.ustc.edu.cn/docker-ce/linux/ubuntu/gpg | sudo apt-key add -
sudo add-apt-repository "deb [arch=amd64] https://mirrors.ustc.edu.cn/docker-ce/linux/ubuntu \
$(lsb_release -cs) stable"

4.添加成功后更新软件包缓存

sudo apt update

5.安装 Docker-ce

sudo apt install docker-ce

6.设置开机自启动并启动 Docker-ce(安装成功后默认已设置并启动,可忽略)

sudo systemctl enable docker
sudo systemctl start docker

7.测试运行

sudo docker run hello-world


出现这个界面即安装成功。
如果PULL速度太慢或者time out,请在 /etc/docker/daemon.json 中写入如下内容(如果文件不存在请新建该文件):

{"registry-mirrors":["https://reg-mirror.qiniu.com/"]}

之后重新启动服务:

$ sudo systemctl daemon-reload
$ sudo systemctl restart docker

Docker常用指令

为了方便以下容器ID都用ubuntu-test表示,以下面这个例子,ubuntu-test和3a9f4163787c都可以表示容器的id

在这里插入图片描述

常规指令介绍格式TIP
stop停止一个运行中的容器docker stop [容器id]docker stop ubuntu-test
start开始一个暂停的容器docker start [容器id]
pull拉取一个镜像docker pull [镜像]docker pull training/webapp
push把镜像推送到远程docker hub上docker push [username]/[镜像]
restart重启容器docker restart [容器id]
attach对于参数-d的后台容器,进入后台容器(退出时容器会停止)docker attach [容器id]
exec对于参数-d的后台容器,进入后台容器(退出时容器不停止)docker exec [run参数] [容器id] [命令]docker exec -it ubuntu-test /bin/bash
export导出容器docker export [容器id]>[自定义名称.tar]docker export ubuntu-test > ubuntu.tar
import导入镜像cat [目录/文件.tar]docker import - [自定义镜像名称]:tag
rm删除一个停止状态的容器(docker container prune删除所有暂停状态的容器)docker rm [容器id]
rmi删除镜像
port查看端口信息docker port [容器id]
top查看容器进程信息docker top [容器id]
inspect查看容器信息docker inspect [容器id]
images列出本地镜像docker images输出说明:●REPOSITORY:表示镜像的仓库源●TAG:镜像的标签●IMAGE ID:镜像ID●CREATED:镜像创建时间●SIZE:镜像大小
search搜索镜像docker serarch [需要的镜像关键字]输出说明:●NAME: 镜像仓库源的名称DESCRIPTION: 镜像的描述 ●OFFICIAL: 是否 docker 官方发布●stars: 类似 Github 里面的star,表示点赞、喜欢的意思。●AUTOMATED: 自动构建。
login登录远程docker hub
logout退出docker hub
tag为镜像添加一个新标签docker tag [镜像id] [镜像名称:标签]
RUN介绍TIP
功能在容器内运行指令
输入格式docker run [run参数] [指定镜像名称:tag] [命令]docker run -it ubuntu15:10 /bin/echo "helloworld!"
参数默认:-t: 在新容器内指定一个伪终端或终端-i: 允许你对容器内的标准输入 (STDIN) 进行交互。-d:后台运行-P:将容器端口随机映射到本地-p:将容器端口映射到指定的本地端口(也可以指定网络地址)● -p 127.0.0.1:666:5000 将容器的5000端口映射到127.0.0.1的666(默认tcp协议,如果要使用udp则在端口后面加/udp) ●–name xxx 以xxx命名容器.
# PS介绍TIP
功能查看容器
输入格式docker ps 参数
参数** 默认 **: 查看正在运行的容器 -a : 查看历史运行容器 -l: 查看最后运行的容器
输出** CONTAINER ID: ** 容器 ID。** IMAGE: ** 使用的镜像。** COMMAND: ** 启动容器时运行的命令。** CREATED: ** 容器的创建时间。** STATUS: ** 容器状态。** PORTS: ** 容器的端口信息和使用的连接类型(tcp\udp)。** NAMES:** 自动分配的容器名称。STATUS状态有7种:●created(已创建)●restarting(重启中)●running(运行中)●removing(迁移中)●paused(暂停)●exited(停止)●dead(死亡)
#logs介绍TIP
功能查看容器内的标准输出
格式docker logs [容器id]docker logs ubuntu-test
参数-f:docker logs 像使用 tail -f 一样来输出容器内部的标准输出。docker logs -f ubuntu-test
# commit介绍TIP
功能更新镜像
格式docker commit [commit参数] [容器id] [自定义镜像名]docker commit -m="update" -a="TIOOO" ubuntu-test my_ubuntu
参数-m: 提交的描述信息 -a: 指定镜像作者容器 ID指定要创建的目标镜像名
输出
# network介绍格式TIP
creat创建一个新的docker网络docker network create [参数] [自定义名称]-d :参数指定 Docker 网络类型,有 bridge、overlay。
ls查看docker网络docker newwordk ls

构建镜像

Dockerfile

Dockerfile介绍格式TIP
dockerfile用来构建镜像的文件。在目录下新建文件tips1:每一次执行命令,都会在docker上新建一层,尽可能减少层数,可使用 && 连接命令tips2:Dockerfile文件目录下,不要放多余无用文件
FROM指定镜像FROM nginx在指定镜像的基础上运行
RUN执行命令,在docker build时执行shell:RUN <命令行命令> #与终端shell命令一样exec:RUNR ["可执行文件","参数1","参数2"]RUN ["./test.php", "dev", "offline"] 等价于 RUN ./test.php dev offline
COPY复制指令,从上下文目录中复制文件或者目录到容器里指定路径。COPY[–chown=:]<源路径1>…<目标路径>[–chown=:]:可选参数,用户改变复制到容器内文件的拥有者和属组。<源路径>:源文件或者源目录,这里可以是通配符表达式<目标路径>:容器内的指定路径,该路径不用事先建好,路径不存在的话,会自动创建。
ADD与COPY一样,会自动解压gzip,bzip2,xz文件不推荐使用
CMD类似于 RUN 指令,用于运行程序,在docker run时执行CMD <shell 命令>CMD ["<可执行文件或命令>","","",…]CMD ["","",…]# 该写法是为 ENTRYPOINT 指令指定的程序提供默认参数如果 Dockerfile 中如果存在多个 CMD 指令,仅最后一个生效。CMD 指令指定的程序可被 docker run 命令行参数中指定要运行的程序所覆盖。
ENTRYPOINT类似于 CMD 指令,但其不会被 docker run 的命令行参数指定的指令所覆盖,而且这些命令行参数会被当作参数送给 ENTRYPOINT 指令指定的程序。ENTRYPOINT ["","","",…]●假设已通过 Dockerfile 构建了 nginx:test 镜像:FROM nginxENTRYPOINT [&quot;nginx&quot;,&quot;-c&quot;]# 定参CMD [&quot;/etc/nginx/nginx.conf&quot;]# 变参 ●1、不传参运行$ docker run nginx:test容器内会默认运行以下命令,启动主进程。nginx -c /etc/nginx/nginx.conf ●2、传参运行$ docker run nginx:test -c /etc/nginx/new.conf容器内会默认运行以下命令,启动主进程(/etc/nginx/new.conf:假设容器内已有此文件)nginx -c /etc/nginx/new.conf
ENV设置环境变量ENV ENV ==…可通过$key 引用变量
ARG与ENV功能一样,作用域只在docker build中ARG <参数名>[=<默认值>]构建命令 docker build 中可以用 --build-arg <参数名>=<值> 来覆盖。
VOLUME定义匿名数据卷。在启动容器时忘记挂载数据卷,会自动挂载到匿名卷。VOLUME ["<路径1>","<路径2>"…]VOLUME <路径>●避免重要的数据,因容器重启而丢失,这是非常致命的。●避免容器不断变大。在启动容器 docker run 的时候,我们可以通过 -v 参数修改挂载点。
EXPOSE声明端口。EXPOSE <端口1>[<端口2>…]●帮助镜像使用者理解这个镜像服务的守护端口,以方便配置映射。●在运行时使用随机端口映射时,也就是 docker run -P 时,会自动随机映射 EXPOSE 的端口。
WORKDIR指定工作目录。WORKDIR <工作目录路径>●用 WORKDIR 指定的工作目录,会在构建镜像的每一层中都存在。(WORKDIR 指定的工作目录,必须是提前创建好的)。●docker build 构建镜像过程中的,每一个 RUN 命令都是新建的一层。只有通过 WORKDIR 创建的目录才会一直存在。
USER用于指定执行后续命令的用户和用户组USER <用户名>[:<用户组>]切换后续命令执行的用户(用户和用户组必须提前已经存在)
HEALTHCHECK用于指定某个程序或者指令来监控 docker 容器服务的运行状态●HEALTHCHECK [选项] CMD <命令>:设置检查容器健康状况的命令 ●HEALTHCHECK NONE:如果基础镜像有健康检查指令,使用这行可以屏蔽掉其健康检查指令 ●HEALTHCHECK [选项] CMD <命令>:这边CMD 后面跟随的命令使用,可以参考CMD 的用法。
ONBUILD用于延迟构建命令的执行ONBUILD <其它指令>●Dockerfile 里用 ONBUILD 指定的命令,在本次构建镜像的过程中不会执行(假设镜像为 test-build)。●当有新的 Dockerfile 使用了之前构建的镜像 FROM test-build ,这是执行新镜像的 Dockerfile 构建时候,会执行 test-build 的 Dockerfile 里的 ONBUILD 指定的命令。
# build介绍TIP
功能创建一个新的镜像
格式docker bulid [build参数] [Dockerfile文件路径]docker build ~/docker/Dockerfile
参数-t 设置镜像名称
输出

Docker的使用入门

1.搜索、拉取镜像
docker search
docker pull
2.创建、运行容器
docker run
3.维护容器
docker ps
docker start、stop、restart
docker rm
4.维护镜像
docker images
docker commit(更新镜像)
docker push (上传镜像)
docker export (导出容器)
docker import (导入镜像)

实例:配置 tomcat环境

#搜索tomcat镜像源

docker search tomcat
在这里插入图片描述

*# 拉取 tomcat 镜像源

docker pull tomcat
在这里插入图片描述

#查看 tomcat 镜像
docker images|grep tomcat
在这里插入图片描述

#建立一个工作目录
cd ~/docker && mkdir test

#在 tomcat 镜像上运行一个容器 -d :后台运行 --name :指定名称为 tomcat_test -p : docker**** 的 8080 映射到本地的 8088 端口 -v :将主机当前目录的 test挂载到容器的/test

#docker run -d --name tomcat_test -p 8088:8080 -v $PWD/test:/usr/local/tomcat/webapps/test tomcat**

#查看tomcat 运行状态
docker ps
在这里插入图片描述

echo "hello world!">./test/index.html

# 打开127.0.0.1:8088/test即可看到 hello world!

在这里插入图片描述

查找镜像
Docker Hub 网址为: https://hub.docker.com/
注册时人机验证可能需要科学上网。

参考资料:
https://www.runoob.com/docker/docker-tutorial.html

这篇关于看了这篇Docker指令详解,网友直呼:我收藏了你呢?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/893018

相关文章

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

OpenHarmony鸿蒙开发( Beta5.0)无感配网详解

1、简介 无感配网是指在设备联网过程中无需输入热点相关账号信息,即可快速实现设备配网,是一种兼顾高效性、可靠性和安全性的配网方式。 2、配网原理 2.1 通信原理 手机和智能设备之间的信息传递,利用特有的NAN协议实现。利用手机和智能设备之间的WiFi 感知订阅、发布能力,实现了数字管家应用和设备之间的发现。在完成设备间的认证和响应后,即可发送相关配网数据。同时还支持与常规Sof

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

K8S(Kubernetes)开源的容器编排平台安装步骤详解

K8S(Kubernetes)是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。以下是K8S容器编排平台的安装步骤、使用方式及特点的概述: 安装步骤: 安装Docker:K8S需要基于Docker来运行容器化应用程序。首先要在所有节点上安装Docker引擎。 安装Kubernetes Master:在集群中选择一台主机作为Master节点,安装K8S的控制平面组件,如AP

嵌入式Openharmony系统构建与启动详解

大家好,今天主要给大家分享一下,如何构建Openharmony子系统以及系统的启动过程分解。 第一:OpenHarmony系统构建      首先熟悉一下,构建系统是一种自动化处理工具的集合,通过将源代码文件进行一系列处理,最终生成和用户可以使用的目标文件。这里的目标文件包括静态链接库文件、动态链接库文件、可执行文件、脚本文件、配置文件等。      我们在编写hellowor

LabVIEW FIFO详解

在LabVIEW的FPGA开发中,FIFO(先入先出队列)是常用的数据传输机制。通过配置FIFO的属性,工程师可以在FPGA和主机之间,或不同FPGA VIs之间进行高效的数据传输。根据具体需求,FIFO有多种类型与实现方式,包括目标范围内FIFO(Target-Scoped)、DMA FIFO以及点对点流(Peer-to-Peer)。 FIFO类型 **目标范围FIFO(Target-Sc

019、JOptionPane类的常用静态方法详解

目录 JOptionPane类的常用静态方法详解 1. showInputDialog()方法 1.1基本用法 1.2带有默认值的输入框 1.3带有选项的输入对话框 1.4自定义图标的输入对话框 2. showConfirmDialog()方法 2.1基本用法 2.2自定义按钮和图标 2.3带有自定义组件的确认对话框 3. showMessageDialog()方法 3.1

工作常用指令与快捷键

Git提交代码 git fetch  git add .  git commit -m “desc”  git pull  git push Git查看当前分支 git symbolic-ref --short -q HEAD Git创建新的分支并切换 git checkout -b XXXXXXXXXXXXXX git push origin XXXXXXXXXXXXXX