安装KubeSphere
1. KubeSphere 是什么
1.1. 官方解释
KubeSphere是一个分布式操作系统,提供以Kubernetes为核心的云原生堆栈,旨在成为第三方应用程序的即插即用架构,以促进其生态系统的发展。 KubeSphere还是一个多租户企业级容器平台,具有全栈自动IT操作和简化的DevOps工作流程。它提供了开发人员友好的向导Web UI,可帮助企业构建更健壮且功能丰富的平台,其中包括企业Kubernetes战略所需的最常用功能,例如Kubernetes资源管理,DevOps(CI / CD),应用程序生命周期管理、监控、日志记录、服务网格、多租户、报警和通知,存储和网络、自动定量、访问控制、GPU的支持等,以及多集群管理、网络策略、注册表管理,更多即将发布的安全增强特性。
KubeSphere提供了整合的视图,同时围绕Kubernetes集成了广泛的生态系统工具,并提供一致的用户体验以降低复杂性,并开发了上游Kubernetes中尚不可用的新功能,以减轻Kubernetes的痛苦之处,包括存储,网络 ,安全性和易用性。 KubeSphere不仅允许开发人员和DevOps团队在统一控制台中使用他们喜欢的工具,而且最重要的是,由于这些功能是可插拔和可选的,因此它们与平台松散地结合在一起。
Kubernetes平台,专为DevOps团队量身定制
KubeSphere,以应用为中心的容器平台
极简、易用、灵活、高效
关于KubeSphere,最好最全面最通俗易懂的一篇文章是《一文说清 KubeSphere 容器平台的价值》
https://kubesphere.io/zh-CN/blog/kubesphere-values/
1.2. 个人理解
KubeSphere,这是国内唯一一个开源的Kubernetes(k8s)发行版,它的开源不涉及任何商业意图,它不属于青云而属于社区,它极大地降低了使用Kubernetes的门槛,它的出现将加速中国企业向云原生迈进的步伐。
“发行版”的说法常用于Linux操作系统。比如,虽有Linux内核,而Ubuntu、CentOS等等叫做Linux发行版,对应的,Kubernetes就相当于内核,KubeSphere就是Kubernetes的发行版,正常人类是很难使用Linux内核和Kubenetes的,为了让大家用起来,要基于Linux内核和Kubernetes做很多周边配套,Linux和Kubenetes就好像一台光秃秃的汽车发动机,为了把它当车开,你起码得有车架子、轮胎、方向盘、刹车、……等等。
所以,开源KubeSphere的青云就像一个汽车厂,负责KubeSphere牌汽车各个组件的组装搭配,不过,这个汽车不需要花钱就能获取到,这就是青云开源KubeSphere的实质。它的意义在于加快了大家使用k8s发动机的进程,让大家都能开上KubeSphere牌汽车。
云原生能帮助企业做数字化转型,帮助企业用数字化转型获取竞争力。而KubeSphere可以让企业更快地上原生,开上汽车。
以上摘抄自https://tech.ifeng.com/c/7u6tUXwXbJU
我觉得,读完以后,醍醐灌顶,茅塞顿开
我们使用Linux的各种发行版(比如:CentOS、Ubuntu等)与Linux内核交互,极大地降低了使用Linux的门槛,而且像Ubuntu还提供了特别漂亮的桌面版,图像界面式的操作使用起来更方便。
我们当然可以使用CMD命令行窗口同Windows系统交互,所有在图形界面上完成的操作都可以通过命令行完成,但是这种操作方式的门槛极高,不利于微软推行Windows桌面操作系统。
同样的,Kubenetes就相当于内核,而KubeSphere就相当于是Kubernetes的发行版。KubeSphere提供极简体验,向导式UI,极大的降低了使用Kubenetes的门槛。
记不住Kubenetes命令不要紧,不会写Dockerfile也没关系,使用KubeSphere图像界面以后一起都变得简单了,而且它是以应用为中心的,极大地解放了运维和开发人员的生产力。
KubeSphere就是Java编程界的Spring。想想看,用了Spring以后你不需要关心各种数据库的连接,各种各样的组件都帮你集成好了,拿来就用。KubeSphere也是一样,开箱即用。
2. 安装
就一条命令,挺简单的,但是我装了两天两夜。期间,虚拟机装了好几遍,KubeSphere也重装了很多遍,一遍就是几个小时……
话不多说,官方文档(中/英文版)都写的非常清楚,开始安装
由于资源限制,我只能在虚拟机里装,这里选择All-in-One模式
首先,一定一定要看清楚系统要求,之前用CentOS没装成功,试了很多版本,最后老老实实用Ubuntu18.04
https://ubuntu.com/download/alternative-downloads
下载安装包
- curl -L https://kubesphere.io/download/stable/v2.1.1 > installer.tar.gz \
- && tar -zxf installer.tar.gz && cd kubesphere-all-v2.1.1/scripts
在安装前一定一定要记得配置镜像加速器
例如阿里云容器镜像加速器服务 https://cr.console.aliyun.com/cn-hangzhou/instances/mirrors
- docker_registry_mirrors:
- - https://docker.mirrors.ustc.edu.cn
- - https://registry.docker-cn.com
- - https://mirror.aliyuncs.com
~/kubesphere-all-v2.1.1/conf/common.yaml
执行./install.sh就等着吧(如果要重新安装建议先执行./uninstall.sh)
安装了两天,终于看到期待已久的画面了:
各种验证
https://kubesphere.io/docs/installation/verify-components/
https://kubesphere.io/docs/zh-CN/installation/verify-components/
安装完以后,一看资源占用情况,吓一跳,果然只适合企业用户
3. 遇到的问题
https://kubesphere.io/docs/troubleshooting/installation/
1、container in pod is not available
- Error from server (BadRequest): container "installer" in pod "ks-installer-7d9fb945c7-6tnl9" is not available
检查安装日志 ~/kubesphere-all-v2.1.1/logs
有一个非常好用的命令是 journalctl -xefu kubelet
2、如何重启
3、如何重启Kubernetes集群
我一直有个疑问,如果物理机或者Kubernetes的宿主机宕机或重启以后Kubernetes集群会自动重启吗?如果挂的是master所在的机器,很显然是不会的, 但如果是非master的节点的话不知道没试过。所以,Kubernetes集群的高可用就非常重要了。
https://kubernetes.io/docs/setup/production-environment/tools/kubeadm/high-availability/
https://kubernetes.io/docs/concepts/workloads/controllers/replicationcontroller/
ReplicationController确保在任何时候都运行指定数量的pod副本。换句话说,ReplicationController确保一个pod或一组同类的pod总是处于可用状态。
我忽略了Kubernetes有很强的自愈能力
自愈(自我修复):重新启动失败的容器,在节点死亡时替换和重新调度容器,杀死那些不响应用户定义的健康检查的容器,并且在它们准备好提供服务之前不会向客户端通知它们。
在后面安装KubeSphere可插拔的功能组件时,更改common.yaml配置文件后,不需要做什么操作,过一会儿会自动更新容器以应用这些改变。
备忘录
- kubectl get pods --all-namespaces
- kubectl get pod -n <namespace>
- kubectl logs <pod_name> -n <namespace>
- kubectl delete pod <pod_name> -n <namespace>
- # 查询systemd日志
- journalctl -xefu kubelet
- kubectl get services
- kubectl get deployments
- kubectl cluster-info
4. 文档
https://kubesphere.io/docs/installation/intro/
https://kubesphere.io/docs/zh-CN
https://kubesphere.io/docs/zh-CN/installation/intro/
https://kubesphere.io/zh-CN/blogs/
https://kubesphere.io/zh-CN/blog/kubesphere-values/
https://kubesphere.io/docs/zh-CN/introduction/what-is-kubesphere/
https://www.kubernetes.org.cn/author/kubesphere
安装KubeSphere的更多相关文章
- 安装 KubeSphere DevOps 系统
1. 安装KubeSphere 安装了一夜,终于看到了期待已久的画面 第一步.硬件配置(PS:VirtualBox虚拟机): 操作系统:Ubuntu 18.04 CPU:4核 内存:8G 磁盘:60 ...
- K8S安装Kubesphere
准备工作 安装Helm curl -L https://git.io/get_helm.sh | bash 创建账户 cat > heml-rbac.yaml << EOF apiV ...
- 【葵花宝典】All-in-One模式安装KubeSphere
1.准备 Linux 机器 2.google api受限下载 KubeKey export KKZONE=cn curl -sfL https://get-kk.kubesphere.io | VER ...
- 使用kubekey安装kubesphere
下载 KubeKey KubeKey 是新一代 Kubernetes 和 KubeSphere 安装器,可帮助您以简单.快速.灵活的方式安装 Kubernetes 和 KubeSphere. expo ...
- [转帖]Kubesphere all-in-one 安装方式.
All-in-One 模式 对于首次接触 KubeSphere 高级版的用户,想寻找一个最快安装和体验 KubeSphere 高级版核心功能的方式,all-in-one 模式支持一键安装 KubeSp ...
- Kubernetes Dashboard 终结者:KubeSphere
原文链接:Kubernetes Dashboard 终结者:KubeSphere 2018 年 7 月份,青云在 Cloud Insight 云计算峰会上推出了一款全新的容器平台--KubeSpher ...
- 手把手带你一键部署 Kubernetes + KubeSphere 至 Linux
本文介绍一个最快安装 Kubernetes 和体验 KubeSphere 核心功能的方式,all-in-one 模式可一键安装 Kubernetes v1.15.5 和 KubeSphere 至一台 ...
- 在 Kubernetes 集群快速部署 KubeSphere 容器平台
KubeSphere 不仅支持部署在 Linux 之上,还支持在已有 Kubernetes 集群之上部署 KubeSphere,自动纳管 Kubernetes 集群的已有资源与容器. 前提条件 Kub ...
- 在 Linux 部署多节点 Kubernetes 集群与 KubeSphere 容器平台
KubeSphere 是在 Kubernetes 之上构建的以应用为中心的企业级容器平台,所有供为用户提供简单易用的操作界面以及向导式操作方式.同时,KubeSphere Installer 提供了 ...
随机推荐
- HAproxy shell脚本安装
#!/bin/bash #需要lua-..tar.gz在家目录下 # 编译安装lua #安装编译环境需要的包 yum -y install gcc openssl-devel pcre-devel s ...
- 了解一下mock
1.mock简介: mock测试就是在测试过程中,对于某些不容易构成或者不容易获取的对象,用一个虚拟的对象来创建以便测试的测试方法,mock是在测试过程中,对于一些不容易构造/获取的对象,创建一个mo ...
- STC15F2K60S2串口通信的应用。
前言:由于不可抗拒因素,初始的STC12C5A60S2芯片由于无法进行烧录(...因为没带有锁紧座的开发板),暂且使用STC15F2K60S2芯片.. 一 串行通信概述: 串口通信有SPI IIC U ...
- 数据结构和算法(Golang实现)(16)常见数据结构-字典
字典 我们翻阅书籍时,很多时候都要查找目录,然后定位到我们要的页数,比如我们查找某个英文单词时,会从英语字典里查看单词表目录,然后定位到词的那一页. 计算机中,也有这种需求. 一.字典 字典是存储键值 ...
- 【python实现卷积神经网络】定义训练和测试过程
代码来源:https://github.com/eriklindernoren/ML-From-Scratch 卷积神经网络中卷积层Conv2D(带stride.padding)的具体实现:https ...
- Java 数据类型转换的骚操作和神奇现象
问:银行用什么数据类型来表示余额?float还是double? 都不是!!下面说明为什么都不可以呢? public static void main(String[] args) { //浮点数他都是 ...
- phoenix 索引实践
准备工作 创建测试表 CREATE TABLE my_table ( rowkey VARCHAR NOT NULL PRIMARY KEY, v1 VARCHAR, v2 VARCHAR, v3 V ...
- Spring Data REST不完全指南(一)
简介 Spring Data REST是Spring Data项目的一部分,可轻松在Spring Data存储库上构建超媒体驱动的REST Web服务. Spring Data REST 构建在 Sp ...
- BUG 测试计划
性能追求 目前状况 测试标准 APP平稳运行,无crush现象 快速下拉翻页时,崩溃退出 要求多人使用,均流畅无异常退出方可 页面的放大缩小不会造成页面显 ...
- HBase可用性分析与高可用实践
HBase作为一个分布式存储的数据库,它是如何保证可用性的呢?对于分布式系统的CAP问题,它是如何权衡的呢? 最重要的是,我们在生产实践中,又应该如何保证HBase服务的高可用呢? 下面我们来仔细分析 ...