Docker的那些事(Kubernetes+docker)

简介: 采用VMware的虚拟机虚拟化三台Centos7的系统,作为我们安装Docker的环境系统; docker_4,docker_6,docker_8 1.下载相应的centos的版本:http://101.

采用VMware的虚拟机虚拟化三台Centos7的系统,作为我们安装Docker的环境系统;

docker_4,docker_6,docker_8
1.下载相应的centos的版本:http://101.96.10.26/mirror.centos.org/centos/7/isos/x86_64/CentOS-7-x86_64-DVD-1611.iso 2.安装相应的虚拟机,但是这个过程执行完之后,发现我们的虚拟机上不了网,错误提示如下;经过分析之后得出结论是,在安装虚拟机的时候没有配置网卡选项;

提示出现的问题

重新安装的过程中选择相 应的网卡即可:安装的过程选择相应的网卡即可

选择相应的网卡

1.根据官方提供的文档对在centos上安装Docker,
2.首先更新当前的软件包:

yum update 

输入这个命令更新你的yum源

跟新yum成功

3.添加相应的yum源到虚机中,之后就可以进行相应的yum源安装了;

[dockerrepo] name=Docker Repository
baseurl=https://yum.docherproject.org/repo/main/centos/7/
enabled=1 gpgcheck=1 gpgkey=https://yum.dockerproject/org/gpg

添加的yum源信息

4.安装Docker软件包:docker-engine

yum install -y docker-engine 

安装成功

启动docker守护进程:

systemctl start docker

docker守护进程

5.配置docker
打开docker远程管理端口2375,配置docker hub的国内仓库:
1.新建docker的配置文件

vi /etc/sysconfig/docker
在其内增加相应的配置项:
DOCKER_OPTS="-H unix:///var/run/docker.sock -H 0.0.0.0:2375 --registry-mirror=仓库地址"
仓库地址:可以申请daocloud的相应的docker国内地址即可;

2.启动docker守护进程的时候加载配置文件

 vi /lib/systemd/system/docker.servic
 修改相应的配置:
 ExecStart=/usr/lib/dockerd $DOCKER_OPTS
 EnvironmentFile=-/etc/sysconfig/docker

3.重启docker守护进程

systemctl stop docker
systemctl start docker
systemctl status docker.service

docker启动状态

6.安装需求:由多个docker节点构成docker的集群,采用kubernetes的容器编排技术进行管理构成的docker集群,kubernetes是google开源的容器管理系统,实现基于Docker构建容器,利用kubernetes可以很方便的管理含有多台Docker主机中的容器,将多个docker主机抽象为一个资源,以集群方式管理容器;

节点信息:
Master:docker_4->192.168.94.129 Minion:docker_6->192.168.94.130 docker_8->192.168.94.131Master节点上安装:kube-apiserver kube-scheduler kube-controller-manageretcd节点;
在Minion节点上安装:dockerkube-proxykubelet-node
kubernetes的角色构成:
1.Pod:最小操作单元,一个pod由一个或多个容器构成,同一个pod只能运行在同一个主机上;
2.Kubernetes是独立于docker存在的,安装docker之前要安装k8s软件;
3.Kubernetes存在两部分的内容,其中master节点是承担管理集群中所有容器的工作;minion是容器的栖身之所;

6.1 首先我们要构造一个由三个节点构成的简单的docker集群,实现docker跨主机网络通信;Kubernetes使用的是Flannel解决的跨主机的通信问题; 在3台机器上装上docker服务,三台机器的系统为centos系统,首先应该关闭系统上的防火墙,centos系统默认是开启firewalld服务的。 在master节点是不安装docker的,这里只是管理节点;minion是工作节点,负责安装的docker,Flannel等服务,这里要清楚的知道这个区别;(集群的结构为:1master+2minion的结构部署)
6.2在三台虚拟机上关闭相应的防火墙的工作:

systemctl stop firewalld.service
systemctl disable firewalld.service

6.3 Kubernetes的网络互联是通过flannel进行的: 安装master:

yum install -y kubernetes etcd ntp.x86_64 flannel

安装成功示意图

配置参数: 1./etc/etcd/etcd.conf:

需要修改的部分

2./etc/kubernetes/config:

需要修改的部分

3./etc/kubernetes/apiserver:

需要修改的部分

4.执行相应的开启服务操作验证安装的正确性:

1.systemctl start ntpd
 systemctl enable ntpd
 systemctl status ntpd
------------------------------------------ 2.systemctl start etcd
 systemctl enable etcd
 systemctl status etcd
