文章目录
1. Docker概述
(1)基本介绍
Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从 Apache2.0 协议开源。
Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。
容器是完全使用沙箱机制,相互之间不会有任何接口(类似 iPhone 的 app),更重要的是容器性能开销极低。
Docker 从 17.03 版本之后分为 CE(Community Edition: 社区版) 和 EE(Enterprise Edition: 企业版),我们用社区版就可以了。官网:https://docs.docker.com/
(2)应用场景
- Web 应用的自动化打包和发布。
- 自动化测试和持续集成、发布。
- 在服务型环境中部署和调整数据库或其他的后台应用。
- 从头编译或者扩展现有的 OpenShift 或 Cloud Foundry 平台来搭建自己的 PaaS 环境。
(3)Docker 的优势
Docker 是一个用于开发,交付和运行应用程序的开放平台。Docker 使您能够将应用程序与基础架构分开,从而可以快速交付软件。借助 Docker,您可以与管理应用程序相同的方式来管理基础架构。通过利用 Docker 的方法来快速交付,测试和部署代码,您可以大大减少编写代码和在生产环境中运行代码之间的延迟。
1、快速,一致地交付您的应用程序。Docker 允许开发人员使用您提供的应用程序或服务的本地容器在标准化环境中工作,从而简化了开发的生命周期。
容器非常适合持续集成和持续交付(CI / CD)工作流程,请考虑以下示例方案:
您的开发人员在本地编写代码,并使用 Docker 容器与同事共享他们的工作。
他们使用 Docker 将其应用程序推送到测试环境中,并执行自动或手动测试。
当开发人员发现错误时,他们可以在开发环境中对其进行修复,然后将其重新部署到测试环境中,以进行测试和验证。
测试完成后,将修补程序推送给生产环境,就像将更新的镜像推送到生产环境一样简单。
2、响应式部署和扩展
Docker 是基于容器的平台,允许高度可移植的工作负载。Docker 容器可以在开发人员的本机上,数据中心的物理或虚拟机上,云服务上或混合环境中运行。
Docker 的可移植性和轻量级的特性,还可以使您轻松地完成动态管理的工作负担,并根据业务需求指示,实时扩展或拆除应用程序和服务。
3、在同一硬件上运行更多工作负载
Docker 轻巧快速。它为基于虚拟机管理程序的虚拟机提供了可行、经济、高效的替代方案,因此您可以利用更多的计算能力来实现业务目标。Docker 非常适合于高密度环境以及中小型部署,而您可以用更少的资源做更多的事情。
2. 虚拟化技术和容器化技术
虚拟化技术特点:1.资源占用多 2.冗余步骤多 3.启动很慢
容器化技术:容器化技术不是模拟的一个完整的操作系统
比较Docker和虚拟机的不同:
1.传统虚拟机,虚拟出硬件,运行一个完整的操作系统,然后在这个系统上安装和运行软件。
2.Docker容器内的应用直接运行在宿主机的内容,容器是没有自己的内核的,也没有虚拟硬件。
3.每个容器都是相互隔离的,每个容器都有属于自己的文件系统,互不影响。
容器化带来的好处:
3. Docker的基本组成
Docker的基本组成图如下:
说明:
4. Docker的安装
查看系统的内核:
uname -r
系统内核版本为3.10.0
- [root@iZwz99sm8v95sckz8bd2c4Z ~]# uname -r
- 3.10.0-957.21.3.el7.x86_64
复制代码 查看系统配置
cat /etc/os-release
- [root@iZwz99sm8v95sckz8bd2c4Z ~]# 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"
复制代码 Docker的安装步骤:
(1)卸载旧的版本
- yum remove docker \
- docker-client \
- docker-client-latest \
- docker-common \
- docker-latest \
- docker-latest-logrotate \
- docker-logrotate \
- docker-engine
复制代码 (2)下载需要的安装包
(3)设置镜像的仓库
- yum-config-manager \
- --add-repo \
- https://download.docker.com/linux/centos/docker-ce.repo #国外的地址
-
- # 设置阿里云的Docker镜像仓库
- yum-config-manager \
- --add-repo \
- https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo #国外的地址
复制代码 (4)更新yum软件包索引
(5)安装docker相关的配置
docker-ce 是社区版,docker-ee 企业版
- yum install docker-ce docker-ce-cli containerd.io
复制代码 出现了completed即安装成功。
(6)启动Docker
- systemctl start docker
- # 查看当前版本号,是否启动成功
- docker version
- # 设置开机自启动
- systemctl enable docker
复制代码 结果:
下载hello-world镜像进行测试
查看下载的hello world镜像
- [root@iZwz99sm8v95sckz8bd2c4Z lib]# docker images
- REPOSITORY TAG IMAGE ID CREATED SIZE
- hello-world latest bf756fb1ae65 11 months ago 13.3kB
复制代码 5. Docker的卸载
- # 1. 卸载依赖
- yum remove docker-ce docker-ce-cli containerd.io
- # 2. 删除资源 . /var/lib/docker是docker的默认工作路径
- rm -rf /var/lib/docker
复制代码 6. 配置阿里云镜像加速
(1)进入阿里云官网,搜索容器镜像服务
(2)依次执行官方的这四条命令
- sudo mkdir -p /etc/docker
- sudo tee /etc/docker/daemon.json <<-'EOF'
- {
- "registry-mirrors": ["https://axvfsf7e.mirror.aliyuncs.com"]
- }
- EOF
- sudo systemctl daemon-reload
- sudo systemctl restart docker
复制代码 13. 常用容器部署
13.1 Nginx部署
(1)搜索并下载镜像
- docker version #查看docker的版本信息
- docker info #查看docker的系统信息,包括镜像和容器的数量
- docker 命令 --help #帮助命令(可查看可选的参数)
- docker COMMAND --help
复制代码 可以到dockerhub官网查看Nginx的详细版本信息 :https://hub.docker.com/_/nginx
(2)运行测试
- [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker images
- REPOSITORY TAG IMAGE ID CREATED SIZE
- hello-world latest bf756fb1ae65 11 months ago 13.3kB
- #解释:
- 1.REPOSITORY 镜像的仓库源
- 2.TAG 镜像的标签
- 3.IMAGE ID 镜像的id
- 4.CREATED 镜像的创建时间
- 5.SIZE 镜像的大小
- # 可选参数
- -a/--all 列出所有镜像
- -q/--quiet 只显示镜像的id
复制代码 运行结果:
- [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker search mysql
- NAME DESCRIPTION STARS OFFICIAL AUTOMATED
- mysql MySQL is a widely used, open-source relation… 10308 [OK]
- mariadb MariaDB is a community-developed fork of MyS… 3819 [OK]
- mysql/mysql-server Optimized MySQL Server Docker images. Create… 754 [OK]
- percona Percona Server is a fork of the MySQL relati… 517 [OK]
- centos/mysql-57-centos7 MySQL 5.7 SQL database server 86
- mysql/mysql-cluster Experimental MySQL Cluster Docker images. Cr… 79
- centurylink/mysql Image containing mysql. Optimized to be link… 60 [OK]
- #可选参数
- Search the Docker Hub for images
- Options:
- -f, --filter filter Filter output based on conditions provided
- --format string Pretty-print search using a Go template
- --limit int Max number of search results (default 25)
- --no-trunc Don't truncate output
-
-
- #搜索收藏数大于3000的镜像
- [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker search mysql --filter=STARS=3000
- NAME DESCRIPTION STARS OFFICIAL AUTOMATED
- mysql MySQL is a widely used, open-source relation… 10308 [OK]
- mariadb MariaDB is a community-developed fordockerk of MyS… 3819 [OK]
复制代码 端口暴露的概念:
(3)配置文件
进入容器,自定义配置文件
- [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker pull mysql
- Using default tag: latest #如果不写tag默认就是latest
- latest: Pulling from library/mysql
- 6ec7b7d162b2: Pull complete #分层下载,docker image的核心-联合文件系统
- fedd960d3481: Pull complete
- 7ab947313861: Pull complete
- 64f92f19e638: Pull complete
- 3e80b17bff96: Pull complete
- 014e976799f9: Pull complete
- 59ae84fee1b3: Pull complete
- ffe10de703ea: Pull complete
- 657af6d90c83: Pull complete
- 98bfb480322c: Pull complete
- 6aa3859c4789: Pull complete
- 1ed875d851ef: Pull complete
- Digest: sha256:78800e6d3f1b230e35275145e657b82c3fb02a27b2d8e76aac2f5e90c1c30873 #签名
- Status: Downloaded newer image for mysql:latest
- docker.io/library/mysql:latest #下载来源的真实地址 #docker pull mysql等价于docker pull docker.io/library/mysql:latest
复制代码 (4)访问测试
本地主机访问测试,curl命令发起请求,如果使用阿里云服务器需要设置安全组。
- [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker pull mysql:5.7
- 5.7: Pulling from library/mysql
- 6ec7b7d162b2: Already exists
- fedd960d3481: Already exists
- 7ab947313861: Already exists
- 64f92f19e638: Already exists
- 3e80b17bff96: Already exists
- 014e976799f9: Already exists
- 59ae84fee1b3: Already exists
- 7d1da2a18e2e: Pull complete
- 301a28b700b9: Pull complete
- 529dc8dbeaf3: Pull complete
- bc9d021dc13f: Pull complete
- Digest: sha256:c3a567d3e3ad8b05dfce401ed08f0f6bf3f3b64cc17694979d5f2e5d78e10173
- Status: Downloaded newer image for mysql:5.7
- docker.io/library/mysql:5.7
复制代码 (5)安装vim
我们使用Nginx往往需要编写配置文件,但是Nginx官方镜像没有安装vim,需要我们手动进行安装。使用以下命令进行安装:
- #1.删除指定的镜像id
- [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker rmi -f 镜像id
- #2.删除多个镜像id
- [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker rmi -f 镜像id 镜像id 镜像id
- #3.删除全部的镜像id
- [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker rmi -f $(docker images -aq)
复制代码 如果执行上述命令出现提示:
则需要先同步 /etc/apt/sources.list 和 /etc/apt/sources.list.d 中列出的源的索引,这样才能获取到最新的软件包。执行以下命令来更新:
- docker run [可选参数] image
- #参数说明
- --name="名字" 指定容器名字
- -d 后台方式运行
- -it 使用交互方式运行,进入容器查看内容
- -p 指定容器的端口
- (
- -p ip:主机端口:容器端口 配置主机端口映射到容器端口
- -p 主机端口:容器端口
- -p 容器端口
- )
- -P 随机指定端口(大写的P)
复制代码 更新完毕再安装即可。我们修改了配置文件,只要重新启动容器docker restart 容器id,改动就可以生效了。
解决vim在终端不能复制的问题:在vim 中输入 :set mouse=r。
拓展:启动项目并设置数据卷,为避免nginx因为修改配置文件导致的错误而无法启动容器,我们可以通过cp命令覆盖配置文件,但是设置数据卷会更为方便。启动Nginx容器的同时设置数据卷的命令:
- [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker run -it centos /bin/bash
- [root@bd1b8900c547 /]# ls
- bin dev etc home lib lib64 lost+found media mnt opt proc root run sbin srv sys tmp usr var
复制代码 参数说明:
- #exit 停止并退出容器(后台方式运行则仅退出)
- #Ctrl+P+Q 不停止容器退出
- [root@bd1b8900c547 /]# exit
- exit
- [root@iZwz99sm8v95sckz8bd2c4Z ~]#
复制代码 13.2 Tomcat部署
(1)下载并运行
- #docker ps
- # 列出当前正在运行的容器
- -a # 列出所有容器的运行记录
- -n=? # 显示最近创建的n个容器
- -q # 只显示容器的编号
- [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker ps
- CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
- [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker ps -a
- CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
- bca129320bb5 centos "/bin/bash" 4 minutes ago Exited (0) 3 minutes ago optimistic_shtern
- bd1b8900c547 centos "/bin/bash" 6 minutes ago Exited (0) 5 minutes ago cool_tesla
- cf6adbf1b506 bf756fb1ae65 "/hello" 5 hours ago Exited (0) 5 hours ago optimistic_darwin
复制代码 (2)进入容器
1.容器中的命令是少了
2.阿里云镜像默认下载的是最小的镜像,保证最小的运行环境。
- docker rm 容器id #删除指定的容器,不能删除正在运行的容器,强制删除使用 rm -f
- docker rm -f $(docker ps -aq) #删除所有的容器
- docker ps -a -q|xargs docker rm #删除所有的容器
复制代码 (3)访问测试
- docker start 容器id #启动容器
- docker restart 容器id #重启容器
- docker stop 容器id #停止当前运行的容器
- docker kill 容器id #强制停止当前容器
复制代码 13.3 ElasticSearch部署
添加 ’-e ES_JAVA_OPTS=“-Xms128m -Xmx512m” ‘ 配置ElasticSearch的虚拟机占用的内存大小。
docker stats 查看资源占用情况
- [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker logs --help
- Usage: docker logs [OPTIONS] CONTAINER
- Fetch the logs of a container
- Options:
- --details Show extra details provided to logs
- -f, --follow Follow log output
- --since string Show logs since timestamp (e.g. 2013-01-02T13:23:37Z) or relative (e.g. 42m for 42 minutes)
- -n, --tail string Number of lines to show from the end of the logs (default "all")
- -t, --timestamps Show timestamps
- --until string Show logs before a timestamp (e.g. 2013-01-02T13:23:37Z) or relative (e.g. 42m for 42 minutes)
- 常用:
- docker logs -tf 容器id
- docker logs --tail number 容器id #num为要显示的日志条数
- #docker容器后台运行,必须要有一个前台的进程,否则会自动停止
- #编写shell脚本循环执行,使得centos容器保持运行状态
- [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker run -d centos /bin/sh -c "while true;do echo hi;sleep 5;done"
- c703b5b1911ff84d584390263a35707b6024816e1f46542b61918a6327a570dc
- [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker ps
- CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
- c703b5b1911f centos "/bin/sh -c 'while t…" 13 seconds ago Up 10 seconds pedantic_banach
- [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker logs -tf --tail 10 c703b5b1911f
- 2020-12-27T03:34:07.255599560Z hi
- 2020-12-27T03:34:12.257641517Z hi
- 2020-12-27T03:34:17.259706294Z hi
- 2020-12-27T03:34:22.261693707Z hi
- 2020-12-27T03:34:27.262609289Z hi
- 2020-12-27T03:34:32.267862677Z hi
- 2020-12-27T03:34:37.270382873Z hi
- 2020-12-27T03:34:42.272414182Z hi
- 2020-12-27T03:34:47.274823243Z hi
- 2020-12-27T03:34:52.277419274Z hi
复制代码 13.4 MySQL部署
(1)下载并运行
- [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker top c703b5b1911f
- UID PID PPID C STIME TTY TIME CMD
- root 11156 11135 0 11:31 ? 00:00:00 /bin/sh -c while true;do echo hi;sleep 5;done
- root 11886 11156 0 11:43 ? 00:00:00 /usr/bin/coreutils --coreutils-prog-shebang=sleep /usr/bin/sleep 5
复制代码 参数说明:
- [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker inspect 容器id
复制代码 (2)进入容器查看MySQL服务
进入容器,并通过账号root查看MySQL服务能否正常连接。
- [root@iZwz99sm8v95sckz8bd2c4Z ~]# docker exec -it c703b5b1911f /bin/bash
- [root@c703b5b1911f /]# ls
- bin dev etc home lib lib64 lost+found media mnt opt proc root run sbin srv sys tmp usr var
- [root@c703b5b1911f /]# ps -ef
- UID PID PPID C STIME TTY TIME CMD
- root 1 0 0 03:31 ? 00:00:00 /bin/sh -c while true;do echo hi;sleep 5;done
- root 279 0 0 03:54 pts/0 00:00:00 /bin/bash
- root 315 1 0 03:56 ? 00:00:00 /usr/bin/coreutils --coreutils-prog-shebang=sleep /usr/bin/sleep 5
- root 316 279 0 03:56 pts/0 00:00:00 ps -ef
复制代码
Docker系列文章:
1.Docker快速入门总结笔记
2.Docker容器数据卷详解
3.Dockerfile详解与镜像发布
4.Docker网络详解与实战
笔记总结:https://www.bilibili.com/video/BV1og4y1q7M4
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |