docker 安装与加速

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: docker 安装与加速

1.docker的发展史

GOOGLE 2003 mapreduce

2004  hadoop

google cgroup  namespace  用来做虚拟机容器隔离

2010  dotcloud   docker

2013  docker开源

2.docker网站

官网:https://www.docker.com 

中文网站:https://docker.org.cn 

3.概念

Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从 Apache2.0 协议开源。


Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。


容器是完全使用沙箱机制,相互之间不会有任何接口(类似 iPhone 的 app),更重要的是容器性能开销极低。


Docker 从 17.03 版本之后分为 CE(Community Edition: 社区版) 和 EE(Enterprise Edition: 企业版)。



Docker的应用场景:


Web 应用的自动化打包和发布。


自动化测试和持续集成、发布。


在服务型环境中部署和调整数据库或其他的后台应用。


从头编译或者扩展现有的 OpenShift 或 Cloud Foundry 平台来搭建自己的 PaaS 环境。



Docker 的优点

Docker 是一个用于开发,交付和运行应用程序的开放平台。

Docker 能够将应用程序与基础架构分开,从而可以快速交付软件。借助 Docker,可以与管理应用程序相同的方式来管理基础架构。

通过利用 Docker 的方法来快速交付,测试和部署代码,大大减少编写代码和在生产环境中运行代码之间的延迟。

1、快速,一致地交付您的应用程序

Docker 允许开发人员使用您提供的应用程序或服务的本地容器在标准化环境中工作,从而简化了开发的生命周期。


容器非常适合持续集成和持续交付(CI / CD)工作流程,请考虑以下示例方案:


您的开发人员在本地编写代码,并使用 Docker 容器与同事共享他们的工作。

他们使用 Docker 将其应用程序推送到测试环境中,并执行自动或手动测试。

当开发人员发现错误时,他们可以在开发环境中对其进行修复,然后将其重新部署到测试环境中,以进行测试和验证。

测试完成后,将修补程序推送给生产环境,就像将更新的镜像推送到生产环境一样简单。



2、响应式部署和扩展


Docker 是基于容器的平台,允许高度可移植的工作负载。Docker 容器可以在开发人员的本机上,数据中心的物理或虚拟机上,云服务上或混合环境中运行。


Docker 的可移植性和轻量级的特性,还可以使您轻松地完成动态管理的工作负担,并根据业务需求指示,实时扩展或拆除应用程序和服务。


3、在同一硬件上运行更多工作负载


Docker 轻巧快速。它为基于虚拟机管理程序的虚拟机提供了可行、经济、高效的替代方案,因此您可以利用更多的计算能力来实现业务目标。Docker 非常适合于高密度环境以及中小型部署,而您可以用更少的资源做更多的事情

CentOS Docker 安装

一.Docker 支持以下的 64 位 CentOS 版本:

CentOS 7
CentOS 8

二.安装方法

1.使用官方安装脚本自动安装

安装命令如下:

curl -fsSL https://get.docker.com | bash -s docker --mirror Aliyun


也可以使用国内 daocloud 一键安装命令:

curl -sSL https://get.daocloud.io/docker | sh

2.手动安装

(1)卸载旧版本

较旧的 Docker 版本称为 docker 或 docker-engine 。如果已安装这些程序,请卸载它们以及相关的依赖项。

$ sudo yum remove docker \
                  docker-client \
                  docker-client-latest \
                  docker-common \
                  docker-latest \
                  docker-latest-logrotate \
                  docker-logrotate \
                  docker-engine

(2)安装 Docker Engine-Community

安装所需的软件包。yum-utils 提供了 yum-config-manager ,并且 device mapper 存储驱动程序需要 device-mapper-persistent-data 和 lvm2。


yum install -y yum-utils device-mapper-persistent-data lvm2


使用官方源地址(比较慢)

$ sudo yum-config-manager \
    --add-repo \

  https://download.docker.com/linux/centos/docker-ce.repo


可以选择国内的一些源地址:


阿里云  ***

$ sudo yum-config-manager \
    --add-repo \

  http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo


清华大学源

$ sudo yum-config-manager \
    --add-repo \

  https://mirrors.tuna.tsinghua.edu.cn/docker-ce/linux/centos/docker-ce.repo


安装 Docker Engine-Community

安装最新版本的 Docker Engine-Community 和 containerd,或者转到下一步安装特定版本:


$ sudo yum install docker-ce docker-ce-cli containerd.io



默认yum安装docker最新版本,如果希望选择某个旧版本安装,请在安装时写上相应的版本号:


Docker 安装完默认未启动。并且已经创建好 docker 用户组,但该用户组下没有用户。


要安装特定版本的 Docker Engine-Community,请在存储库中列出可用版本,然后选择并安装:


1、列出并排序您存储库中可用的版本。此示例按版本号(从高到低)对结果进行排序。


$ yum list docker-ce --showduplicates | sort -r
docker-ce.x86_64  3:18.09.1-3.el7                     docker-ce-stable
docker-ce.x86_64  3:18.09.0-3.el7                     docker-ce-stable
docker-ce.x86_64  18.06.1.ce-3.el7                    docker-ce-stable
docker-ce.x86_64  18.06.0.ce-3.el7                    docker-ce-stable


2、通过其完整的软件包名称安装特定版本,该软件包名称是软件包名称(docker-ce)加上版本字符串(第二列),从第一个冒号(:)一直到第一个连字符,并用连字符(-)分隔。例如:docker-ce-19.03.10。


$ sudo yum install docker-ce-19.03.10 docker-ce-cli-19.03.10 containerd.io

启动 Docker。


$ sudo systemctl start docker

通过运行 hello-world 映像来验证是否正确安装了 Docker Engine-Community 。


$ sudo docker run hello-world


