通过二进制包一键部署 Kubernetes v1.15.0 集群

简介: 通过二进制包一键部署 Kubernetes v1.15.0 集群 一 概述 Kubernetes目前有两种较为流行的安装方式:二进制和Kubeadm。二进制安装过程有利于大家理解Kubernetes各组件的原理和详细配置过程,安装包容易获取,不需要其他方式即可完成全部组件的下载。

通过二进制包一键部署 Kubernetes v1.15.0 集群

一 概述

Kubernetes目前有两种较为流行的安装方式:二进制和Kubeadm。二进制安装过程有利于大家理解Kubernetes各组件的原理和详细配置过程,安装包容易获取,不需要其他方式即可完成全部组件的下载。但是操作过程复杂而且冗长,令众多初学者望而生畏。在解决了网络问题后,Kubeadm这种安装方式非常简单快捷,唯一的缺点是不利于初学者理解Kubernetes各组件的原理与详细配置过程。两种安装方案均能用于生产环境,根据实际情况选择即可。

二 使用说明

2.1 前提条件及组件安装规划

脚执行后会删除或修改相关目录之前已经存在的文件或内容,无需手动处理。如需备份,请在脚本执行之前操作。相关操作路径可以在 kube_config.sh 文件中查看。

操作系统 Docker版本 Kubernetes版本 Etcd版本 Flannel版本 CoreDNS
CentOS Linux release 7.6.1810 Docker version 18.09.7 v1.15.0 Version: 3.3.13 v0.11.0 v.1.5.0

IP 主机名(Hostname) 角色(Role) 组件(Component)
172.31.2.10 gysl-master Master kube-apiserverkube-controller-managerkube-scheduleretcd,kubectl, docker,flannel
172.31.2.11 gysl-node1 Node kubelet,kube-proxy,docker,flannel,etcd
172.31.2.12 gysl-node2 Node kubelet,kube-proxy,docker,flannel,etcd

2.2 源码目录结构

kubernetes-all-in-one/
├── configurations
│   ├── master
│   │   ├── etcd
│   │   │   ├── ca.d
│   │   │   │   ├── ca-config.json
│   │   │   │   ├── ca.csr
│   │   │   │   ├── ca-csr.json
│   │   │   │   ├── ca-key.pem
│   │   │   │   ├── ca.pem
│   │   │   │   ├── server.csr
│   │   │   │   ├── server-csr.json
│   │   │   │   ├── server-key.pem
│   │   │   │   └── server.pem
│   │   │   └── conf.d
│   │   │       └── etcd.conf
│   │   └── kubernetes
│   │       ├── ca.d
│   │       │   ├── bootstrap.kubeconfig
│   │       │   ├── ca-config.json
│   │       │   ├── ca.csr
│   │       │   ├── ca-csr.json
│   │       │   ├── ca-key.pem
│   │       │   ├── ca.pem
│   │       │   ├── kube-proxy.csr
│   │       │   ├── kube-proxy-csr.json
│   │       │   ├── kube-proxy-key.pem
│   │       │   ├── kube-proxy.kubeconfig
│   │       │   ├── kube-proxy.pem
│   │       │   ├── server.csr
│   │       │   ├── server-csr.json
│   │       │   ├── server-key.pem
│   │       │   ├── server.pem
│   │       │   └── token.csv
│   │       └── conf.d
│   │           ├── kube-apiserver.conf
│   │           ├── kube-controller-manager.conf
│   │           └── kube-scheduler.conf
│   └── node
│       ├── docker
│       │   ├── daemon.json
│       │   └── key.json
│       ├── etcd
│       │   ├── ca.d
│       │   │   ├── ca-key.pem
│       │   │   ├── ca.pem
│       │   │   ├── server-key.pem
│       │   │   └── server.pem
│       │   └── conf.d
│       │       └── etcd.conf
│       ├── flanneld.d
│       │   └── flanneld.conf
│       └── kubernetes
│           ├── ca.d
│           │   ├── kubelet-client-2019-07-11-17-25-43.pem
│           │   ├── kubelet-client-current.pem
│           │   ├── kubelet.crt
│           │   └── kubelet.key
│           └── conf.d
│               ├── bootstrap.kubeconfig
│               ├── kubelet.conf
│               ├── kubelet.kubeconfig
│               ├── kubelet.yaml
│               ├── kube-proxy.conf
│               └── kube-proxy.kubeconfig
├── coredns_installation.sh
├── docker_installation.sh
├── etcd_cluster_installation.sh
├── flannel_installation.sh
├── kube_api_installation.sh
├── kube_config.sh
├── kube_controller_installation.sh
├── kube_installation.sh
├── kubelet_installation.sh
├── kube_proxy_installation.sh
├── kube_scheduler_installation.sh
├── modules
│   ├── coredns.yaml
│   ├── create_etcd_ca.sh
│   ├── create_etcd_config.sh
│   ├── create_flanneld_config.sh
│   ├── create_kube_api_config.sh
│   ├── create_kube_ca.sh
│   ├── create_kubeconfig.sh
│   ├── create_kube_controller_config.sh
│   ├── create_kubelet_config.sh
│   ├── create_kube_proxy_config.sh
│   ├── create_kube_scheduler_config.sh
│   ├── deploy_coredns.sh
│   ├── init.sh
│   ├── last_config.sh
│   ├── no_passwd_login.sh
│   └── unzip_pkgs.sh
├── pkgs
│   ├── cfssl-v1.2-linux-amd64.tar.gz
│   ├── etcd-v3.3.13-linux-amd64.tar.gz
│   ├── flannel-v0.11.0-linux-amd64.tar.gz
│   ├── kubernetes-v1.15.0-linux-amd64-1.tar.gz
│   ├── kubernetes-v1.15.0-linux-amd64-2.tar.gz
│   └── README.md
├── README.md
└── services
    ├── master
    │   ├── docker.service
    │   ├── etcd.service
    │   ├── kube-apiserver.service
    │   ├── kube-controller-manager.service
    │   └── kube-scheduler.service
    └── node
        ├── docker.service
        ├── etcd.service
        ├── flanneld.service
        ├── kubelet.service
        └── kube-proxy.service

