kubernetes 1.4.5集群部署
[fu@centos server]$ uname -aLinux centos 3.10.0-327.el7.x86_64 #1 SMP Thu Nov 19 22:10:57 UTC 2015 x86_64 x86_64 x86_64 GNU/Linux
1. 初始化环境
关闭防火墙:
[root@k8s-master fu]# systemctl stop firewalld
[root@k8s-master fu]# systemctl disable firewalld
1.1 环境:
节点
IP
node-1
192.168.44.129
node-2
192.168.44.131
node-3
192.168.44.132
[root@k8s-master fu]# systemctl stop firewalld[root@k8s-master fu]# systemctl disable firewalld
1.1 环境:
| 节点 | IP |
|---|---|
| node-1 | 192.168.44.129 |
| node-2 | 192.168.44.131 |
| node-3 | 192.168.44.132 |
1.2 设置hostname
hostnamectl --static set-hostname hostname
| IP | hostname |
|---|---|
| 192.168.44.129 | k8s-master |
| 192.168.44.131 | k8s-node-1 |
| 192.168.44.132 | k8s-node-2 |
[root@centos fu]# hostnamectl --static set-hostname k8s-master
[root@centos fu]# hostnamectl --static set-hostname k8s-node-1
[root@centos fu]# hostnamectl --static set-hostname k8s-node-2
1.3 配置 hosts
vi /etc/hosts
| IP | hostname |
|---|---|
|
192.168.44.129 |
k8s-master |
|
192.168.44.131 |
k8s-node-1 |
|
192.168.44.132 |
k8s-node-2 |
192.168.44.129 k8s-master192.168.44.131 k8s-node-1192.168.44.132 k8s-node-2
echo '192.168.44.129 k8s-master192.168.44.131 k8s-node-1192.168.44.132 k8s-node-2' >> /etc/hosts
1.4安装kubelet 和kubeadm
添加yum (注:root用户下执行)
cat <<EOF > /etc/yum.repos.d/k8s.repo
[kubelet]
name=kubelet
baseurl=http://files.rm-rf.ca/rpms/kubelet/
enabled=1
gpgcheck=0
EOF
安装并启动:
yum install docker kubelet kubeadm kubectl kubernetes-cni
systemctl enable docker && systemctl start docker
systemctl enable kubelet && systemctl start kubelet
cat <<EOF > /etc/yum.repos.d/k8s.repo[kubelet]name=kubeletbaseurl=http://files.rm-rf.ca/rpms/kubelet/enabled=1gpgcheck=0EOF
yum install docker kubelet kubeadm kubectl kubernetes-cnisystemctl enable docker && systemctl start dockersystemctl enable kubelet && systemctl start kubelet
2 部署 kubernetes master
2.1 添加yum(如环境统一处理,此处略过)
注:root用户下执行
cat <<EOF> /etc/yum.repos.d/k8s.repo
[kubelet]
name=kubelet
baseurl=http://files.rm-rf.ca/rpms/kubelet/
enabled=1
gpgcheck=0
EOF
2.1 添加yum(如环境统一处理,此处略过)
cat <<EOF> /etc/yum.repos.d/k8s.repo[kubelet]name=kubeletbaseurl=http://files.rm-rf.ca/rpms/kubelet/enabled=1gpgcheck=0EOF
安装 kubernetes依赖环境:
[root@k8s-master fu]# yum makecache[root@k8s-master fu]# yum install -y socat kubelet kubeadm kubectl kubernetes-cni

