Docker学习——③

文章目录

  • 1、Docker Registry(镜像仓库)
    • 1.1 什么是 Docker Registry?
    • 1.2 镜像仓库分类
    • 1.3 镜像仓库工作机制
    • 1.4 常用的镜像仓库
  • 2、镜像仓库命令
  • 3、镜像命令[部分]
  • 4、容器命令[部分]
    • 4.1 docker run
    • 4.2 docker ps
  • 5、CentOS 搭建一个 nginx 服务

1、Docker Registry(镜像仓库)

1.1 什么是 Docker Registry?

镜像仓库 (Docker Registry) 负责存储、管理和分发镜像,并且提供了登录认证能力,建立了仓库的索引。

镜像仓库管理多个 Repository, Repository 通过命名来区分。每个 Repository 包含一个或多个镜像,镜像通过镜像名称和标签 (Tag)来区分。

整体视图如下:

在这里插入图片描述

镜像仓库(Registry):要从哪一个镜像仓库拉取镜像,通常通过 DNS 或 IP 地址来确定一个镜像仓库如 hub.docker.com;一个 Registry 中可以存在多个Repository·Repository 可分为“顶层仓库”和“用户仓库”;·用户仓库名称格式为“用户名/仓库名”·每个仓库可以包含多个 Tag(标签),每个标签对应一个镜像

Repository:由某特定的 docker 镜像的所有迭代版本组成的镜像仓库

镜像名称(name)+标签(tag):如 nginx:latest

认证能力:提供用户注册,登录、登出能力

索引:提供镜像的索引信息,方便检索

一个容器镜像包含了两个部分,一个是元数据,其实就是由 dockerfile 构建出来的描述文件,这个描述文件会说这个容器镜像有多少层,每一层里面有什么内容,它的checksum 这些信息都会记录下来,还有最终的可执行文件在哪就是在存储数据里面,就是在一个一个的 blob 里面,真正占有空间的就是这些 blob

1.2 镜像仓库分类

按是否对外开放划分,也是研发人员常说的
公有仓库:像阿里云、dockerhub 等放到公有网络上,不用登录就可以下载镜像,
供大家访问使用

私有仓库:不对外开放,往往位于私有网络,只有公司内部人员可以使用。

按供应商和面向群体划分
sponsor(赞助) registry:第三方的 registry,供客户和 docker 社区版使用
mirror(镜像) registry:第三方的 registry,只让客户使用,例如阿里云必须注册才能使用
vendor(供应商) registry:由发布 docker 镜像的供应商提供的 registry,例如像Google 和 Redhat 提供了镜像仓库服务
private registry:通过没有防火墙和额外的安全层的私有实体提供的 registry,仅供内部使用

1.3 镜像仓库工作机制

镜像仓库使用流程

  1. 通过 docker login 登录仓库(公共仓库不需要登录)
  2. Docker pull 拉取需要的镜像
  3. 通过 dockerfile 或者 commit 等方式制作完镜像通过 docker push 上传到仓库

实际研发中镜像仓库如何使用

Docker Registry 中的镜像通常由开发人员制作,而后推送至“公共”或“私有”Registry 上保存,供其他人员使用,例如“部署”到生产环境
在这里插入图片描述

镜像仓库的拉取机制

启动容器时,docker daemon 会试图从本地获取相关的镜像;本地镜像不存在时,其将从 Registry 中下载该镜像并保存到本地

1.4 常用的镜像仓库

DockerHub
Docker Hub 是 Docker 提供的托管存储库服务,用于查找容器映像并与您的团队共享。具有以下功能:
(1)个人可以注册私有仓库,能够发布自己的镜像
(2)提供镜像检索能力
(3)提供海量官方和认证组织的镜像
(4)从 GitHub 和 Bitbucket 自动构建容器镜像并将它们推送到 Docker Hub
(5)支持 webhook(webhook 是一种基于 HTTP 的回调函数,发生指定的事件时,服
务器会自动将相关的有效负载发送到客户端的 webhook URL。 )

