Docker(二):Docker的基本使用

1 Docker的基本使用

1.1 镜像相关操作

1、从DockerHub搜索镜像

[root@master ~]# docker search centos
# 镜像名字                          描述                                             星标      是否官方(有OK表示为官方镜像)
NAME                               DESCRIPTION                                      STARS     OFFICIAL
centos                             DEPRECATED; The official build of CentOS.        7718      [OK]
kasmweb/centos-7-desktop           CentOS 7 desktop for Kasm Workspaces             43
bitnami/centos-base-buildpack      Centos base compilation image                    0
dokken/centos-7                    CentOS 7 image for kitchen-dokken                8
dokken/centos-8                    CentOS 8 image for kitchen-dokken                6
spack/centos7                      CentOS 7 with Spack preinstalled                 2
dokken/centos-6                    EOL: CentOS 6 image for kitchen-dokken           0
spack/centos6                      CentOS 6 with Spack preinstalled                 1
ustclug/centos                     Official CentOS Image with USTC Mirror           0
dokken/centos-stream-8                                                              5
eclipse/centos_jdk8                CentOS, JDK8, Maven 3, git, curl, nmap, mc, …   5
dokken/centos-stream-9                                                              9
corpusops/centos-bare              https://github.com/corpusops/docker-images/      0
corpusops/centos                   centos corpusops baseimage                       0
spack/centos-stream                                                                 2

解释说明:

  • NAME: 镜像仓库源的名称
  • DESCRIPTION: 镜像的描述
  • OFFICIAL: 是否 docker 官方发布
  • stars: 类似 Github 里面的 star,表示点赞、喜欢的意思。
  • AUTOMATED: 自动构建。
    在选择镜像时尽量选择官方构建的镜像,其他镜像可能会存在安全隐患。

2、下载镜像

docker pull centos
# 不知道tag时,默认拉取最新版本。
# tag 相当于版本号
Using default tag: latest
latest: Pulling from library/centos
a1d0c7532777: Pull complete
Digest: sha256:a27fd8080b517143cbbbab9dfb7c8571c40d67d534bbdee55bd6c473f432b177
Status: Downloaded newer image for centos:latest
docker.io/library/centos:latest

## 解释:
library:代表官方仓库的意思

3、查看镜像

docker images
REPOSITORY   TAG       IMAGE ID       CREATED       SIZE
centos       latest    5d0da3dc9764   2 years ago   231MB

参数解释:

  • REPOSITORY:镜像名称
  • TAG:相当于软件版本
  • IMAGE ID:镜像ID,镜像的唯一标识
  • CREATED:镜像构建时间
  • SIZE:镜像大小

4、把镜像做成离线包/解压离线包

# 压缩成离线包
[root@master ~]# docker save -o centos.tar.gz centos
[root@master ~]# ls
anaconda-ks.cfg  centos.tar.gz

# 删除
[root@master ~]# docker rmi centos:latest
Untagged: centos:latest
Untagged: centos@sha256:a27fd8080b517143cbbbab9dfb7c8571c40d67d534bbdee55bd6c473f432b177
Deleted: sha256:5d0da3dc976460b72c77d94c8a1ad043720b0416bfc16c52c45d4847e53fadb6
Deleted: sha256:74ddd0ec08fa43d09f32636ba91a0a3053b02cb4627c35051aff89f853606b59
# 此时已经没有镜像了
[root@master ~]# docker images
REPOSITORY   TAG       IMAGE ID   CREATED   SIZE


# 解压离线包
[root@master ~]# docker load -i centos.tar.gz
74ddd0ec08fa: Loading layer  238.6MB/238.6MB
Loaded image: centos:latest
# 镜像就有了
[root@master ~]# docker images
REPOSITORY   TAG       IMAGE ID       CREATED       SIZE
centos       latest    5d0da3dc9764   2 years ago   231MB
[root@master ~]#

5、删除镜像

docker rmi centos:latest
docker rmi 5d0da3dc9764 
docker rmi -f 5d0da3dc9764 
# rmi 后面的参数可以是 镜像名称:TAG ,也可以是 IMAGE ID
# -f:强制执行

1.2 容器相关操作

1、以交互式方式启动并进入容器

[root@master ~]# docker run --name test -it centos:latest /bin/bash
[root@721baa423e43 /]#

# 此时查看正在运行的容器可以看懂
 [root@master ~]# docker ps