22 directories, 91 files

目录中已经包含了安装过程中所需要的所有组件,服务及配置文件无需自己手动准备,安装过程中会自动配置,目录中提供的服务及配置文件仅供参考。

2.3 脚本使用说明

根据个人需求修改 kube_config 文件。如果节点个数不是2的话还需要修改对应证书配置文件及 etcd 相关服务配置文件。在执行安装脚本之前,需要在所有节点上部署 docker ,安装脚本参考 docker_installation.sh 。可以根据需求选择一键安装或者分步骤安装,kube_installation.sh 为一键安装脚本,在执行过程中也需要进行几次密码输入或者手动确认。其余所有组件均与 kube_config 在同一目录,可以根据文件名称直接区分。建议按照模块,分步骤进行安装,安装配置完成一个组件之后立马验证,及时排障。分模块安装顺序具体可以参考 kube_installation.sh 每一步均有注释。

2.4 执行方式

建议使用 bash example_installation.sh 的方式执行。一键安装及分模块安装的工作目录均为:kubernetes-all-in-one。例如: bash kube_installation.sh 。

2.5 验证安装是否成功

此步骤略,根据自身情况进行验证。

三 源码及意见反馈

3.1 源码

GitHub

3.2 意见反馈

可以通过 GitHub、微信、邮件、文章评论向本人反馈。

四 参考资料

4.1 使用二进制包在生产环境部署 Kubernetes v1.13.2 集群

4.2 二进制包20分钟快速安装部署 Kubernetes v1.14.0 集群