Docker Hub 功能浏览

镜像搜索

在这里插入图片描述

镜像tag查找

在这里插入图片描述

对应版本拉取命令

在这里插入图片描述

镜像的大小,id,cpu架构查看

在这里插入图片描述
网址:https://hub.docker.com/

国内镜像源
国内从 Docker Hub 拉取镜像有时会遇到困难,此时可以配置镜像加速器。国内很多云服务商都提供了国内镜像加速器服务,例如:

阿里云加速器(点击管理控制台 -> 登录账号(淘宝账号) -> 右侧镜像工具 -> 镜像加速器-> 复制加速器地址)
网易云加速器地址 https://hub-mirror.c.163.com
百度云加速器地址"https://mirror.baidubce.com"
可以在 /etc/docker/daemon.json 中写入如下内容(如果文件不存在请新建该文件)

{
# 注意如果最外层以及你给有了配置,不要直接覆盖,而是将下面的内容添加,然
后确保 json 的格式正确"registry-mirrors": ["https://hub-mirror.c.163.com","https://mirror.baidubce.com"]
}

添加完成后需要重新加载配置,重启 Docker:

# 加载配置
sudo systemctl daemon-reload 
# 重启 docker
sudo systemctl restart docker 
#查看 docker 状态
sudo systemctl status docker

私有仓库

私有镜像仓库则是指部署在公司或组织内部,用于自身应用 Docker 镜像存储、分发的镜像仓库。在构建公司内部使用的自动化发布系统的过程中,从安全的角度出发,应用的打包镜像一般情况下只会被存储在私有镜像仓库中,CI/CD 流程的衔接点也是通过向私有镜像仓库上传镜像和拉取镜像的操作来完成的。

常见的私有仓库工具:
Harbor:Harbor 是 VMware 公司最近开源的企业级 Docker Registry 项目, 其目标是帮助用户迅速搭建一个企业级的 Docker registry 服务。它以 Docker 公司开源的registry 为基础,提供了管理 UI, 基于角色的访问控制(Role Based Access Control),AD/LDAP 集成、以及审计日志(Audit logging) 等企业用户需求的功能,同时还原生支持中文。Harbor 的每个组件都是以 Docker 容器的形式构建的,使用 Docker Compose 来对它进行部署。

Nexus:Nexus 是 Sonatype 公司发布的一款仓库(Repository)管理软件,目前常被用来作为 Maven 私服、Docker 私服。

Docker registry:由 docker 官方提供的私服,类似于 docker hub。用于保存公司内部上传的 Docker 镜像。

2、镜像仓库命令

命令清单

命令别名功能
docker login登录仓库
docker pulldocker image pull拉取镜像
docker pushdocker image push推送镜像
docker search查找镜像
docker logout登出仓库

如果想要学习某个命令,例如学习docker login,可以添加上 --help 参数,就会有对应的命令信息

在这里插入图片描述

或者直接去官网学习:https://docs.docker.com/engine/reference/commandline/cli/

在这里插入图片描述

docker login
登陆到一个 Docker 镜像仓库,如果未指定镜像仓库地址,默认为官方仓库 Docker Hub

docker login [OPTIONS] [SERVER]

关键参数:
-u :登陆的用户名
-p :登陆的密码

可以自行去docker官网去注册,然后再进行登录

docker pull
从镜像仓库中拉取或者更新指定镜像

docker pull [OPTIONS] NAME[:TAG|@DIGEST]

别名

docker image pull

关键参数
-a :拉取所有 tagged 镜像
–disable-content-trust :忽略镜像的校验,默认开启

通过名字+tag拉取
在这里插入图片描述

通过id下载
在这里插入图片描述

在这里插入图片描述
因为前面下过,所以就没有重复下载了

docker push
将本地的镜像上传到镜像仓库,要先登陆到镜像仓库

docker push [OPTIONS] NAME[:TAG]

别名

docker image push

关键参数
-a :推送所有 tagged 镜像
–disable-content-trust :忽略镜像的校验,默认开启