CONTAINER ID   IMAGE           COMMAND       CREATED              STATUS              PORTS     NAMES
721baa423e43   centos:latest   "/bin/bash"   About a minute ago   Up About a minute             test
[root@master ~]#
  
# 输入exit,退出容器,退出之后容器也会停止,不会再前台运行
[root@master ~]# docker ps
CONTAINER ID   IMAGE     COMMAND   CREATED   STATUS    PORTS     NAMES
[root@master ~]#


# 解释:
docker run运行并创建容器
--name 容器的名字
-i 交互式
-t 分配伪终端
centos: 启动docker需要的镜像
/bin/bash说明你的shell类型为bash,bash shell是最常用的一种shell, 是大多数Linux发行版默认的shell。 此外还有C shell等其它shell。

2、以守护进程方式启动容器

[root@master ~]# docker run --name test1 -td centos:latest /bin/bash
014b1b3ae7a351f3d20c662b06c9b5078d01aa302a3b0f4a63fd3a127b748e50
[root@master ~]#
# -d在后台运行docker

## 此时查看容器还在运行
[root@master ~]# docker ps
CONTAINER ID   IMAGE           COMMAND       CREATED          STATUS          PORTS     NAMES
014b1b3ae7a3   centos:latest   "/bin/bash"   59 seconds ago   Up 58 seconds             test1
[root@master ~]#


# 进入容器
[root@master ~]# docker exec -it test1 /bin/bash
[root@014b1b3ae7a3 /]# exit
exit
# 退出之后容器还在后台运行
[root@master ~]# docker ps
CONTAINER ID   IMAGE           COMMAND       CREATED         STATUS         PORTS     NAMES
014b1b3ae7a3   centos:latest   "/bin/bash"   2 minutes ago   Up 2 minutes             test1
[root@master ~]#

3、查看容器

# 查看正在运行的容器
[root@master ~]# docker ps
CONTAINER ID   IMAGE           COMMAND       CREATED         STATUS         PORTS     NAMES
014b1b3ae7a3   centos:latest   "/bin/bash"   4 minutes ago   Up 4 minutes             test1
[root@master ~]#
# 输出内容解释:
CONTAINER ID:容器ID
IMAGE:该容器所使用的镜像
COMMAND:容器执行的命令
CREATED:容器创建时间
STATUS:容器的状态
PORTS:暴露端口
NAMES:容器名称

# 这里介绍一个参数:--no-trunc,显示 容器ID、执行的命令等详细信息
[root@master ~]# docker ps --no-trunc
CONTAINER ID                                                       IMAGE           COMMAND       CREATED         STATUS         PORTS     NAMES
014b1b3ae7a351f3d20c662b06c9b5078d01aa302a3b0f4a63fd3a127b748e50   centos:latest   "/bin/bash"   8 minutes ago   Up 8 minutes             test1
[root@master ~]#




# 查看所有容器:包括运行和没有运行的容器
[root@master ~]# docker ps -a
CONTAINER ID   IMAGE           COMMAND       CREATED         STATUS                     PORTS     NAMES
014b1b3ae7a3   centos:latest   "/bin/bash"   5 minutes ago   Up 5 minutes                         test1
721baa423e43   centos:latest   "/bin/bash"   9 minutes ago   Exited (0) 7 minutes ago             test
[root@master ~]#

4、停止容器

[root@master ~]# docker ps
CONTAINER ID   IMAGE           COMMAND       CREATED         STATUS         PORTS     NAMES
014b1b3ae7a3   centos:latest   "/bin/bash"   9 minutes ago   Up 9 minutes             test1
[root@master ~]# docker stop  test1
test1
[root@master ~]# docker ps
CONTAINER ID   IMAGE     COMMAND   CREATED   STATUS    PORTS     NAMES
[root@master ~]#

5、启动已经停止的容器

[root@master ~]# docker start test1
test1
[root@master ~]# docker ps
CONTAINER ID   IMAGE           COMMAND       CREATED          STATUS         PORTS     NAMES
014b1b3ae7a3   centos:latest   "/bin/bash"   10 minutes ago   Up 2 seconds             test1
[root@master ~]#

6、删除容器

docker rm test
# 注意:docker rm 只能删除停止运行的容器。如果想要删除正在运行的容器则会报错:Error response from daemon: cannot remove container "/test1": container is running: stop the container before removing or force remove

