Rancher-k8s加速安装文档

简介:

Kubernetes是一个强大的容器编排工具,帮助用户在可伸缩性系统上可靠部署和运行容器化应用。Rancher容器管理平台原生支持K8s,使用户可以简单轻松地部署K8s集群。


很多同学正常部署k8s环境后无法进入Dashboard,基础设施应用栈均无报错。但通过查看 基础架构|容器 发现并没有Dashboard相关的容器。


因为k8s在拉起相关服务(如Dashboard、内置DNS等服务)是通过应用商店里面的YML文件来定义的,YML文件中定义了相关的镜像名和版本。而Rancher部署的k8s应用栈属于k8s的基础框架,相关的镜像通过dockerhub/rancher 仓库拉取。


默认Rancher-catalog k8s YML中服务镜像都是从谷歌仓库拉取,在没有科学上网的情况下,国内环境几乎无法成功拉取镜像。


为了解决这一问题,优化中国区用户的使用体验,我们修改了http://git.oschina.net/rancher/rancher-catalog仓库中的YML文件,将相关的镜像也同步到国内仓库,通过替换默认商店地址来实现加速部署。


环境准备


整个演示环境由以下4台本地虚拟机组成,相关信息说明如下:


wKioL1lkxFKSzHRfAAMGsT22yXI596.png


操作说明


具体演示操作说明如下:


第一步


1、直接运行Rancher_server:

1
Sudo docker run -d --restart always –name rancher_server -p  8080 : 8080   rancher/server:stable  && sudo docker logs -f rancher-server


容器初始化完成后,通过主机IP:8080访问WEB。


2、添加变量启动Rancher_server:

1
2
3
Sudo docker run -d --name rancher-server -p  8080 : 8080  --restart=unless-stopped  -e  DEFAULT_CATTLE_CATALOG_URL= '{"catalogs":{"library":{"url":"http://git.oschina.net/rancher/rancher-catalog.git","branch":"k8s-cn"}}}'   \
 
rancher/server:stable  && sudo docker logs -f rancher-server


变量的作用后面介绍。


第二步,Rancher基本配置:


因为Rancher修改过的设置参数无法同步到已创建的环境,所以在创建环境前要把相关设置配置好。比如,如果你想让Rancher默认去拉取私有仓库的镜像,需要配置registry.default= 参数等。 


应用商店(Catalog)地址配置:在系统管理\系统设置中,找到应用商店。禁用Rancher 官方认证仓库并按照下图配置。


  • 名称:library  (全小写)

  • 地址: https://git.oschina.net/rancher/rancher-catalog.git   

  • 分支: k8s-cn


wKioL1lkxOrgCi41AABctsbOFmc573.png


PS:回到最开始的启动命令,如果以第二种方式启动,这个地方就会被默认配置好。所以,根据自己的情况选择哪一种配置方式, 最后点击保存。


第三步,Kubernetes环境配置查看对比:


重启并进入WEB后,选择环境管理。如图:


wKioL1lkxQGjPyohAADOPAzNKWQ191.png


在环境模板中,找到Kubernetes 模板,点击右边的编辑图标,接着点击编辑配置。


wKiom1lkxQ3QZryIAAA9WdAIY1o915.png


以下是Rancher-k8s的默认配置对比,图一为默认商店的参数,图二为自定义商店的参数。


wKioL1lkxVWD7MIOAAGruRtPsRM588.pngwKioL1lkxV6jhvKxAAFbWn_uaA8488.png


这里只是查看参数不做相关修改。点击cancel返回模板编辑页面。  在这里,根据需要可以定制组件,比如可以把默认的ipsec网络改为vxlan网络等,这里不再叙述。 最后点保存或者cancle返回环境管理界面。


第四步,添加环境:


在环境管理界面中,点击页面上方的添加环境按钮:


wKioL1lkxX2CdVEwAAAX3fjd6xE905.png


填写环境名称,选择环境模板(Kubernetes),点击创建。创建后:


wKiom1lkxYjTCb7XAAAniRfv3Vs649.png


PS:default环境由于没有添加host,会显示Unhealthy。


切换模板


wKioL1lkxZeR5S_pAAA_pObGor4340.png


等待添加主机


wKiom1lkxaOg-hZ4AAC2Ll3cYMk906.png


第五步,添加主机:


wKioL1lkxc-AEOWNAAA0AbSXAks939.png


如上图,进入添加主机界面


指定用于注册这台主机的公网IP。如果留空,Rancher会自动检测IP注册。通常在主机有唯一公网IP 的情况下这是可以的。如果主机位于防火墙/NAT设备之后,或者主机同时也是运行rancher/server容器的主机时,则必须设置此IP。


