设为首页 收藏本站
查看: 2619|回复: 0

[经验分享] Rancher-k8s加速安装文档

[复制链接]

尚未签到

发表于 2018-1-5 23:19:43 | 显示全部楼层 |阅读模式
  Kubernetes是一个强大的容器编排工具,帮助用户在可伸缩性系统上可靠部署和运行容器化应用。Rancher容器管理平台原生支持K8s,使用户可以简单轻松地部署K8s集群。
  很多同学正常部署k8s环境后无法进入Dashboard,基础设施应用栈均无报错。但通过查看 基础架构|容器 发现并没有Dashboard相关的容器。
  因为k8s在拉起相关服务(如Dashboard、内置DNS等服务)是通过应用商店里面的YML文件来定义的,YML文件中定义了相关的镜像名和版本。而Rancher部署的k8s应用栈属于k8s的基础框架,相关的镜像通过dockerhub/rancher 仓库拉取。
  默认Rancher-catalog k8s YML中服务镜像都是从谷歌仓库拉取,在没有科学上网的情况下,国内环境几乎无法成功拉取镜像。
  为了解决这一问题,优化中国区用户的使用体验,rancher修改了http://git.oschina.net/rancher/rancher-catalog仓库中的YML文件,将相关的镜像也同步到国内仓库,通过替换默认商店地址来实现加速部署。
一、环境准备
  整个演示环境由以下4台本地虚拟机组成,相关信息说明如下:
DSC0000.jpg

二、操作说明
  具体演示操作说明如下:
  
  第一步
  1、直接运行Rancher_server:
  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:
  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
DSC0001.jpg

  PS:回到最开始的启动命令,如果以第二种方式启动,这个地方就会被默认配置好。所以,根据自己的情况选择哪一种配置方式, 最后点击保存。
  
  第三步,Kubernetes环境配置查看对比:
  重启并进入WEB后,选择环境管理。如图:
DSC0002.jpg

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

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

DSC0005.jpg

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

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

  PS:default环境由于没有添加host,会显示Unhealthy。
  切换模板
DSC0008.jpg

  等待添加主机
DSC0009.jpg

  
  第五步,添加主机:
DSC00010.jpg

  如上图,进入添加主机界面
  指定用于注册这台主机的公网IP。如果留空,Rancher会自动检测IP注册。通常在主机有唯一公网IP 的情况下这是可以的。如果主机位于防火墙/NAT设备之后,或者主机同时也是运行rancher/server容器的主机时,则必须设置此IP。
  以上这段话会在添加主机页面显示,这段话的意思就是:如果准备添加的节点有运行Rancher-server容器,那么在添加节点的时候就要输入节点可被直接访问的主机IP地址(如果做的Rancher-HA,那么每台运行Rancher-server的节点都要添加主机IP地址),如果不添加主机IP地址,那么在添加节点后获取到的地址很可能会是Rancher-server容器内部的私网地址,导致无法使各节点通信。所以需要注意一下!
  本示例三个节点都没有运行rancher_server,所以直接复制生成的代码,在三个节点执行。
DSC00011.jpg

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

  镜像拉取中
DSC00013.jpg

DSC00014.jpg

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

DSC00016.jpg

  服务容器查看:点击基础架构|主机
   DSC00017.jpg
  对比基础设施中kubernetes 应用栈,可以发现有以下容器是不在应用栈中的:
   DSC00018.jpg
  这些应用是在k8s框架运行起来之后,再通过YML配置文件拉起的k8s服务,比如Dashboard服务
   DSC00019.jpg
  那些点击 kubernetes UI 提示服务不可达的。 可以先看看有没有此服务容器。
  接下来在k8s中简单部署一个应用。
  
  第六步,k8s应用部署:
  进入k8s的Dashboard后,默认显示的是default 命名空间。
  可以通过下拉箭头切换到kube-system命名空间,这里显示了CPU、内存使用率,以及一些系统组件的运行状况。
DSC00020.jpg

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

  注:在service中,如果选择Internal, 将需要ingress功能,ingress类似于LB的功能,这个后续讲解。这里我们选择External 。
  最后点击deploy .点击deploy后将会跳转到部署状态界面,如图:
   DSC00022.jpg
  部署完成后显示状态:
   DSC00023.jpg
  页面右侧点击service
   DSC00024.jpg
  可以看到部署的服务以及访问信息。
   DSC00025.jpg DSC00026.jpg
  返回Rancher,进入基础设施
   DSC00027.jpg
  可以看到自动增加了一个kubernetes-loadbalancers 应用栈。 这个应用栈的信息是通过k8s传递到Rancher,所以在部署应用后,在Rancher中很容易找到服务访问点。
   DSC00028.jpg DSC00029.jpg

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-432072-1-1.html 上篇帖子: 在K8s中创建StatefulSet 下篇帖子: 添加k8s新节点失败总结
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表