# 如果想要删除正在运行的容器,则需要加 -f 选项
[root@master ~]# docker ps
CONTAINER ID   IMAGE           COMMAND       CREATED          STATUS         PORTS     NAMES
014b1b3ae7a3   centos:latest   "/bin/bash"   12 minutes ago   Up 2 minutes             test1
[root@master ~]# docker rm -f test1
test1
[root@master ~]# docker ps
CONTAINER ID   IMAGE     COMMAND   CREATED   STATUS    PORTS     NAMES
[root@master ~]#

7、进入容器

docker exec -it test /bin/bash
# 注意:有时候镜像不支持 /bin/bash 这种shell。可以换成其他的shell,比如 /bin/sh 等。
# 进入容器后退出,使用 exit 命令

[root@master ~]# docker start test
test
[root@master ~]# docker exec -it test /bin/bash
[root@721baa423e43 /]# exit
exit
[root@master ~]# docker ps
CONTAINER ID   IMAGE           COMMAND       CREATED          STATUS          PORTS     NAMES
721baa423e43   centos:latest   "/bin/bash"   20 minutes ago   Up 16 seconds             test
[root@master ~]#

8、查看容器日志

# 查看所有日志
docker logs test

# 查看最后保存的20行的内容
docker logs -n 20 test

# 实时刷新,页面总是显示20行内容
docker logs -f -n 20 test

9、查看帮助信息

# 查看docker命令的帮助信息
docker --help

# 查看某个选项的帮助信息
docker logs --help

1.3 通过 docker 部署 nginx 服务

1、启动容器

docker run -itd --name nginx -p 80 centos

### 参数解释
-p:把容器端口随机在物理机随机映射一个端口
--name:容器名称
-t:终端
-d:后台运行容器并输出容器id
-i:即使未连接也保持标准输入(STDIN)开启

2、在容器中安装nginx

# 查看
root@con02:~# docker ps |grep nginx
3e45f4fc0c3b   centos                     "/bin/bash"              4 minutes ago   Up 3 minutes   0.0.0.0:32768->80/tcp, :::32768->80/tcp                                                                                                               nginx

# 进入容器
root@con02:~# docker exec -it nginx /bin/bash
# 可以看到容器的IP为172.17.0.3
[root@3e45f4fc0c3b /]# ip addr
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
10: eth0@if11: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default
    link/ether 02:42:ac:11:00:03 brd ff:ff:ff:ff:ff:ff link-netnsid 0
    inet 172.17.0.3/16 brd 172.17.255.255 scope global eth0
       valid_lft forever preferred_lft forever