需要自行注册登录,然后创建一个仓库

在这里插入图片描述

必须按照规定上传

在这里插入图片描述

需要给原来的镜像按照规定重新取名,再提交

在这里插入图片描述
再验证一下,发现已经成功 push 到 docker hub 上了

在这里插入图片描述

一次推送所有镜像
在这里插入图片描述

docker search
从 Docker Hub 查找镜像

docker search [OPTIONS] TERM

关键参数
–no-trunc :显示完整的镜像描述
-f <过滤条件>:列出收藏数不小于指定值的镜像

查找nginx的镜像
在这里插入图片描述
查找nginx镜像stars大于10的镜像

在这里插入图片描述

但是往往找镜像,都是去站点上找,因为查看方面

docker logout
登出一个 Docker 镜像仓库,如果未指定镜像仓库地址,默认为官方仓库 Docker Hub

docker logout [SERVER]

在这里插入图片描述

3、镜像命令[部分]

docker images
列出本地镜像

docker images [OPTIONS] [REPOSITORY[:TAG]]

别名

docker image ls, docker image list

关键参数
-a :列出本地所有的镜像(含中间映像层,默认情况下,过滤掉中间映像层)
–digests :显示镜像的摘要信息
-f :显示满足条件的镜像
–format :指定返回值的模板文件
–no-trunc :显示完整的镜像信息
-q :只显示镜像 ID

列出本地全部镜像,以及列出本地镜像名为nginx:1.23.4的镜像
在这里插入图片描述

也可以跟shell配合使用

在这里插入图片描述

docker image inspect
查看镜像详细信息

docker image inspect [OPTIONS] IMAGE [IMAGE...]

在这里插入图片描述

还能通过image id查看
在这里插入图片描述

docker tag
标记本地镜像,将其归入某一仓库,相当于mv命令,进行重命名

docker tag SOURCE_IMAGE[:TAG] TARGET_IMAGE[:TAG]

在这里插入图片描述

4、容器命令[部分]

4.1 docker run

docker run
创建一个新的容器并运行一个命令

docker run [OPTIONS] IMAGE [COMMAND] [ARG...]

别名

docker container run

关键参数
-d: 后台运行容器,并返回容器 ID
-i: 以交互模式运行容器,通常与 -t 同时使用
-P: 随机端口映射,容器内部端口随机映射到主机的端口
-p: 指定端口映射,格式为:主机(宿主)端口:容器端口
-t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用
–name=“nginx-lb”: 为容器指定一个名称
-h “mars”: 指定容器的 hostname
-e username=“ritchie”: 设置环境变量
- -cpuset-cpus=“0-2” or --cpuset-cpus=“0,1,2”: 绑定容器到指定 CPU 运行
-m :设置容器使用内存最大值
–network=“bridge”: 指定容器的网络连接类型
- -link <name or id>:alias: 添加链接到另一个容器,name和id是源容器的name和id,alias是源容器在link下的别名
- -volume , -v: 绑定一个卷
- -rm :shell 退出的时候自动删除容器

docker run 无参
拉取CentOS 7的镜像,并运行
在这里插入图片描述

此时发现run之后,里面退出了,这是因为centos 7默认的命令是/bin/bash,需要长时间交互,因为这里没有交互,所以直接退出了

通过以下命令查看是否创建容器

#查看正在运行的容器
docker ps#查看所有的容器
docker ps -a

在这里插入图片描述

通过以下命令从新启动容器

docker run -it centos:7 bash

在这里插入图片描述

参数 -d

因为docker run 无参是前台运行,它会把所有的日志都打印到前台,例如启动nginx服务

在这里插入图片描述

因此可以使用-d选项,使其成为后台运行

docker run -d nginx:1.23.4

在这里插入图片描述

在这里插入图片描述

参数 -p

docker run -d -p 80:80 nginx:1.23.4

在这里插入图片描述

在指定端口时,需要注意宿主机的端口没被占用,如果没有

参数 -P
使用-P,随机指定宿主机的端口
在这里插入图片描述