2.2 安装docker
wget -qO- https://get.docker.com/ | sh
bash: wget: 未找到命令
[root@centos fu]# yum -y install wget
[root@centos fu]# docker imagesCannot connect to the Docker daemon. Is the docker daemon running on this host?
systemctl enable dockersystemctl start docker
2.3 下载镜像
images=(kube-proxy-amd64:v1.4.5 kube-discovery-amd64:1.0 kubedns-amd64:1.7 kube-scheduler-amd64:v1.4.5 kube-controller-manager-amd64:v1.4.5 kube-apiserver-amd64:v1.4.5 etcd-amd64:2.2.5 kube-dnsmasq-amd64:1.3 exechealthz-amd64:1.1 pause-amd64:3.0 kubernetes-dashboard-amd64:v1.4.1)for imageName in ${images[@]} ; dodocker pull jicki/$imageNamedocker tag jicki/$imageName gcr.io/google_containers/$imageNamedocker rmi jicki/$imageNamedone
2.4 启动 kubernetes
systemctl enable kubeletsystemctl start kubelet
2.5 创建集群
kubeadm init --api-advertise-addresses=192.168.44.129 --use-kubernetes-version v1.4.5
如提示:
Running pre-flight checkspreflight check errors:/etc/kubernetes is not empty
[root@k8s-master kubernetes]# rm -rf manifests/
2.6 记录 token
Kubernetes master initialised successfully!You can now join any number of machines by running the following on each node:kubeadm join --token=a46536.cad65192491d2fd9 192.168.44.129
systemctl status kubelet
2.8 查询集群pods:
[root@k8s-master system]# kubectl get nodes
3 部署 kubernetes node
3.1 安装docker
wget -qO- https://get.docker.com/ | sh
bash: wget: 未找到命令
[root@centos fu]# yum -y install wget
systemctl enable dockersystemctl start docker
3.2 下载镜像
images=(kube-proxy-amd64:v1.4.5 kube-discovery-amd64:1.0 kubedns-amd64:1.7 kube-scheduler-amd64:v1.4.5 kube-controller-manager-amd64:v1.4.5 kube-apiserver-amd64:v1.4.5 etcd-amd64:2.2.5 kube-dnsmasq-amd64:1.3 exechealthz-amd64:1.1 pause-amd64:3.0 kubernetes-dashboard-amd64:v1.4.1)for imageName in ${images[@]} ; dodocker pull jicki/$imageNamedocker tag jicki/$imageName gcr.io/google_containers/$imageNamedocker rmi jicki/$imageNamedone
3.3 安装并启动 kubernetes(如环境统一处理,此处略过)
yum makecacheyum install -y socat kubelet kubeadm kubectl kubernetes-cni
systemctl enable kubeletsystemctl start kubelet
3.4 加入集群
- kubeadm join --token=a46536.cad65192491d2fd9 192.168.44.129
4 设置 kubernetes
[fu@k8s-master ~]$ kubectl apply -f https://git.io/weave-kube
daemonset "weave-net" created
[fu@k8s-master ~]$ kubectl apply -f https://git.io/weave-kubedaemonset "weave-net" created
4.2 查看系统服务状态
查看所有的namespaces中的pods
[fu@k8s-master ~]$ kubectl get pods --all-namespaces
将master中文件,/etc/kubernetes/admin.conf拷贝到其它node节点,可以下载再上传,也可以主机间拷贝
主机间拷贝:
[root@k8s-master fu]# scp admin.conf fu@192.168.44.131:/home/fu[root@k8s-master fu]# scp admin.conf fu@192.168.44.132:/home/fu
node节点查询集群nodes状态命令:
[fu@k8s-node-2 ~]$ kubectl --kubeconfig ./admin.conf get nodes可以看到跟在master上运行效果一样:![]()
想看一下admin.conf是啥,可以more或cat,more按空格分页
[root@k8s-master fu]# more admin.conf
4.4 配置dashboard
#在master节点下载 yaml 文件, 直接导入会去官方拉取images
[fu@k8s-master ~]$ curl -O https://rawgit.com/kubernetes/dashboard/master/src/deploy/kubernetes-dashboard.yaml

编辑 yaml 文件,默认的 yaml 文件中对于 image 拉取策略的定义是 无论何时都会去拉取镜像
[fu@k8s-master ~]$ vi kubernetes-dashboard.yaml
编辑 yaml 改一下 imagePullPolicy,把 Always 改成 IfNotPresent(本地没有再去拉取) 或者 Never(从不去拉取) 即可
imagePullPolicy: Always
修改为:
imagePullPolicy: IfNotPresent
修改为:
创建:
[fu@k8s-master ~]$ kubectl create -f ./kubernetes-dashboard.yaml