以上这段话会在添加主机页面显示,这段话的意思就是:如果准备添加的节点有运行Rancher-server容器,那么在添加节点的时候就要输入节点可被直接访问的主机IP地址(如果做的Rancher-HA,那么每台运行Rancher-server的节点都要添加主机IP地址),如果不添加主机IP地址,那么在添加节点后获取到的地址很可能会是Rancher-server容器内部的私网地址,导致无法使各节点通信。所以需要注意一下!


本示例三个节点都没有运行rancher_server,所以直接复制生成的代码,在三个节点执行。


wKiom1lkxenAiH7xAAEaEzz7rCw650.png


节点添加成功,应用栈创建完毕,正在启动服务:


wKioL1lkxfahgdqiAABnvV9lfxo531.png


镜像拉取中


wKiom1lkxgTQYZk8AAFxPd6SnYQ810.pngwKioL1lkxhDw-WKXAAHLNAdCOMc318.png


到此为止,k8s就部署完成。


wKioL1lkxiGhp3lZAACPU7fsjFg813.pngwKioL1lkxiuQ0ApEAACUSMpd9h0286.png


服务容器查看:点击基础架构|主机 


wKiom1lkxjyiEupaAAArcK5KBOc835.png


对比基础设施中kubernetes 应用栈,可以发现有以下容器是不在应用栈中的:


wKiom1lkxkvz7tj3AABAaiiUVoU553.png


这些应用是在k8s框架运行起来之后,再通过YML配置文件拉起的k8s服务,比如Dashboard服务


wKiom1lkxljxc1CAAAAdpIT9VNc531.png


那些点击 kubernetes UI 提示服务不可达的。 可以先看看有没有此服务容器。


接下来在k8s中简单部署一个应用。


第六步,k8s应用部署:


进入k8s的Dashboard后,默认显示的是default 命名空间。


可以通过下拉箭头切换到kube-system命名空间,这里显示了CPU、内存使用率,以及一些系统组件的运行状况。


wKioL1lkxm2waU8eAADdWlNl4Jo623.png


应用部署:


页面右上角点击create 按钮,进入部署配置界面,并简单做一写设置:


wKiom1lkxnyzpZHKAADBGAWG9qo797.png


注:在service中,如果选择Internal, 将需要ingress功能,ingress类似于LB的功能,这个后续讲解。这里我们选择External 。

 

最后点击deploy .点击deploy后将会跳转到部署状态界面,如图:


wKioL1lkxo3DAREqAACE4MIN_A0437.png


部署完成后显示状态:


wKioL1lkxpqAqGDvAACa7Oh_Y6Y364.png


页面右侧点击service


wKiom1lkxquRJ_xcAAAnsZreD5s960.png


可以看到部署的服务以及访问信息。


wKiom1lkxriDjkaGAAB1h-QSpTc949.pngwKioL1lkxsOwhuDNAACjdPNTEAY842.png


返回Rancher,进入基础设施


wKiom1lkxtLAqORQAABpVhyp1sU522.png


可以看到自动增加了一个kubernetes-loadbalancers 应用栈。 这个应用栈的信息是通过k8s传递到Rancher,所以在部署应用后,在Rancher中很容易找到服务访问点。


原文来源:Rancher Labs



本文转自 RancherLabs 51CTO博客,原文链接:http://blog.51cto.com/12462495/1946612