3、卸载 docker

删除安装包:

yum remove docker-ce


删除镜像、容器、配置文件等内容:

rm -rf /var/lib/docker



Docker的基本概念


| 英文名称  | 中文翻译 |
| --------- | -------- |
| image     | 镜像     |
| container | 容器     |
| repository | 仓库     |


镜像image:

   容器运行的基石,一个镜像代表一个软件,只读;


容器container:

   基于某个镜像运行一次之后生成的程序实例,也称为一个容器,可读写;


仓库repository:

   指的是放置image(镜像)的地方,默认指定的是docker官方的仓库:

   dockerhub仓库地址:https://hub.docker.com

配置Docker镜像加速器

dockerhub是在国外,我们在下载镜像的时候,速度非常慢,且经常会出现`timeout`的情况,因此,我们这里决定配置一个加速器,能够帮组我们快速的下载镜像,常用的加速器有很多,这里我们说两个。

1.阿里云镜像加速器

除了上述方法,还可以使用阿里云镜像加速器,当然,前提需要每个人都申请注册一个阿里云账号。

注册成功后,在阿里云官网上,找到`容器镜像服务`

查看docker信息:

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

2.道云加速器

道云官方下载地址:http://get.daocloud.io


curl -sSL https://get.daocloud.io/daotools/set_mirror.sh | sh -s http://f1361db2.m.daocloud.io


在/etc/目录下,创建一个docker的目录,且在此目录下生产2个文件:一个是daemon.json ,key.json。


systemctl daemon-reload
systemctl restart docker
docker info


Docker体验

docker pull nginx
docker pull mysql:5.7


( 或复制镜像文件到虚拟机:docker load -i 镜像文件)


docker images    #查看本地镜像


1、使用docker部署nginx服务。

docker run -itd --name web1 -p 8080:80 nginx
docker run -itd --name web2 -p 8081:80 nginx
docker run -itd --name web3 -p 8082:80 nginx


docker exec -it web1 /bin/bash     #交互式进入容器


2、使用docker部署MySQL服务。

docker run -d --name testsql -p 3306:3306 -e  MYSQL_ROOT_PASSWORD=123.com mysql:5.7

3. 查看镜像

docker images

4. 查看容器

docker ps -a

5. 导入本地镜像文件

docker load -i mysql5.7.tar


目录
相关文章
|
19天前
|
关系型数据库 MySQL Linux
Docker安装Mysql5.7,解决无法访问DockerHub问题
当 Docker Hub 无法访问时,可以通过配置国内镜像加速来解决应用安装失败和镜像拉取超时的问题。本文介绍了如何在 CentOS 上一键配置国内镜像加速,并成功拉取 MySQL 5.7 镜像。
166 2
Docker安装Mysql5.7,解决无法访问DockerHub问题
|
6天前
|
Prometheus 监控 Cloud Native
基于Docker安装Grafana和Prometheus
Grafana 是一款用 Go 语言开发的开源数据可视化工具,支持数据监控和统计,并具备告警功能。通过 Docker 部署 Grafana 和 Prometheus,可实现系统数据的采集、展示和告警。默认登录用户名和密码均为 admin。配置 Prometheus 数据源后,可导入主机监控模板(ID 8919)进行数据展示。
34 2
|
8天前
|
消息中间件 Linux RocketMQ
在Red Hat Enterprise Linux 9上使用Docker快速安装并部署
通过以上步骤,你可以在Red Hat Enterprise Linux 9上使用Docker快速安装并部署RocketMQ。这种方法不仅简化了安装过程,还提供了一个灵活的环境来管理和扩展消息队列系统。RocketMQ作为一款高性能的分布式消息系统,通过Docker可以实现快速部署和高效管理。
29 2
|
9天前
|
消息中间件 Linux RocketMQ
在Red Hat Enterprise Linux 9上使用Docker快速安装并部署
通过以上步骤,你可以在Red Hat Enterprise Linux 9上使用Docker快速安装并部署RocketMQ。这种方法不仅简化了安装过程,还提供了一个灵活的环境来管理和扩展消息队列系统。RocketMQ作为一款高性能的分布式消息系统,通过Docker可以实现快速部署和高效管理。
22 3
|
28天前
|
监控 虚拟化 Docker
Window系统安装Docker
这篇文章提供了在Windows系统上安装与配置Docker的详细指南,包括Docker Desktop的安装及通过Docker来运行容器化应用的步骤。
86 1
Window系统安装Docker
|
28天前
|
存储 物联网 数据安全/隐私保护
Docker安装Mosquitto
这篇文章详细介绍了如何在Docker中安装和配置Mosquitto消息代理服务,包括拉取镜像、创建容器以及配置持久化存储等步骤。
43 0
Docker安装Mosquitto
|
12天前
|
关系型数据库 MySQL Linux
基于阿里云服务器Linux系统安装Docker完整图文教程(附部署开源项目)
基于阿里云服务器Linux系统安装Docker完整图文教程(附部署开源项目)
121 2
|
20天前
|
数据可视化 数据挖掘 Docker
Docker Desktop 安装 ClickHouse 超级简单教程
Docker Desktop 安装 ClickHouse 超级简单教程
36 1
|
20天前
|
Ubuntu Linux 网络安全
Docker&Docker Compose安装(离线+在线)
Docker&Docker Compose安装(离线+在线)
138 1
|
22天前
|
NoSQL Linux Redis
Docker学习二(Centos):Docker安装并运行redis(成功运行)
这篇文章介绍了在CentOS系统上使用Docker安装并运行Redis数据库的详细步骤,包括拉取Redis镜像、创建挂载目录、下载配置文件、修改配置以及使用Docker命令运行Redis容器,并检查运行状态和使用Navicat连接Redis。
157 3