Docker最新教程 (视频地址https://www.bilibili.com/video/BV1og4y1q7M4)

本文深入探讨Docker的起源、作用及其优势,详细介绍了Docker的安装过程、常用命令、镜像管理和容器数据卷等内容。通过实战示例,如安装MySQL、构建Tomcat镜像和部署Redis集群,阐述Docker在简化开发、部署和运维中的关键角色。此外,还讨论了Docker网络原理,以及如何将SpringBoot项目打包为Docker镜像。
摘要由CSDN通过智能技术生成

Docker概述

Docker为什么出现?


一款产品:开发–上线 两套环境!应用环境,应用配置!
开发—运维。问题:我在我电脑上可以运行!版本更新,导致服务不可用!对于运维来说,考验十分大?
环境配置十分麻烦,每个机器都要部署环境(集群Redis、ES、Hadoop…)!费时费力。
发布一个项目(jar+(Redis Mysql jdk ES)),项目能不能带上环境安装打包!
之前在服务器配置一个应用环境 Redis Mysql jdk ES Hadoop,配置超级麻烦,不能够跨平台。
传统:开发jar,运维来做!
现在:开发打包部署上线,一套流程做完!

java —apk–发布(应用商店)—张三使用apk–安装即可用!
Java—jar(环境)—打包项目带上环境(镜像)—(Docker仓库:商店)----下载发布的镜像–直接运行即可!

Docker给以上问题,提出了解决方案!
在这里插入图片描述
Docker的思想来自于集装箱!
JRE–多个应用(端口冲突)—原来都是交叉的
隔离:Docker核心思想!打包装箱!每个箱子是互相隔离的
Docker通过隔离机制,可以将服务器利用到极致

本质:所有技术都是因为出现了一些问题,需要去解决,才去学习

Docker的历史


2010年,几个搞IT的年轻人,就在美国成立了一家公司dotCloud
做一些pass的云计算服务!LXC有关的容器技术!
他们将自己的技术(容器化技术)命名就是Docker!
Docker刚刚诞生的时候,没有引起行业的注意!dotCloud,就活不下去!
2013年,Docker开源!
越来越多的人发现了docker的优点!火了,Docker每个月都会更新一个版本!
2014年4月9日,Docker1.0发布!
Docker为什么这么火?十分的轻巧!
在容器技术出现之前,我们都使用虚拟机技术!
虚拟机:在windows中装一个Vmware,通过这个软件我们可以虚拟出来一台或多台电脑!笨重!
虚拟机也属于虚拟化技术,Docker容器技术,也是一种虚拟化技术!

vm,linux centos原生镜像(一个电脑) 隔离,需要开启多个虚拟机!几个G 几分钟
docker,隔离。镜像(最核心的环境 4m+jdk+mysql)十分的小巧,运行镜像就可以了!小巧! 几个M KB 秒级启动

到现在,所有开发人员都必须要学会Docker!

聊聊Docker

Docker是基于go语言开发的!开源项目

官网!https://www.docker.com/
文档!https://docs.docker.com/ 超级详细
仓库地址https://hub.docker.com/

Docker能干嘛!


之前的虚拟机技术

在这里插入图片描述
虚拟机技术缺点:
1、资源占用十分多
2、冗余步骤多
3、启动很慢!

容器化技术

容器化技术不是模拟的一个完整的操作系统
在这里插入图片描述
比较Docker和虚拟机技术的不同:

  • 传统虚拟机,虚拟出一条硬件,运行一个完整的操作系统,然后在这个系统上安装和运行软件
  • 容器内的应用是直接运行在宿主机的内容,容器是没有自己的内核的,也没有虚拟我们的硬件,所以就轻便了
  • 每个容器间互相隔离,每个容器内都有一个属于自己的文件系统,互不影响

DevOps(开发、运维)

更快速的交付和部署
传统:一堆帮助文档,安装程序
Docker:打包镜像发布测试,一键运行
更便捷的升级和扩缩容
使用了Docker之后,我们部署应用就和搭积木一样
项目打包为一个镜像,扩展 服务器A!服务器B
更简单的系统运维
在容器化之后,我们的开发,测试环境都是高度一致的
更高效的计算资源利用
1核2g的服务器!Docker是内核级别的虚拟化,可以在一个物理机上运行很多的容器实例!容器的性能可以被压榨到极致

Docker安装

Docker的基本组成


在这里插入图片描述
镜像(image)

docker镜像就好比是一个模版,可以通过这个模版来创建容器服务,tomcat镜像===》 run===》tomcat01容器(提供服务器),通过这个镜像可以创建多个容器(最终服务运行或者项目运行就是在容器中的)

容器(container)

Docker利用容器技术,独立运行一个或者一个组应用,通过镜像来创建的。
启动,停止,删除,基本命令!
目前就可以把这个容器理解为一个简易的linux系统

仓库(repository)

仓库就是存放镜像的地方!
仓库分为公有仓库和私有仓库!
Docker Hub(默认是国外的)
阿里云。。。都有容器服务器(配置镜像加速!)

安装docker

环境准备
1、需要会一点linux的基础
2、CentOS7
3、使用Xshell连接远程服务器进行操作!

环境查看

# 系统内核
[root@hadoop105 /]# uname -r
5.1.0-1.el7.elrepo.x86_64
[root@hadoop105 /]# 

# 系统版本
[root@hadoop105 /]# cat /etc/os-release 
NAME="CentOS Linux"
VERSION="7 (Core)"
ID="centos"
ID_LIKE="rhel fedora"
VERSION_ID="7"
PRETTY_NAME="CentOS Linux 7 (Core)"
ANSI_COLOR="0;31"
CPE_NAME="cpe:/o:centos:centos:7"
HOME_URL="https://www.centos.org/"
BUG_REPORT_URL="https://bugs.centos.org/"

CENTOS_MANTISBT_PROJECT="CentOS-7"
CENTOS_MANTISBT_PROJECT_VERSION="7"
REDHAT_SUPPORT_PRODUCT="centos"
REDHAT_SUPPORT_PRODUCT_VERSION="7"

安装

帮助文档:

# 1、卸载旧的版本
yum remove docker \
                  docker-client \
                  docker-client-latest \
                  docker-common \
                  docker-latest \
                  docker-latest-logrotate \
                  docker-logrotate \
                  docker-engine
# 2、需要的安装包
yum install -y yum-utils
# 3、设置镜像的仓库
yum-config-manager \
    --add-repo \
    https://download.docker.com/linux/centos/docker-ce.repo# 默认国外的

yum-config-manager \
    --add-repo \
    http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo# 推荐使用阿里云的

#更新yum软件包索引
yum makecache fast

# 4、安装docker相关的 docker-ce 社区 ee 企业版
yum install docker-ce docker-ce-cli containerd.io

# 5、启动docker
systemctl start docker

# 6、使用docker version 是否安装成功

在这里插入图片描述

# 7、hello-world
docker run hello-world

在这里插入图片描述

# 8、查看一下这个hello-world镜像
[root@hadoop105 ~]# docker images
REPOSITORY                   TAG                 IMAGE ID            CREATED             SIZE
daocloud.io/library/nginx    latest              2622e6cca7eb        4 months ago        132MB
hello-world                  latest              bf756fb1ae65        9 months ago        13.3kB
daocloud.io/library/tomcat   8.5.15-jre8         b8dfe9ade316        3 years ago         334MB
daocloud.io/library/mysql    5.7.4               aa5364eb3d85        6 years ago         252MB

了解:卸载docker

# 1、卸载依赖
yum remove docker-ce docker-ce-cli containerd.io
# 2、删除资源
rm -rf /var/lib/docker
# /var/lib/docker docker的默认工作路径

阿里云镜像加速

1、登陆阿里云找到容器服务

在这里插入图片描述
2、找到镜像加速地址
在这里插入图片描述
3、配置使用

sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
   
  "registry-mirrors": ["https://xa2xb78w.mirror.aliyuncs.com"]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker

回顾HelloWorld


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

底层原理


Docker是怎么工作的?
Docker 是一个Client -Server结构的系统,Docker的守护进程运行在主机上。通过Socket从客户端访问。
DockerServer接收到Docker-Client 的指令,就会执行这个命令。
在这里插入图片描述
Docker为什么比VM快?

1、Docker有着比虚拟机更少的抽象层
2、docker利用的是宿主机的内核,vm需要的是Guest OS
在这里插入图片描述
所以说,新建一个容器的时候,docker不需要像虚拟机一样重新加载一个操作系统,避免引导,虚拟机是加载Guest OS,分钟级别的,而docker是利用宿主机的操作系统,省略了这个复杂的过程,秒级!
在这里插入图片描述

之后学完所有命令,再回过头来看这段理论就会很清晰

Docker的常用命令


帮助命令

docker version    #显示docker的版本信息
docker info       #显示docker的系统信息,包括镜像和容器的数量
docker 命令 --help #帮助命令

帮助文档的地址:https://docs.docker.com/reference/#command-line-interfaces-clis

镜像命令


docker images查看所有本地的主机上的镜像

[root@hadoop105 /]#  docker images
REPOSITORY                   TAG                 IMAGE ID            CREATED             SIZE

hello-world                  latest              bf756fb1ae65        9 months ago        13.3kB

# 解释
REPOSITORY    镜像的仓库源
TAG           镜像的标签
IMAGE ID      镜像的id
CREATED       镜像的创建时间   
SIZE          镜像的大小
# 可选项
 -a, --all         # 列出所有镜像
 -q, --quiet       # 只显示镜像的id

docker search 搜索镜像

[root@hadoop105 /]# docker search mysql
NAME                              DESCRIPTION                                     STARS               OFFICIAL            AUTOMATED
mysql                             MySQL is a widely used, open-source relation…   10103               [OK]                
mariadb                           MariaDB is a community-developed fork of MyS…   3708                [OK]                

# 可选项,通过搜索过滤
--filter=STARS=3000 # 搜索出来的镜像就是STARS大于3000
                                
[root@hadoop105 /]# docker search mysql --filter=STARS=3000
NAME                DESCRIPTION                                     STARS               OFFICIAL            AUTOMATED
mysql               MySQL is a widely used, open-source relation…   10103               [OK]                
mariadb             MariaDB is a community-developed fork of MyS…   3708                [OK]                

[root@hadoop105 /]# docker search mysql --filter=STARS=5000
NAME                DESCRIPTION                                     STARS               OFFICIAL            AUTOMATED
mysql               MySQL is a widely used, open-source relation…   10103               [OK]      

docker pull 下载镜像

# 下载镜像 docker pull 镜像名[:tag]
[root@hadoop105 /]# docker pull mysql 
Using default tag: latest #如果不写tag,默认就是latest
latest: Pulling from library/mysql
bb79b6b2107f: Pull complete  # 分层下载,docker image的核心 联合文件下载
49e22f6fb9f7: Pull complete 
842b1255668c: Pull complete 
9f48d1f43000: Pull complete 
c693f0615bce: Pull complete 
8a621b9dbed2: Pull complete 
0807d32aef13: Pull complete 
a56aca0feb17: Pull complete 
de9d45fd0f07: Pull complete 
1d68a49161cc: Pull complete 
d16d318b774e: Pull complete 
49e112c55976: Pull complete 
Digest: sha256:8c17271df53ee3b843d6e16d46cff13f22c9c04d6982eb15a9a47bd5c9ac7e2d
Status: Downloaded newer image for mysql:latest #签名
docker.io/library/mysql:latest #真实地址

# 等价
docker pull mysql
docker pull docker.io/library/mysql:latest 
#指定版本下载
[root@hadoop105 /]# docker pull mysql:5.7
5.7: Pulling from library/mysql
bb79b6b2107f: Already exists 
49e22f6fb9f7: Already exists 
842b1255668c: Already exists 
9f48d1f43000: Already exists 
c693f0615bce: Already exists 
8a621b9dbed2: Already exists 
0807d32aef13: Already exists 
f15d42f48bd9: Pull complete 
098ceecc0c8d: Pull complete 
b6fead9737bc: Pull complete 
351d223d3d76: Pull complete 
Digest: sha256:4d2b34e99c14edb99cdd95ddad4d9aa7ea3f2c4405ff0c3509a29dc40bcb10ef
Status: Downloaded newer image for mysql:5.7
docker.io/library/mysql:5.7

在这里插入图片描述
docker rmi 删除镜像

[root@hadoop105 /]# docker rmi -f  容器id # 删除指定的容器    
[root@hadoop105 /]# docker rmi -f  容器id  容器id 容器id #删除多个容器    
[root@hadoop105 /]# docker rmi -f  $(docker images -aq) # 删除全部的容器    

容器命令


说明:有了镜像才可以创建容器,linux,下载一个centos镜像来测试

docker pull centos

新建容器并启动

docker run [可选参数] image

# 参数说明
--name="Name" 容器名字 tomcat01 tomcat02 用来区分容器
-d            后台方式运行
-it           使用交互方式运行,进入容器查看内容
-P            指定容器的端口 -p 8080:8080
      -P  ip:主机端口:容器端口
      -P 主机端口:容器端口(常用)
      -P 容器端口
       容器端口
-p            随机指定端口

# 启动并进入容器
[root@hadoop105 /]# docker run -it centos /bin/bash
[root@9b861b70c610 /]# 


[root@9b861b70c610 /]# ls #查看容器的centos,基础版本,很多命令都是不完善的
bin  dev  etc  home  lib  lib64  lost+found  media  mnt  opt  proc  root  run  sbin  srv  sys  tmp  usr  var

# 从容器中退回主机
[root@9b861b70c610 /]# exit
exit
[root@hadoop105 /]# ls
bin  boot  dev  etc  ftpfile  home  lib  lib64  media  mnt  opt  proc  root  run  sbin  srv  sys  tmp  usr  var

列出所有运行的容器

# docker ps 命令
    # 列出当前正在运行的容器
-a  # 列出当前正在运行的容器,带出历史运行的容器
-n=?# 显示最近创建的容器
-q  # 只显示容器的编号

[root@hadoop105 /]# docker ps
CONTAINER ID        IMAGE                                    COMMAND                  CREATED             STATUS                              PORTS                    NAMES
6e54f39a423b        daocloud.io/library/nginx:latest         "/docker-entrypoint.…"   3 months ago        Restarting (1) About a minute ago                            nginx
6d9a7cd4e9d0        daocloud.io/library/mysql:5.7.4          "/entrypoint.sh mysq…"   3 months ago        Up 6 hours                          0.0.0.0:3306->3306/tcp   mysql
40629088ade0        daocloud.io/library/tomcat:8.5.15-jre8   "catalina.sh run"        3 months ago        Up 6 hours                          0.0.0.0:8080->8080/tcp   tomcat
[root@hadoop105 /]# docker ps -a
CONTAINER ID        IMAGE                                    COMMAND                  CREATED             STATUS                        PORTS                    NAMES
9b861b70c610        centos                                   "/bin/bash"              4 minutes ago       Exited (0) 3 minutes ago                               hardcore_goldwasser
6b6a375b1228        hello-world                              "/hello"                 22 hours ago        Exited (0) 22 hours ago                                confident_elgamal
6e54f39a423b        daocloud.io/library/nginx:latest         "/docker-entrypoint.…"   3 months ago        Restarting (1) 1 second ago                            nginx
6d9a7cd4e9d0        daocloud.io/library/mysql:5.7.4          "/entrypoint.sh mysq…"   3 months ago        Up 6 hours                    0.0.0.0:3306->3306/tcp   mysql
40629088ade0        daocloud.io/library/tomcat:8.5.15-jre8   "catalina.sh run"        3 months ago        Up 6 hours                    0.0.0.0:8080->8080/tcp   tomcat

退出容器

exit # 直接容器停止并退出
Ctrl+P+Q # 容器不停止退出

删除容器

docker rm 容器id  # 删除指定容器,不能删除正在运行的容器,如果强制删除 rm -f
docker rm -f $(docker ps -aq) # 删除所有容器
docker ps -a -q|xargs docker rm # 删除所有容器

启动和停止容器的操作

docker start 容器id    # 启动容器
docker restart 容器id  # 重启容器
docker stop 容器id     # 停止当前正在运行的容器
docker kill 容器id     # 强制停止当前容器

常用的其他命令

后台启动容器

# 命令 docker run -d 镜像名
[root@hadoop105 ~]# docker run -d centos

# 问题docker ps,发现centos 停止了

# 常见的坑:docker 容器使用后台运行,就必须要有一个前台进程,docker发现没有应用,就会自动停止
# nginx,容器启动后,发现自己没有提供服务,就会立刻停止,就是没有程序了

查看日志

docker logs -f -t --tail 容器,没有日志

# 自己编写一段shell脚本
[root@hadoop105 /]# docker run -d centos /bin/sh -c "while true;do echo gn;sleep 1;done"

# [root@hadoop105 /]# docker ps
CONTAINER ID        IMAGE              
2108bee778a9        centos       

# 显示日志
-tf #显示日志
--tail number # 要显示日志的条数
[root@hadoop105 /]# docker logs  -tf --tail 10 2108bee778a9    

查容器中的进程信息 ps

#  命令 docker top 容器id
[root@hadoop105 /]# docker top 2108bee778a9   
UID                 PID                 PPID                C                   STIME               TTY                 TIME                CMD
root                12999               12981               0                   09:40               ?                   00:00:00            /bin/sh -c while true;do echo gn;sleep 1;done
root                23214               12999               0                   09:49               ?                   00:00:00            /usr/bin/coreutils --coreutils-prog-shebang=sleep /usr/bin/sleep 1

查看镜像元数据

# 命令  
docker inspect 容器id

#测试
[root@hadoop105 /]# docker inspect 2108bee778a9  
[
    {
   
        "Id": "2108bee778a923e00162edb5b2f9abd8efe4aac53994d6e61f04d8d89b2170c0",
        "Created": 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值