Openstack+Kubernetes+Docker微服务实践之路--Kubernetes
经过几番折腾终于搞定Kubernetes了,我们要在Openstack上部署Kubernetes集群,使用最新工具Kubeadm来安装,由于不能直接访问Kubernetes的源,我们需要一台可以穿墙的机器,可以是个人电脑,另外需要一台基于Docker快照的云主机,将下载后的所有资源放到这台机器中生成新的Kubernetes快照,用来做为以后Kubernetes集群的系统基础。
下载Kubernetes依赖资源
所有操作在可以穿墙的机器上进行
1,下载安装源
我们使用的kubernetes版本是1.4.5, 参考官方安装文档,http://kubernetes.io/docs/getting-started-guides/kubeadm/ ,配置好源后,仅下载所有Kubernetes依赖的安装包,注意这里不需要再安装Docker了
yum install -y kubelet kubeadm kubectl kubernetes-cni --downloadonly --downloaddir=/root/rpmsource
在安装的时候配置一个本地源。
下载kubernetes镜像
kubernetes一些服务是运行在Docker中的,所以我们需要提前下载好依赖的镜像到本地,然后Push到我们在上文中说到的Registry2.io中
images=(gcr.io/google_containers/kube-proxy-amd64:v1.4.5 gcr.io/google_containers/kube-apiserver-amd64:v1.4.5 gcr.io/google_containers/kube-scheduler-amd64:v1.4.5 gcr.io/google_containers/kube-controller-manager-amd64:v1.4.5 gcr.io/google_containers/kube-discovery-amd64:1.0 gcr.io/google_containers/kubedns-amd64:1.7 gcr.io/google_containers/exechealthz-amd64:1.1 gcr.io/google_containers/kube-dnsmasq-amd64:1.3 gcr.io/google_containers/pause-amd64:3.0 gcr.io/google_containers/etcd-amd64:2.2.5 weaveworks/weave-npc:1.7.2 weaveworks/weave-kube:1.7.2 weaveworks/scope:0.17.1 weaveworks/weaveexec:1.6.1)
for imageName in ${images[@]} ; do
docker pull $imageName
localName=registry2.io/${imageName/gcr.io\//}
docker tag $imageName $localName
docker push $localName
echo $localName
done
注意你要安装的版本号,在用的时候同样的方法pull下来再把tag改回去。

将所有下载好的资源上传到云主机上,并生成一个新的快照做为以后创建Kubernetes集群主机的基础系统!
Kubernetes初始化
现在可以使用Kubernetes的快照创建三台云主机,一台Master,其余的做为Worker,如图


注意网段不要跟Kubernetes的冲突,Kubernetes默认是10,这里改为100!

按照官方文档,安装之后,在Master上做init操作
kubeadm init --use-kubernetes-version=v1.4.5
需要注意的是一定要等所有的pods都处于Running状态再进行一步操作,比如安装Web UI等

另外需要注意的一点是一定要按照顺序操作,先添加一台子结点再初始化网络,反之始化网络时总是失败,其它的子结点可以在后序慢慢添加。
组件安装
Web UI
安装参考http://kubernetes.io/docs/user-guide/ui/ ,一条Kubectl命令搞定
配置heapster,支持图形展示cpu、内存等数据
https://github.com/kubernetes/heapster/blob/master/docs/influxdb.md

Weave Scope
一个图形化的k8s所有资源的拓扑、pods依赖展现等
安装参考,很简单,参考https://www.weave.works/docs/scope/latest/installing/

常用操作
记住,有了Kubernetes就不要再想着直接操作Docker了,大多数操作基本都被封装在了Kubectl命令中了,Kubect的常用命令大家在网上搜索一下,这里就不一一列举了,只说几个非常有用的操作,
- kubectl exec pod_id_xxx date 在PODS中运行命令
- kubectl exec pod_id_xxx -it /bin/sh 进入PODS
- kubectl delete -f xxx.yml 删除资源
- kubectl apply -f xxx.yml 更新、修改资源,没有的话会创建,所以可以直接使用apply,如果失败尝试删除再create!
- kubectl create -f xxx.yml 创建资源
- kubectl get po --all-namespaces 所出所有pods资源
到此我们的基本条件都准备好了,下文将开始做运行测试,敬请期待。
Openstack+Kubernetes+Docker微服务实践之路--Kubernetes的更多相关文章
- Openstack+Kubernetes+Docker微服务实践之路--基础设施
近两年微服务在网上聊的如此的如火如荼,备受关注,我在去年下半年的一个项目中也用到了阿里云的EDAS.HSF,深有体会,最近时间空闲出于好奇,决定一探究竟打算自建微服务平台,基本实现EDAS.HSF的功 ...
- Openstack+Kubernetes+Docker微服务实践之路--RPC
重点来了,本文全面阐述一下我们的RPC是怎么实现并如何使用的,跟Kubernetes和Openstack怎么结合. 在选型一文中说到我们选定的RPC框架是Apache Thrift,它的用法是在Ma ...
- Openstack+Kubernetes+Docker微服务实践之路--选型
上一篇博文中我们选定Openstack做为我们的基础设施IAAS平台,本文将明确我们用什么技术做为微服务平台的技术选型. 经过对微服务的特性总结和添加一些个性需求后对微服务平台的基本要求 PRC远程调 ...
- Openstack+Kubernetes+Docker微服务实践之路--服务发布
结合上文,我们的服务已经可以正常运行了,但它的访问方式只能通过服务器IP加上端口来访问,如何通过域名的方式来访问到我们服务,本来想使用Kubernetes的Ingress来做,折腾一天感觉比较麻烦,I ...
- Openstack+Kubernetes+Docker微服务实践之路--Docker和Registry2
渐入佳境,我们开始比较具体的工作,由于Docker是一个基础组件,所以本文的主题是Docker和Registry2. 底层系统基于Centos7,先在一台云主机上安装Docker,Docker的安装非 ...
- Openstack+Kubernetes+Docker微服务实践之路--弹性扩容
服务上线就要顶的住压力.扛的住考验,不然挨说的还是我们这帮做事的兄弟,还记得上图这个场景吗 老办法是服务集群部署,但总归有个上限,之前跟阿里合作的时候他们有个弹性计算可以通过设置CPU的阀值来动态扩展 ...
- Openstack+Kubernetes+Docker微服务实践
Openstack+Kubernetes+Docker微服务实践 ..... Openstack+Kubernetes+Docker微服务实践之路--选型 posted @ 2016-11-15 ...
- QCon技术干货:个推基于Docker和Kubernetes的微服务实践
2016年伊始,Docker无比兴盛,如今Kubernetes万人瞩目.在这个无比需要创新与速度的时代,由容器.微服务.DevOps构成的云原生席卷整个IT界.在近期举办的QCon全球软件开发大会上, ...
- Openstack+Kubernetes+Docker微服务
Openstack+Kubernetes+Docker微服务 渐入佳境,我们开始比较具体的工作,由于Docker是一个基础组件,所以本文的主题是Docker和Registry2. 底层系统基于Cent ...
随机推荐
- 阿里 otter搭建过程整理
1 环境说明: 本机ip 192.168.8.3 虚拟机1 ip 192.168.8.5 虚拟机2 ip 192.168.8.6 虚拟机采取桥接模式 虚拟机系统为CentOS 2.6.32-279.e ...
- linux scp 远程复制文件
1.从本机复制文件到远程scp 文件名 远程计算机用户名@远程计算机的ip:远程计算机存放该文件的路径2.从远程复制文件到本机:scp 远程计算机用户名@远程计算机ip:文件名 存放该文件的本机路径3 ...
- iBatis框架batch处理优化 (转)
为什么要做batch处理 这个问题我就不解释了,因为我想你们肯定能比我解释的更好!如果你真的不知道,那就到Google上去搜索一下吧☻Oracle回滚段 这个问题偶也不很明白,只是 ...
- excel手机号码归属地批量公式查询 vlookup函数
Excel手机号码归属地 批量公式查询 vlookup函数 xls 手机号码 添加一列 地区归属地 使用 公式:=(VLOOKUP(LEFT(B2,7),号段数据库!B:D,2,0)& ...
- mui小总结
下拉刷新 第一: mui.init({ pullRefresh: { container: '#pullrefresh', up: { contentrefresh: '正在加载...', callb ...
- 客户端使用java,服务端使用c++的corba编程环境搭建
我们先用c++实现服务端和客户端,然后再用java编写客户端. 1. 首先安装omniORB,omniORB提供 omniidl命令,以及一些头文件和库. omniORB一般是需要你自己进行编译. 2 ...
- DELPHI实现百度开放平台
学习百度语音 百度语音开发平台 http://yuyin.baidu.com/ 百度开发者账号 13600514494,短信登录 应用账号 词语听写 App ID: 7799366 API Key: ...
- Protocols
- h5动画效果总结
一些常用的h5效果,自己总结的,用的时候直接拿,方便快捷! 1.悬浮时放大: .one{transition:All 0.4s ease-in-out;-webkit-transition:All 0 ...
- 将形如:Oct 8, 2016 5:29:44 PM串转换成正常时间在真机上遇到的坑
将形如:Oct 8, 2016 5:29:44 PM串转换成正常时间在真机上遇到的坑 /** * 根据传入字符串 * * @param str 传入的日期字符串 形如:Oct 8, 2016 5:29 ...