通过curl命令向本机的32768端口发送请求

在这里插入图片描述

成功访问到了nginx

参数 --name
如果不使用–name,那么启动容器时,docker将会随机给容器取名,根本记不住

在这里插入图片描述
在这里插入图片描述

参数 -h
指定容器名为mycentos7
在这里插入图片描述

参数 -e
指定环境变量
在这里插入图片描述

参数 --cpuset-cpus
给nginx指定CUP为0核和1核
在这里插入图片描述

这里出错的原因不是语法错误,而是我的云服务只有1核

在这里插入图片描述

从新指定为0核

在这里插入图片描述

参数 -m
给nginx指定500m内存
在这里插入图片描述在这里插入图片描述

参数 --link
在一个终端启动一个容器,名为mycentos1,再在另一个终端启动另外一个容器,名为mycentos2,并链接大mycentos1上,从而实现容器互联

终端1启动名为mycentos1的容器
在这里插入图片描述
另一个终端启动名为mycentos2的容器,并链接到mycentos1上,进行ping操作,查看是否能ping通

在这里插入图片描述

这里本质上就是把mycentos1的IP地址进行了DNS的解析,在/etc/hosts文件中就能看到

在这里插入图片描述

但是mycentos1不能ping通mycentos2,因为没对mycentos2的IP地址进行DNS解析

在这里插入图片描述

参数 --rm
不使用- -rm参数,容器停止后,还会保留
在这里插入图片描述

使用- -rm参数,容器停止后,会自动将容器删除
在这里插入图片描述

4.2 docker ps

docker ps
列出容器

docker ps [OPTIONS]

别名

docker container ls, docker container list, docker container ps

关键参数
-a :显示所有的容器,包括未运行的
-f :根据条件过滤显示的内容
- -format :指定返回值的模板文件。如 json 或者 table
-l :显示 ;的容器
-n :列出最近创建的 n 个容器
- -no-trunc :不截断输出
-q :静默模式,只显示容器编号
-s :显示总的文件大小

docker ps 无参
在这里插入图片描述

参数 -a
显示所有的容器,包括未运行的
在这里插入图片描述

参数 -f
根据名字显示容器
在这里插入图片描述

参数 -l
显示最近的一个容器
在这里插入图片描述

参数 -n
显示最近的n个容器
在这里插入图片描述

参数 -q
显示所有正在运行容器的id
在这里插入图片描述

参数 -s
将容器的大小也打印出来
在这里插入图片描述

5、CentOS 搭建一个 nginx 服务

首先查看nginx服务是否在运行,或者查看是否有nginx服务

在这里插入图片描述

可以通过杀死master进程,从而杀死整个nginx服务

在这里插入图片描述

删除nginx

在这里插入图片描述

安装nginx

# centos 配置 nginx 源
rpm -Uvh http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm

可以在这个目录下查看是否配置成功

在这里插入图片描述

构建缓存,这样下载起来速度就会变快

在这里插入图片描述

#安装nginx
yum install -y nginx

安装完成之后,查看 nginx 是否启动,如果没有启动,则可以手动启动

#查看版本
nginx -v
#手动启动
命令1:nginx
命令2:systemctl start nginx

访问nginx的首页

在这里插入图片描述

查看nginx默认的配置文件

在这里插入图片描述

在这里插入图片描述
nginx默认监听80端口,访问根的话,就会访问到 /usr/share/nginx/html/index.html

将 /usr/share/nginx/html/index.html 的内容修改一下,然后再次访问nginx的首页

在这里插入图片描述

在这里插入图片描述

安装nginx,首先得检查环境,查看机器上是否有nginx,有的话,就卸载掉,然后进行nginx的下载安装,并完成启动,如果觉得首页不好看,再调整首页的配置信息

通过docker搭建nginx服务

首先拉去合适的镜像

docker pull nginx:1.24.0

查看对应的详细信息

docker image inspect nginx:1.24.0

可以看到对外暴露的端口是80端口
在这里插入图片描述

进入容器,启动nginx,然后修改对应的页面信息