------------------------------------------ 3.systemctl start kube-apiserver
 systemctl enable kube-apiserver
 systemctl status kube-apiserver
------------------------------------------ 4.systemctl start kube-scheduler
 systemctl enable kube-scheduler
 systemctl status kube-scheduler
------------------------------------------ 5.systemctl start kube-controlled-manager
 systemctl enable kube-controlled-manager
 systemctl status kube-controlled-manager

如果每一个服务都启动成功的话,那么显示的信息为Active:Active(running)的状态;

启动成功

5.在master节点修改etcd的配置:设定minion子网的范围

本文转自掘金-Docker的那些事(Kubernetes+docker)

相关实践学习
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。     相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
2月前
|
Kubernetes Docker Python
Docker 与 Kubernetes 容器化部署核心技术及企业级应用实践全方案解析
本文详解Docker与Kubernetes容器化技术,涵盖概念原理、环境搭建、镜像构建、应用部署及监控扩展,助你掌握企业级容器化方案,提升应用开发与运维效率。
592 108
|
1月前
|
弹性计算 关系型数据库 微服务
基于 Docker 与 Kubernetes(K3s)的微服务:阿里云生产环境扩容实践
在微服务架构中,如何实现“稳定扩容”与“成本可控”是企业面临的核心挑战。本文结合 Python FastAPI 微服务实战,详解如何基于阿里云基础设施,利用 Docker 封装服务、K3s 实现容器编排,构建生产级微服务架构。内容涵盖容器构建、集群部署、自动扩缩容、可观测性等关键环节,适配阿里云资源特性与服务生态,助力企业打造低成本、高可靠、易扩展的微服务解决方案。
1461 9
|
1月前
|
Kubernetes Devops Docker
Kubernetes 和 Docker Swarm:现代 DevOps 的理想容器编排工具
本指南深入解析 Kubernetes 与 Docker Swarm 两大主流容器编排工具,涵盖安装、架构、网络、监控等核心维度,助您根据团队能力与业务需求精准选型,把握云原生时代的技术主动权。
218 1
|
4月前
|
存储 Kubernetes 监控
Docker与Kubernetes集成挑战及方案
面对这些挑战,并不存在一键解决方案。如同搭建灌溉系统需要考虑多种因素,集成Docker与Kubernetes也需要深思熟虑的规划、相当的技术知识和不断的调试。只有这样,才能建立起一个稳定、健康、高效的Docker-Kubernetes生态,让你的应用像花园中的植物一样繁荣生长。
233 63
|
6月前
|
存储 Kubernetes 调度
Kubernetes、Docker和Containerd的关系解析
总的来说,Docker、Containerd和Kubernetes之间的关系可以用一个形象的比喻来描述:Docker就像是一辆装满货物的卡车,Containerd就像是卡车的引擎,而Kubernetes就像是调度中心,负责指挥卡车何时何地送货。
312 12
|
7月前
|
Kubernetes Docker 容器
Kubernetes与Docker参数对照:理解Pod中的command、args与Dockerfile中的CMD、ENTRYPOINT。
需要明确的是,理解这些都需要对Docker和Kubernetes有一定深度的理解,才能把握二者的区别和联系。虽然它们都是容器技术的二个重要组成部分,但各有其特性和适用场景,理解它们的本质和工作方式,才能更好的使用这些工具,将各自的优点整合到生产环境中,实现软件的快速开发和部署。
245 25
|
10月前
|
存储 Kubernetes 开发者
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
Docker 是一种开源的应用容器引擎,允许开发者将应用程序及其依赖打包成可移植的镜像,并在任何支持 Docker 的平台上运行。其核心概念包括镜像、容器和仓库。镜像是只读的文件系统,容器是镜像的运行实例,仓库用于存储和分发镜像。Kubernetes(k8s)则是容器集群管理系统,提供自动化部署、扩展和维护等功能,支持服务发现、负载均衡、自动伸缩等特性。两者结合使用,可以实现高效的容器化应用管理和运维。Docker 主要用于单主机上的容器管理,而 Kubernetes 则专注于跨多主机的容器编排与调度。尽管 k8s 逐渐减少了对 Docker 作为容器运行时的支持,但 Doc
412 5
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
|
10月前
|
存储 Kubernetes Docker
Kubernetes(k8s)和Docker Compose本质区别
理解它们的区别和各自的优势,有助于选择合适的工具来满足特定的项目需求。
1138 19

热门文章

最新文章