相关实践学习
容器服务Serverless版ACK Serverless 快速入门:在线魔方应用部署和监控
通过本实验,您将了解到容器服务Serverless版ACK Serverless 的基本产品能力,即可以实现快速部署一个在线魔方应用,并借助阿里云容器服务成熟的产品生态,实现在线应用的企业级监控,提升应用稳定性。
云原生实践公开课
课程大纲 开篇:如何学习并实践云原生技术 基础篇: 5 步上手 Kubernetes 进阶篇:生产环境下的 K8s 实践 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
13天前
|
运维 Kubernetes 监控
Kubernetes 集群的持续性能优化实践
【4月更文挑战第26天】 在动态且不断增长的云计算环境中,维护高性能的 Kubernetes 集群是一个挑战。本文将探讨一系列实用的策略和工具,旨在帮助运维专家监控、分析和优化 Kubernetes 集群的性能。我们将讨论资源分配的最佳实践,包括 CPU 和内存管理,以及集群规模调整的策略。此外,文中还将介绍延迟和吞吐量的重要性,并提供日志和监控工具的使用技巧,以实现持续改进的目标。
|
15天前
|
存储 运维 Kubernetes
Kubernetes 集群的监控与维护策略
【4月更文挑战第23天】 在微服务架构日益盛行的当下,容器编排工具如 Kubernetes 成为了运维工作的重要环节。然而,随着集群规模的增长和复杂性的提升,如何确保 Kubernetes 集群的高效稳定运行成为了一大挑战。本文将深入探讨 Kubernetes 集群的监控要点、常见问题及解决方案,并提出一系列切实可行的维护策略,旨在帮助运维人员有效管理和维护 Kubernetes 环境,保障服务的持续可用性和性能优化。
|
17天前
|
存储 运维 Kubernetes
Kubernetes 集群的持续性能优化实践
【4月更文挑战第22天】在动态且复杂的微服务架构中,确保 Kubernetes 集群的高性能运行是至关重要的。本文将深入探讨针对 Kubernetes 集群性能优化的策略与实践,从节点资源配置、网络优化到应用部署模式等多个维度展开,旨在为运维工程师提供一套系统的性能调优方法论。通过实际案例分析与经验总结,读者可以掌握持续优化 Kubernetes 集群性能的有效手段,以适应不断变化的业务需求和技术挑战。
|
5天前
|
运维 监控 Kubernetes
Kubernetes 集群的监控与维护策略
【5月更文挑战第4天】 在当今微服务架构盛行的时代,容器化技术已成为软件开发和部署的标准实践。Kubernetes 作为一个开源的容器编排平台,因其强大的功能和灵活性而广受欢迎。然而,随着 Kubernetes 集群规模的扩大,集群的监控和维护变得日益复杂。本文将探讨 Kubernetes 集群监控的重要性,分析常见的监控工具,并提出一套有效的集群维护策略,以帮助运维人员确保集群的健康运行和高可用性。
37 10
|
6天前
|
存储 运维 监控
Kubernetes 集群的持续监控与优化策略
【5月更文挑战第3天】在微服务架构和容器化部署日益普及的背景下,Kubernetes 已成为众多企业的首选容器编排平台。然而,随着集群规模的增长和业务复杂度的提升,有效的集群监控和性能优化成为确保系统稳定性和提升资源利用率的关键。本文将深入探讨针对 Kubernetes 集群的监控工具选择、监控指标的重要性解读以及基于数据驱动的性能优化实践,为运维人员提供一套系统的持续监控与优化策略。
|
9天前
|
运维 Kubernetes 监控
Kubernetes 集群的监控与维护策略
【4月更文挑战第30天】 在现代云计算环境中,容器化技术已成为应用程序部署和管理的重要手段。其中,Kubernetes 作为一个开源的容器编排平台,以其强大的功能和灵活性受到广泛欢迎。然而,随之而来的是对 Kubernetes 集群监控和维护的复杂性增加。本文将探讨针对 Kubernetes 集群的监控策略和维护技巧,旨在帮助运维人员确保集群的稳定性和高效性。通过分析常见的性能瓶颈、故障诊断方法以及自动化维护工具的应用,我们将提供一套实用的解决方案,以优化 Kubernetes 环境的性能和可靠性。
|
9天前
|
运维 Kubernetes 监控
Kubernetes集群的持续性能优化策略
【4月更文挑战第30天】 在动态且不断扩展的云计算环境中,保持应用性能的稳定性是一个持续的挑战。本文将探讨针对Kubernetes集群的持续性能优化策略,旨在为运维工程师提供一套系统化的性能调优框架。通过分析集群监控数据,我们将讨论如何诊断常见问题、实施有效的资源管理和调度策略,以及采用自动化工具来简化这一过程。
|
9天前
|
Prometheus 监控 Kubernetes
Kubernetes 集群的监控与日志管理策略
【4月更文挑战第30天】 在微服务架构日益普及的当下,容器化技术与编排工具如Kubernetes成为了运维领域的重要话题。有效的监控和日志管理对于保障系统的高可用性和故障快速定位至关重要。本文将探讨在Kubernetes环境中实施监控和日志管理的最佳实践,包括选用合适的工具、部署策略以及如何整合这些工具来提供端到端的可见性。我们将重点讨论Prometheus监控解决方案和EFK(Elasticsearch, Fluentd, Kibana)日志管理堆栈,分析其在Kubernetes集群中的应用,并给出优化建议。
|
10天前
|
SQL Kubernetes 调度
【一文看懂】部署Kubernetes模式的Havenask集群
本次分享内容为havenask的kubernetes模式部署,由下面2个部分组成(部署Kubernetes模式Havenask集群、 Kubernetes模式相关问题排查),希望可以帮助大家更好了解和使用Havenask。
23 1
|
10天前
|
Kubernetes 网络协议 Python
一文教会你,如何通过kubeadm,在生产环境部署K8S高可用集群(二)
一文教会你,如何通过kubeadm,在生产环境部署K8S高可用集群(二)