博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
使用kubeadm安装Kubernetes
阅读量:4349 次
发布时间:2019-06-07

本文共 2879 字,大约阅读时间需要 9 分钟。

  1. Docker安装
    yum install -y yum-utilsyum-config-manager --add-repo https://docs.docker.com/v1.13/engine/installation/linux/repo_files/centos/docker.repoyum makecache fastyum list docker-engine.x86_64 --showduplicates |sort -rrpm -qa | grep docker*yum install -y docker-engine-1.12.6systemctl start dockersystemctl enable docker

    Kubernetes 1.6还没有针对docker 1.13和最新的docker 17.03上做测试和验证,所以这里安装Kubernetes官方推荐的Docker 1.12版本

  2. 添加kubernetes源
    cat >> /etc/yum.repos.d/kubernetes.repo <
    > /etc/sysctl.d/k8s.conf <
  3. 安装k8s服务
    yum install -y kubelet kubeadm kubectl kubernetes-cni
    systemctl enable kubelet.service
    systemctl restart kubelet.service
  4. 所有节点添加hosts
    cat >> /etc/hosts <<EOF
    10.10.24.237 k8s-master
    10.10.24.236 k8s-node-1
    10.10.24.232 k8s-node-2
    EOF
  5. 主节点初始化集群
    kubeadm init --kubernetes-version=v1.7.5 --pod-network-cidr=10.244.0.0/16 --apiserver-advertise-address=10.10.24.237
    网络问题无法从google下载容器镜像:
    [apiclient] Created API client, waiting for the control plane to become ready
    卡住需要执行kubeadm reset清理,重新执行
    init成功后k8s的核心组件均正常启动,以container的形式启动:ps -ef|grep kube
    为了使用kubectl访问apiserver,在~/.bash_profile中追加下面的环境变量:
    export KUBECONFIG=/etc/kubernetes/admin.conf
    source ~/.bash_profile
    此时kubectl命令在master node上就可以用了,查看一下当前机器中的Node:
    kubectl get nodes
  6. 向集群中添加节点
    将node1和node2加入集群,分别在node1和node2上执行:
    kubeadm join --token e7986d.e440de5882342711 10.10.24.237:6443
    使master node参与工作负载
    kubectl taint nodes --all node-role.kubernetes.io/master-
    使用kubeadm初始化的集群,出于安全考虑Pod不会被调度到Master Node上,也就是说Master Node不参与工作负载
  7. 所有节点安装flannel pod网络
    kubectl create -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel-rbac.yml
    kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml
    serviceaccount "flannel" created
    configmap "kube-flannel-cfg" created
    daemonset "kube-flannel-ds" created
    ps -ef|grep kube|grep flannel
    使用kubectl get pod --all-namespaces -o wide确保所有的Pod都处于Running
  8. 安装Dashboard插件
    wget https://raw.githubusercontent.com/kubernetes/dashboard/master/src/deploy/kubernetes-dashboard.yaml
    kubectl create -f kubernetes-dashboard.yaml
    kubectl create -f kube-dashboard-rbac.yml
    kind: ClusterRoleBindingapiVersion: rbac.authorization.k8s.io/v1beta1metadata:name: dashboard-adminroleRef:apiGroup: rbac.authorization.k8s.iokind: ClusterRolename: cluster-adminsubjects:- kind: ServiceAccountname: defaultnamespace: kube-system
    kube-dashboard-rbac.yml

    kubectl create -f dashboard-rbac.yml

  9. 在集群中运行Heapster 
    wget https://github.com/kubernetes/heapster/archive/v1.3.0.tar.gz
    tar -zxvf v1.3.0.tar.gz
    cd heapster-1.3.0/deploy/kube-config/influxdb
    kubectl create -f ./
    deployment "monitoring-grafana" created
    service "monitoring-grafana" created
    deployment "heapster" created
    service "heapster" created
    deployment "monitoring-influxdb" created
    service "monitoring-influxdb" created

转载于:https://www.cnblogs.com/Mrhuangrui/p/7805555.html

你可能感兴趣的文章
knockoutJS学习笔记04:监控属性
查看>>
18.10.6 考试总结
查看>>
iptables防火墙网路安全实践配置
查看>>
ASP.net Web窗体添加多条数据到数据库
查看>>
PHP面向对象(三)
查看>>
mysql与实际时间有8小时差怎么办
查看>>
docker 常用命令
查看>>
微信小程序 - 参数传递
查看>>
在Centos7上安装Oracle
查看>>
Linux下启动/关闭Oracle
查看>>
session和cookie的区别
查看>>
oracle 数据库、实例、服务名、SID
查看>>
web.xml文件的作用
查看>>
linux下oracle调试小知识
查看>>
alert弹出窗口,点击确认后关闭页面
查看>>
oracle问题之数据库恢复(三)
查看>>
单点登陆(SSO)
查看>>
HR,也确实“尽职尽责”
查看>>
MaxComputer 使用客户端配置
查看>>
20190823 顺其自然
查看>>