相关实践学习
容器服务Serverless版ACK Serverless 快速入门:在线魔方应用部署和监控
通过本实验,您将了解到容器服务Serverless版ACK Serverless 的基本产品能力,即可以实现快速部署一个在线魔方应用,并借助阿里云容器服务成熟的产品生态,实现在线应用的企业级监控,提升应用稳定性。
云原生实践公开课
课程大纲 开篇:如何学习并实践云原生技术 基础篇: 5 步上手 Kubernetes 进阶篇:生产环境下的 K8s 实践 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
1天前
|
Kubernetes Java API
Kubernetes详解(三)——Kubernetes集群组件
Kubernetes详解(三)——Kubernetes集群组件
10 1
|
6天前
|
运维 监控 Kubernetes
Kubernetes 集群的监控与维护策略
【5月更文挑战第4天】 在当今微服务架构盛行的时代,容器化技术已成为软件开发和部署的标准实践。Kubernetes 作为一个开源的容器编排平台,因其强大的功能和灵活性而广受欢迎。然而,随着 Kubernetes 集群规模的扩大,集群的监控和维护变得日益复杂。本文将探讨 Kubernetes 集群监控的重要性,分析常见的监控工具,并提出一套有效的集群维护策略,以帮助运维人员确保集群的健康运行和高可用性。
39 10
|
7天前
|
存储 运维 监控
Kubernetes 集群的持续监控与优化策略
【5月更文挑战第3天】在微服务架构和容器化部署日益普及的背景下,Kubernetes 已成为众多企业的首选容器编排平台。然而,随着集群规模的增长和业务复杂度的提升,有效的集群监控和性能优化成为确保系统稳定性和提升资源利用率的关键。本文将深入探讨针对 Kubernetes 集群的监控工具选择、监控指标的重要性解读以及基于数据驱动的性能优化实践,为运维人员提供一套系统的持续监控与优化策略。
|
10天前
|
运维 Kubernetes 监控
Kubernetes 集群的监控与维护策略
【4月更文挑战第30天】 在现代云计算环境中,容器化技术已成为应用程序部署和管理的重要手段。其中,Kubernetes 作为一个开源的容器编排平台,以其强大的功能和灵活性受到广泛欢迎。然而,随之而来的是对 Kubernetes 集群监控和维护的复杂性增加。本文将探讨针对 Kubernetes 集群的监控策略和维护技巧,旨在帮助运维人员确保集群的稳定性和高效性。通过分析常见的性能瓶颈、故障诊断方法以及自动化维护工具的应用,我们将提供一套实用的解决方案,以优化 Kubernetes 环境的性能和可靠性。
|
10天前
|
运维 Kubernetes 监控
Kubernetes集群的持续性能优化策略
【4月更文挑战第30天】 在动态且不断扩展的云计算环境中,保持应用性能的稳定性是一个持续的挑战。本文将探讨针对Kubernetes集群的持续性能优化策略,旨在为运维工程师提供一套系统化的性能调优框架。通过分析集群监控数据,我们将讨论如何诊断常见问题、实施有效的资源管理和调度策略,以及采用自动化工具来简化这一过程。
|
10天前
|
Prometheus 监控 Kubernetes
Kubernetes 集群的监控与日志管理策略
【4月更文挑战第30天】 在微服务架构日益普及的当下,容器化技术与编排工具如Kubernetes成为了运维领域的重要话题。有效的监控和日志管理对于保障系统的高可用性和故障快速定位至关重要。本文将探讨在Kubernetes环境中实施监控和日志管理的最佳实践,包括选用合适的工具、部署策略以及如何整合这些工具来提供端到端的可见性。我们将重点讨论Prometheus监控解决方案和EFK(Elasticsearch, Fluentd, Kibana)日志管理堆栈,分析其在Kubernetes集群中的应用,并给出优化建议。
|
11天前
|
Kubernetes 应用服务中间件 nginx
K8S二进制部署详解,一文教会你部署高可用K8S集群(二)
K8S二进制部署详解,一文教会你部署高可用K8S集群(二)
KUBERNETES02_集群安装逻辑、前置环境、搭建一主两从、部署dashboard访问页面(五)
KUBERNETES02_集群安装逻辑、前置环境、搭建一主两从、部署dashboard访问页面(五)
131 0
KUBERNETES02_集群安装逻辑、前置环境、搭建一主两从、部署dashboard访问页面(五)
|
Kubernetes 容器
KUBERNETES02_集群安装逻辑、前置环境、搭建一主两从、部署dashboard访问页面(三)
KUBERNETES02_集群安装逻辑、前置环境、搭建一主两从、部署dashboard访问页面(三)
148 0
KUBERNETES02_集群安装逻辑、前置环境、搭建一主两从、部署dashboard访问页面(三)
|
负载均衡 Perl
KUBERNETES02_集群安装逻辑、前置环境、搭建一主两从、部署dashboard访问页面(二)
KUBERNETES02_集群安装逻辑、前置环境、搭建一主两从、部署dashboard访问页面(二)
143 0
KUBERNETES02_集群安装逻辑、前置环境、搭建一主两从、部署dashboard访问页面(二)