查看 NodePort ,既外网访问端口
[fu@k8s-master ~]$ kubectl describe svc kubernetes-dashboard --namespace=kube-system
通过 describe 命令我们可以查看其暴露出的 NodePoint,然后便可访问:
浏览器中访问 dashboard,端口NodePort
192.168.44.129:32145
如打不开,可以查看一下pod状态,是否创建完成。
[fu@k8s-master ~]$ kubectl get pod --namespace=kube-system都Running后,效果如下:
如有遇到此问题,按下解决,我没遇到。
FAQ:kube-discovery errorfailed to create "kube-discovery" deployment [deployments.extensions "kube-discovery" already exists]systemctl stop kubelet;docker rm -f -v $(docker ps -q);find /var/lib/kubelet | xargs -n 1 findmnt -n -t tmpfs -o TARGET -T | uniq | xargs -r umount -v;rm -r -f /etc/kubernetes /var/lib/kubelet /var/lib/etcd;systemctl start kubeletkubeadm init
github上,kubernetes版本:https://github.com/kubernetes/kubernetes/releases
kubernetes 1.4.5集群部署的更多相关文章
- kubernetes集群部署
鉴于Docker如此火爆,Google推出kubernetes管理docker集群,不少人估计会进行尝试.kubernetes得到了很多大公司的支持,kubernetes集群部署工具也集成了gce,c ...
- Kubernetes集群部署关键知识总结
Kubernetes集群部署需要安装的组件东西很多,过程复杂,对服务器环境要求很苛刻,最好是能连外网的环境下安装,有些组件还需要连google服务器下载,这一点一般很难满足,因此最好是能提前下载好准备 ...
- 基于Kubernetes集群部署skyDNS服务
目录贴:Kubernetes学习系列 在之前几篇文章的基础,(Centos7部署Kubernetes集群.基于kubernetes集群部署DashBoard.为Kubernetes集群部署本地镜像仓库 ...
- 为Kubernetes集群部署本地镜像仓库
目录贴:Kubernetes学习系列 经过之前两篇文章:Centos7部署Kubernetes集群.基于kubernetes集群部署DashBoard,我们基本上已经能够在k8s的集群上部署一个应用了 ...
- Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列目录
0.目录 整体架构目录:ASP.NET Core分布式项目实战-目录 k8s架构目录:Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列目录 一.感谢 在此感谢.net ...
- Kubernetes集群部署篇( 一)
K8S集群部署有几种方式:kubeadm.minikube和二进制包.前两者属于自动部署,简化部署操作,我们这里强烈推荐初学者使用二进制包部署,因为自动部署屏蔽了很多细节,使得对各个模块感知很少,非常 ...
- 利用ansible来做kubernetes 1.10.3集群高可用的一键部署
请读者务必保持环境一致 安装过程中需要下载所需系统包,请务必使所有节点连上互联网. 本次安装的集群节点信息 实验环境:VMware的虚拟机 IP地址 主机名 CPU 内存 192.168.77.133 ...
- 二进制方式部署Kubernetes 1.6.0集群(开启TLS)
本节内容: Kubernetes简介 环境信息 创建TLS加密通信的证书和密钥 下载和配置 kubectl(kubecontrol) 命令行工具 创建 kubeconfig 文件 创建高可用 etcd ...
- Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列之集群部署环境规划(一)
0.前言 整体架构目录:ASP.NET Core分布式项目实战-目录 k8s架构目录:Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列目录 一.环境规划 软件 版本 ...
随机推荐
- react-native ListView使用详解
刚好今天七夕,呆萌的程序猿没有妹纸,刚好发小明天结婚,我还在异地,晚上还要苦逼的赶火车.趁着下午比较闲,更新一下Blog,也算是在百无聊赖之时给众多单身程序猿们的小福利吧,虽然已经好久没更了...囧 ...
- 查看Sql Server被锁的表以及解锁
查看被锁表: select spId from master..SysProcesses where db_Name(dbID) = '数据库名称' and spId <> @@SpId ...
- 黑马程序员——ARC机制总结和用ARC建立模型
ARC 全称:Automatic Reference Counting 使用ARC 只需要在建立一个新的项目的时候把 下面的√打上 Xcode5以后都会默认建议开发者使用ARC机制 新的项目中如果有部 ...
- 手游聚合SDK开发之远程开关---渠道登入白名单
白名单有啥好说的呢?无非就是筛选登入,大家第一眼看到就是这个印象,白名单也是有文章的,弄的时机不同会给你带来很不错的收益,注意是收益.还是举例来说,游戏上线前渠道都会做一个预下载,一般提前1-2天,这 ...
- CRM 2013 相关下载 / 2013-10-11
CRM 2013的安装文件,软件开发工具包(Sdk)以及实施指南,在微软官方网站已经有下载了. 具体地址如下: Name Url 发布日期 语言版本 说明 CRM Server htt ...
- 分享一个ReactiveCocoa的很好的教程(快速上手)
这是我看到的比较全而且讲的很好的文章 https://www.raywenderlich.com/62796/reactivecocoa-tutorial-pt1 https://www.raywen ...
- GitLab CI持续集成配置方案
目录 1. 持续集成介绍 1.1 概念 1.2 持续集成的好处 2. GitLab持续集成(CI) 2.1 简介 2.2 GitLab简单原理图 2.3 GitLab持续集成所需环境 2.4 需要了解 ...
- spring加载配置文件
spring加载配置文件 1.把applicationContext.xml直接放在WEB-INF/classes下,spring会采用默认的加载方式2.采用在web.xml中配置ContextLoa ...
- MySQL 处理重复数据
有些 MySQL 数据表中可能存在重复的记录,有些情况我们允许重复数据的存在,但有时候我们也需要删除这些重复的数据. 本博文我们将为大家介绍如何防止数据表出现重复数据及如何删除数据表中的重复数据. 防 ...
- Merge 的小技巧
今天跟大家分享一下搬动数据使用Merge的方法. 有些时候,当我们做数据搬动的时候,有时候做测试啊,换对象啊,就会存在有时候外键存在,不知道怎么对应的关系.比如我现在有架构相同的两组table , A ...