docker run -it -p 80:80 nginx:1.24.0 bash
nginx
cd /usr/share/nginx/html/
echo "fl" > index.html

在这里插入图片描述

总体来看,使用docker搭建nginx还是挺方便的

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/183106.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

selenium自动化测试入门 —— python unittest单元测试框架

unittest又名PyUnit&#xff0c; Python单元测试框架&#xff08;The Python unit testing framework&#xff09;&#xff0c;简称为PyUnit。自从 Python 2.1 版本后&#xff0c;PyUnit成为 Python标准库的一部分。 为什么需要使用unittest单元测试框架&#xff1f; 当我们写…

CC1101 一款低功耗sub- 1ghz收发器芯片 适用于无线遥控智能家居

产品描述 CC1101是一个低成本的sub- 1ghz收发器,专为极低功耗的无线应用而设计。 该电路主要用于工业、科学和医学)和SRD (Short Range Device)频带,在315,433,868和915兆赫&#xff0c;但可以轻松可编程用于其他操作频率在300-348 MHz、387-464 MHz,以及779-928 MHz频段。射…

数据抽取+dataworks的使用+ADB的应用

一&#xff0c;大数据处理之数据抽取 1&#xff0c;什么是数据抽取 在大数据领域中&#xff0c;数据抽取是指从原始数据源中提取所需的数据子集或特定数据项的过程&#xff0c; 数据抽取是数据预处理的重要步骤&#xff0c;它为后续的数据分析和建模提供了基础。 2&#xff…

暴力递归转动态规划(十三)

题目 给定3个参数&#xff0c;N&#xff0c;M&#xff0c;K 怪兽有N滴血&#xff0c;等着英雄来砍自己 英雄每一次打击&#xff0c;都会让怪兽流失[0~M]的血量 到底流失多少&#xff1f;每一次在[0~M]上等概率的获得一个值 求K次打击之后&#xff0c;英雄把怪兽砍死的概率。 暴…

数据结构:Map和Set(1)

搜索树 概念 若它的左子树不为空&#xff0c;则左子树上所有节点的值都小于根节点的值 若它的右子树不为空&#xff0c;则右子树上所有节点的值都大于根节点的值 它的左右子树也分别为二叉搜索树 这棵树的中序遍历结果是有序的 接下来我们来模拟一棵二叉搜索树&#xff0c…

AD9371 官方例程裸机SW 和 HDL配置概述(二)

AD9371 系列快速入口 AD9371ZCU102 移植到 ZCU106 &#xff1a; AD9371 官方例程构建及单音信号收发 ad9371_tx_jesd -->util_ad9371_xcvr接口映射&#xff1a; AD9371 官方例程之 tx_jesd 与 xcvr接口映射 AD9371 官方例程 时钟间的关系与生成 &#xff1a; AD9371 官方…

Electron[3] 基础配置准备和Electron入门案例

1 背景 上一篇文章已经分享了&#xff0c;如何准备Electron的基础环境了。但是博客刚发才一天&#xff0c;就发现有人问问题了。经过实践发现&#xff0c;严格按照作者的博客教程走是不会有问题的&#xff0c;其中包括安装的环境版本等都要一致。因为昨天发的博客&#xff0c;…

使用Jsoup库编写程序