##### 使用yum 安装 nginx
# 把镜像中的yum源换成阿里源
rm -rf /etc/yum.repos.d/*
curl -o /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-vault-8.5.2111.repo
yum update
yum install wget -y
yum install nginx -y
# 大部分镜像都是最小化安装系统,所以需要安装文本编辑器 vim
yum install vim-enhanced -y

# 以下操作和直接操作nginx就是一样的了
# 创建静态页面
mkdir /var/www/html -p
cd /var/www/html/
cat > index.html << EOF
<html>
<head>
<title>nginx in docker</title>
</head>
<body>
<h1>hello,this is a test page !!!</h1>
</body>
</html>

EOF


# 修改 nginx 配置文件中的 root 路径,如下
vim /etc/nginx/nginx.conf
root /var/www/html/;

# 启动 nginx
/usr/sbin/nginx

# 安装net-tools
yum -y install net-tools
# 查看正常启动
netstat -antp
#### 以下是输出内容
Active Internet connections (servers and established)
Proto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program name
tcp        0      0 0.0.0.0:80              0.0.0.0:*               LISTEN      157/nginx: master p
tcp        0      0 172.17.0.3:40666        116.211.220.239:80      TIME_WAIT   -
tcp6       0      0 :::80    

# 退出容器
exit

在这里插入图片描述

3、查看

docker ps
######### 此时在查看 nginx 容器,端口80映射到32768端口上
CONTAINER ID   IMAGE                      COMMAND                  CREATED          STATUS          PORTS                                                                                                                                                 NAMES
3e45f4fc0c3b   centos                     "/bin/bash"              17 minutes ago   Up 17 minutes   0.0.0.0:32768->80/tcp, :::32768->80/tcp                                                                                                               nginx


netstat -atnp |grep 32768

###### 我们的虚拟机上也存在这个端口
tcp        0      0 0.0.0.0:32768           0.0.0.0:*               LISTEN      15092/docker-proxy
tcp6       0      0 :::32768                :::*                    LISTEN      15100/docker-proxy


#
curl 192.168.92.10:32768
###### 
<html>
<head>
<title>nginx in docker</title>
</head>
<body>
<h1>hello,this is a test page !!!</h1>
</body>
</html>


# 也可以直接访问容器的 ip:port
# 注意:这种方式只能在和容器相同的服务器上进行访问,如果是其他服务器访问,必须要使用 虚拟机ip:虚拟机映射端口  的方式
curl 172.17.0.3:80

web 页面也可以访问
在这里插入图片描述
流量走向:
访问物理节点 ip:port(容器在物理节点映射的端口)→ 容器 ip:port(容器里部署的服务的端口)→ 就可以访问到容器里部署的应用了

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【hector mapping参数设置】

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 hector mapping部分参数介绍调整hector_mapping中的参数ros常见问题总结 hector mapping部分参数介绍 在wiki.ros.org/hector_mapping界面找到3.1.4 Parameters章节…

使用wordcloud与jieba库制作词云图

目录 一、WordCloud库 例子&#xff1a; 结果&#xff1a; 二、Jieba库 两个基本方法 jieba.cut() jieba.cut_for_serch() 关键字提取&#xff1a; jieba.analyse包 extract_tags() 一、WordCloud库 词云图&#xff0c;以视觉效果提现关键词&#xff0c;可以过滤文本…

ios Framework版本号的问题。

自己创建的framework和普通的app的版本号设置的地方是有所有不同的。 framework 的版本号是在 TARGETS -> Build Settings -> current Project Version 这个地方设置的&#xff0c; 在创建framework的时候xcode 会自动创建一个framework.h的文件名&#xff0c;framewo…

Axure设计之多级菜单导航教程(中继器)

在数字化时代&#xff0c;优化产品设计&#xff0c;提升用户界面交互&#xff0c;是产品设计着重考虑的点。针对传统菜单导航复杂繁琐的问题&#xff0c;本设计提出了一套灵活的菜单导航方案&#xff0c;结合中继器与动态面板&#xff0c;实现一键搜索、菜单收藏、多级菜单导航…

真题总结和整理

补码的符号位在最高位 IEEE754 规格化要求 小数点前面是1,其他的认为是小数点后面为1即可 计算之前要对阶 左移和右移在寄存器中如果未说明定点数,可以通过移动小数点实现 涉及最小帧长要记得除以2 求用于外设的时钟周期数 指令两端只允许有寄存器,间接寻址要通过MA…

计组-层次化存储结构

这里主要看存储的整体结构&#xff0c;cache&#xff0c;内存 这里看存储结构是按什么样的层次来划分存储结构&#xff0c;速度由慢到快&#xff0c;容量由大到小&#xff0c;这是基于性价比的考虑&#xff0c;所以分为多级多层次&#xff0c;可以做到提高速度的同时没有增加多…

Rust整合Elasticsearch

Elasticsearch是什么 Lucene&#xff1a;Java实现的搜索引擎类库 易扩展高性能仅限Java开发不支持水平扩展 Elasticsearch&#xff1a;基于Lucene开发的分布式搜索和分析引擎 支持分布式、水平扩展提高RestfulAPI&#xff0c;可被任何语言调用 Elastic Stack是什么 ELK&a…

CoTAM——思维属性操纵链,一种利用大规模语言模型的新的高效快速学习方法

概述 近年来&#xff0c;大规模语言模型已显示出惊人的能力&#xff0c;可以从少量样本中学习。然而&#xff0c;这种能力需要昂贵的大规模模型&#xff0c;其运行成本是一大挑战。此外&#xff0c;在推理过程中&#xff0c;需要对所有测试输入的上下文&#xff08;包括演示&a…

Chromium 中chrome.topSites扩展接口定义c++

一、chrome.topSites 使用 chrome.topSites API 访问新标签页上显示的热门网站&#xff08;即最常访问的网站&#xff09;。不包括用户自定义的快捷方式。 权限 topSites 您必须声明“topSites”扩展程序清单中授予使用此 API 的权限。 {"name": "My exten…

物联网设备如何助力实现高效远程老人监护

在发达国家&#xff0c;老龄化进程加速&#xff0c;老年人常需医疗、行动辅助、安全保障及个人卫生护理&#xff0c;费用高昂。传统老人监护依赖护士或助理现场照料&#xff0c;而物联网远程监控方案能有效改进此模式。它通过运用传感器等技术&#xff0c;实现全天候低成本实时…

NPM 包开发与优化全面指南

前言 Hey, 我是 Immerse系列文章首发于【Immerse】&#xff0c;更多内容请关注该网站转载说明&#xff1a;转载请注明原文出处及版权声明&#xff01; 1. 理解 NPM 包的结构 1.1 package.json 文件&#xff1a;包的核心 package.json文件是 NPM 包的中央配置&#xff0c;定…

基于redis实现延迟队列

Redis实现延时队列 延时队列里装的主要是延时任务&#xff0c;用延时队列来维护延时任务的执行时间。 1、延时队列有哪些使用情景&#xff1f; 1、如果请求加锁没加成功 可以将这个请求扔到延时队列里&#xff0c;延后处理。 2、业务中有延时任务的需要 比如说&#xff0…

探索Python安全字符串处理的奥秘:MarkupSafe库揭秘

文章目录 探索Python安全字符串处理的奥秘&#xff1a;MarkupSafe库揭秘第一部分&#xff1a;背景介绍第二部分&#xff1a;MarkupSafe是什么&#xff1f;第三部分&#xff1a;如何安装MarkupSafe&#xff1f;第四部分&#xff1a;MarkupSafe的简单使用方法1. 使用escape函数2.…

Docker(一):Docker简介及安装

目录 1 Docker简介1.1 容器跟虚拟机的区别1、虚拟机是什么2、容器是什么3、容器和虚拟机的区别 1.2 为什么要学习容器1.3 Docker 是什么 2 Docker安装2.1 安装docker-centos71、环境初始化2、安装docker-ce3、配置docker镜像加速器 2.2 安装docker-ubuntu22.041、安装2、添加镜…

scp免密传输教程

scp免密传输教程 为了在使用 scp 命令时不需要输入密码&#xff0c;通常的做法是通过设置 SSH 公钥认证来实现。这种方法不仅避免了每次都要输入密码的麻烦&#xff0c;而且也更加安全。下面是如何设置 SSH 公钥认证的步骤&#xff1a; 1. 生成 SSH 密钥对&#xff08;如果你…

使用Postman发送POST请求的指南

作为一名软件测试工程师&#xff0c;掌握如何使用Postman发送POST请求是非常重要的技能。POST请求通常用于向服务器发送数据&#xff0c;以创建或更新资源。本文将详细介绍如何在Postman中发送POST请求&#xff0c;帮助你高效地进行接口测试。 什么是POST请求&#xff1f; PO…

<项目代码>YOLOv8 猫狗识别<目标检测>

YOLOv8是一种单阶段&#xff08;one-stage&#xff09;检测算法&#xff0c;它将目标检测问题转化为一个回归问题&#xff0c;能够在一次前向传播过程中同时完成目标的分类和定位任务。相较于两阶段检测算法&#xff08;如Faster R-CNN&#xff09;&#xff0c;YOLOv8具有更高的…

auto占位符(C++11~C++17)

文章目录 1. 定义1.1 注意事项 2. 推导规则3. 返回类型推导(C14)4. lambda表达式中使用auto类型推导5. 非类型模板形参占位符&#xff08;C17&#xff09; 1. 定义 在C11以前&#xff0c;auto关键字是用来声明自动变量的。从C11起auto被用来&#xff1a;声明变量时根据初始化表…

栈虚拟机和寄存器虚拟机,有什么不同?

本来这节内容是打算直接讲字节码指令的&#xff0c;但讲之前又必须得先讲指令集架构&#xff0c;而指令集架构又分为两种&#xff0c;一种是基于栈的&#xff0c;一种是基于寄存器的。 那不妨我们这节就单独来讲讲栈虚拟机和寄存器虚拟机&#xff0c;它们有什么不同&#xff0…

Vision - 开源视觉分割算法框架 Grounded SAM2 配置与推理 教程 (1)

欢迎关注我的CSDN&#xff1a;https://spike.blog.csdn.net/ 本文地址&#xff1a;https://spike.blog.csdn.net/article/details/143388189 免责声明&#xff1a;本文来源于个人知识与公开资料&#xff0c;仅用于学术交流&#xff0c;欢迎讨论&#xff0c;不支持转载。 Ground…