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

[经验分享] Kubernetes 1.5安装

[复制链接]

尚未签到

发表于 2018-9-16 07:24:59 | 显示全部楼层 |阅读模式
  Kubernetes从1.3开始引入kubeadm来试图简化其复杂的安装。但kubeadm至今仍不稳定,而且我个人觉得kubeadm反而麻烦,还不如直接用脚本或者其他自动化工具来安装来的利索。关于kubeadm配置master的ha,也有相应的替代方案,比如使用keepalived或者corosync等高可用集群软件。所以在这篇文档中,我还是会使用传统的方式来安装kubernetes集群
  Kubernetes依赖于docker和etcd,docker的网络,在这里直接使用flannel。在这篇文档里,不会对master的高可用做过多的阐述,我们先简单的建立一个基本可用最小化集群。我这里使用的三台CentOS7.2的服务器,各服务器角色介绍如下:
192.168.1.20 server-20    master节点、node节点、etcd节点  
192.168.1.21 server-21    node节点、etcd节
  
192.168.1.22 server-22    node节点、etcd节点
  需要说明的是,这里需要大家自己设定好基本环境,比如关闭selinux,配置时间同步,清空现有的iptables策略,以及配置好epel源等。
  1、安装并启动docker
  docker的安装比较简单,直接使用yum安装即可:
yum install -y docker  
systemctl start docker
  
systemctl enable docker
  2、安装etcd
  在所有节点上执行如下安装操作:
yum -y install etcd  

  
# 创建etcd data 目录
  
mkdir -p /opt/etcd/data
  
chown -R etcd:etcd /opt/etcd/
  
# 修改配置文件,/etc/etcd/etcd.conf 需要修改如下参数:
  

  

  
ETCD_NAME=server-20
  
ETCD_DATA_DIR="/opt/etcd/data/server-20.etcd"
  
ETCD_LISTEN_PEER_URLS="
  
ETCD_LISTEN_CLIENT_URLS="
  
ETCD_INITIAL_ADVERTISE_PEER_URLS="
  
ETCD_INITIAL_CLUSTER="server-20=
  
ETCD_ADVERTISE_CLIENT_URLS="http://192.168.1.20:2379"

# 修改 etcd 启动文件  
sed -i 's/\\\"${ETCD_LISTEN_CLIENT_URLS}\\\"/\\\"${ETCD_LISTEN_CLIENT_URLS}\\\" --listen-client-urls=\\\"${ETCD_LISTEN_CLIENT_URLS}\\\" --advertise-client-urls=\\\"${ETCD_ADVERTISE_CLIENT_URLS}\\\" --initial-cluster-token=\\\"${ETCD_INITIAL_CLUSTER_TOKEN}\\\" --initial-cluster=\\\"${ETCD_INITIAL_CLUSTER}\\\" --initial-cluster-state=\\\"${ETCD_INITIAL_CLUSTER_STATE}\\\"/g' /usr/lib/systemd/system/etcd.service

# 启动 etcd  

  
systemctl enable etcd
  

  
systemctl start etcd
  

  
systemctl status etcd
  

  

  
# 查看集群状态
  

  
etcdctl cluster-health


# 启动 etcd  

  
systemctl enable etcd
  

  
systemctl start etcd
  

  
systemctl status etcd
  

  

  
# 查看集群状态
  

  
etcdctl cluster-health

  3、配置flannel
  先在etcd中注册flannel子网:
etcdctl set /coreos.com/network/config '{"network": "172.16.0.0/16"}'  在所有节点安装flannel:
yum install -y flannel  修改flannel配置文件/etc/sysconfig/flanneld如下:
FLANNEL_ETCD="http://192.168.1.20:2379,http://192.168.1.21:2379,http://192.168.1.22:2379"FLANNEL_ETCD_KEY="/coreos.com/network"  启动flannel:
systemctl start flanneld  
systemctl enable flanneld
  需要说明的是,如果要让docker使用flannel的网络,docker必须要后于flannel启动,所以需要重新启动docker:
systemctl restart docker  4、安装kubernetes服务端
  我这里使用的是网上别人提供的私有的kubernetes的yum源,如下:

vim /etc/yum.repos.d/kube.repo  

  
[kube]
  
name=Mritd Repository
  
baseurl=https://yum.mritd.me/centos/7/x86_64enabled=1gpgcheck=1gpgkey=https://mritd.b0.upaiyun.com/keys/rpm.public.key

  先通过yumdownloader将所有kubernetes相关的包下载下来,然后再通过本地yum实现安装:
yumdownloader kubernetes-master kubernetes-client kubernetes-nodeyum localinstall -y kubernetes-master kubernetes-client  修改kubernetes master上的配置文件如下:

vim /etc/kubernetes/config  

  
KUBE_LOGTOSTDERR="--logtostderr=true"KUBE_LOG_LEVEL="--v=0"KUBE_ALLOW_PRIV="--allow-privileged=false"KUBE_MASTER="--master=http://10.5.10.116:8080"vim /etc/kubernetes/apiserver
  

  
KUBE_API_ADDRESS="--address=0.0.0.0"KUBE_API_PORT="--port=8080 --secure-port=443"KUBE_MASTER="--master=http://10.5.10.116:8080"KUBELET_PORT="--kubelet-port=10250"KUBE_ETCD_SERVERS="--etcd-servers=http://10.5.10.116:2379,http://10.5.10.117:2379,http://10.5.10.131:2379"KUBE_SERVICE_ADDRESSES="--service-cluster-ip-range=10.254.0.0/16"KUBE_ADMISSION_CONTROL="--admission-control=NamespaceLifecycle,NamespaceExists,LimitRanger,SecurityContextDeny,ResourceQuota"

  启动kubernetes master:
systemctl start kube-apiserver kube-controller-manager kube-scheduler  
systemctl enable kube-apiserver kube-controller-manager kube-scheduler
  5、安装kubernetes node端
yum install -y kubernetes-node  修改node的配置文件:

vim /etc/kubernetes/config  

  
KUBE_LOGTOSTDERR="--logtostderr=true"KUBE_LOG_LEVEL="--v=0"KUBE_ALLOW_PRIV="--allow-privileged=false"KUBE_MASTER="--master=http://10.5.10.116:8080"vim /etc/kubernetes/kubelet
  

  
KUBELET_ADDRESS="--address=0.0.0.0"KUBELET_HOSTNAME="--hostname-override=server-116"KUBELET_API_SERVER="--api-servers=http://10.5.10.116:8080"KUBELET_POD_INFRA_CONTAINER="--pod-infra-container-image=myhub.fdccloud.com/library/pod-infrastructure:latest"

  启动node端:
systemctl start kubelet kube-proxy  
systemctl enable kubelet kube-proxy
  最后通过在kubernetes master上通过kubectl查看各节点是否正常:
[root@server-116 ~]# kubectl get nodes  
NAME         STATUS    AGE
  
server-20   Ready     1d
  
server-21   Ready     1d
  
server-22   Ready     1d
  至此,完成kubernetes 1.5的基本安装  



运维网声明 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-584288-1-1.html 上篇帖子: Kubernetes 使用 Ceph 存储 下篇帖子: Kubernetes 1.5 配置dns
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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