Jsoup库编写的Kotlin网络爬虫程序 kotlin import org.jsoup.Jsoup import org.jsoup.nodes.Document import org.jsoup.nodes.Element import org.jsoup.select.Elements import java.net.HttpURLConnection import java.net.URL fun main(args: Array<String>) { v…

Zephyr-7B-β :类GPT的高速推理LLM

Zephyr 是一系列语言模型&#xff0c;经过训练可以充当有用的助手。 Zephyr-7B-β 是该系列中的第二个模型&#xff0c;是 Mistralai/Mistral-7B-v0.1 的微调版本&#xff0c;使用直接偏好优化 (DPO) 在公开可用的合成数据集上进行训练 。 我们发现&#xff0c;删除这些数据集的…

BIOS开发笔记 - CMOS

CMOS原来指的是一种生产电子电路的工艺,在PC上一般指的是RTC电路单元,因为早期它是由这种工艺生产出来的,所以又把RTC称作了CMOS。 RTC(Real Time Clock)即实时时钟,用于保存记录时间和日期,也可以用来做定时开机功能。RTC靠一组独立的电源给它供电,这样设计的目的就是…

Win系统强制删除文件/文件夹

Win系统强制删除文件/文件夹 前言系统磁盘清理360强制删除NPM删除 前言 Win系统的用户删除文件/文件夹时&#xff0c;可能由于权限问题导致文件无法正常删除&#xff0c;下文介绍解决方案。当常规的删除不起作用时&#xff0c;可使用如下方案进行删除&#xff0c;包含系统磁盘…

大数据商城人流数据分析与可视化 - python 大数据分析 计算机竞赛

0 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 &#x1f6a9; 基于大数据的基站数据分析与可视化 该项目较为新颖&#xff0c;适合作为竞赛课题方向&#xff0c;学长非常推荐&#xff01; &#x1f947;学长这里给一个题目综合评分(每项满分5分) 难度…

若依分离版——配置多数据源(mysql和oracle),实现一个方法操作多个数据源

目录 一、若依平台配置 二、编写oracle数据库访问的各类文件 三. 一个方法操作多个数据源 一、若依平台配置 1、在ruoyi-admin的pom.xml添加oracle依赖 <dependency> <groupId>com.oracle</groupId> <artifactId>ojdbc6</artifactId> <v…

JVM 各个参数详解

在一些规模稍大的应用中&#xff0c;Java虚拟机&#xff08;JVM&#xff09;的内存设置尤为重要&#xff0c;想在项目中取得好的效率&#xff0c;GC&#xff08;垃圾回收&#xff09;的设置是第一步。 PermGen space&#xff1a;全称是Permanent Generation space.就是说是永久…

ZZ308 物联网应用与服务赛题第B套

2023年全国职业院校技能大赛 中职组 物联网应用与服务 任 务 书 &#xff08;B卷&#xff09; 赛位号&#xff1a;______________ 竞赛须知 一、注意事项 1.检查硬件设备、电脑设备是否正常。检查竞赛所需的各项设备、软件和竞赛材料等&#xff1b; 2.竞赛任务中所使用的…

宜昌市公安局、点军区政府与中科升哲达成战略合作,共建视频图像联合创新实验室

11月3日&#xff0c;宜昌视频图像联合创新战略合作签约仪式在宜昌市公安局举行。 宜昌市副市长、市公安局党委书记、局长上官福令&#xff0c;市公安局党委副书记、副局长龚海波&#xff0c;宜昌市点军区委书记万红&#xff0c;点军区委副书记、区长黄文云&#xff0c;升哲科技…

git commit规范提交

Git每次提交代码时&#xff0c;都要写Commit Message&#xff08;提交说明&#xff09;&#xff0c;通常情况下&#xff0c;Commit Message应该清晰明了&#xff0c;说明本次提交的目的和具体操作等。然而笔者工作多年来发现&#xff0c;有些公司对Commit Message没有明确的要求…

AI:64-基于深度学习的口罩佩戴检测

🚀 本文选自专栏:AI领域专栏 从基础到实践,深入了解算法、案例和最新趋势。无论你是初学者还是经验丰富的数据科学家,通过案例和项目实践,掌握核心概念和实用技能。每篇案例都包含代码实例,详细讲解供大家学习。 📌📌📌在这个漫长的过程,中途遇到了不少问题,但是…

Luckysheet 实现excel多人在线协同编辑

前言 前些天看到Luckysheet支持协同编辑Excel&#xff0c;正符合我们协同项目的一部分&#xff0c;故而想进一步完善协同文章&#xff0c;但是遇到了一下困难&#xff0c;特此做声明哈&#xff0c;若侵权&#xff0c;请联系我删除文章&#xff01; 若侵犯版权、个人隐私&#x…