mac本地搭建k8s集群环境

[TOC]

1、基础环境准备

  1. 必备软件

VirtualBox: https://download.virtualbox.org/virtualbox/5.2.14/VirtualBox-5.2.14-123301-OSX.dmg

Centos7-Minimal: http://mirrors.aliyun.com/centos/7/isos/x86_64/CentOS-7-x86_64-Minimal-1804.iso

k8s.1-10-4.tar.gz: https://pan.baidu.com/s/1c4RFaA

kubeasz: https://github.com/gjmzj/kubeasz.git

  1. 三台虚拟机安装

    • 推荐内存2G/硬盘20G以上
    • 最小化安装CentOS7-Minimal
    • 安装过程中需输入root密码
  2. 网络配置,并设置主机免密登陆

    虚拟机安装完成后关闭,并配置网卡2网卡3如下:

    001配置网卡02.png
    001配置网卡01.png

    通过命令ip addr|grep 192获取主机IP:

    192.168.56.102/24

    192.168.56.103/24

    192.168.56.104/24

    主机hostname与ip关系如下:

    IP hostname node
    192.168.56.102 node01 master
    192.168.56.103 node02 slave
    192.168.56.104 node03 slave

    设置hostname:

    yudeMacBook-Pro:.ssh yufeng$ ssh root@192.168.56.102
    root@192.168.56.102's password: 
    Last login: Thu Jul 12 02:47:14 2018 from 192.168.56.1
    [root@node01 ~]# hostnamectl set-hostname node01
    [root@node01 ~]# hostname
    node01
    

    vi /etc/hosts,增加:

    192.168.56.102 node1
    192.168.56.103 node2
    192.168.56.104 node3
    

    设置主机免密登陆:

    # 配置ansible ssh密钥登陆
    ssh-keygen -t rsa -b 2048 #回车 回车 回车
    ssh-copy-id node1 #按照提示输入yes 和root密码
    ssh-copy-id node2 
    ssh-copy-id node3
    #验证免密登陆:
    [root@node01 ~]# ssh node2
    Last login: Thu Jul 12 03:30:05 2018 from node1
    
  3. 安装基本软件

    # 文档中脚本默认均以root用户执行
    # 安装epel源并更新
    cat <<EOF > /etc/yum.repos.d/kubernetes.repo
    [kubernetes]
    name=Kubernetes
    baseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64/
    enabled=1
    gpgcheck=1
    repo_gpgcheck=1
    gpgkey=https://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg https://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpg
    EOF
    yum install epel-release -y
    yum update
    # 安装依赖工具
    yum install git python python-pip -y
    # 安装ansible (国内如果安装太慢可以直接用pip阿里云加速)
    #pip install pip --upgrade
    #pip install ansible
    pip install pip --upgrade -i http://mirrors.aliyun.com/pypi/simple/ --trusted-host mirrors.aliyun.com
    pip install --no-cache-dir ansible -i http://mirrors.aliyun.com/pypi/simple/ --trusted-host mirrors.aliyun.com
    

2、k8s集群安装

  1. 利用kubeasz安装集群

    git clone https://github.com/gjmzj/kubeasz.git
    mkdir -p /etc/ansible
    cp -fr kubeasz/* /etc/ansible
    # 下载已打包好的binaries,解压到/etc/ansible/bin目录
    # 国内请从分享的百度云链接下载 https://pan.baidu.com/s/1c4RFaA
    # 如果你有合适网络环境也可以按照/down/download.sh自行从官网下载各种tar包到 ./down目录,并执行download.sh
    #scp ./Downloads/k8s.1-10-4.tar.gz root@192.168.56.102:///root
    tar zxvf k8s.1-10-4.tar.gz
    cp -fr bin/* /etc/ansible/bin
    # 配置ansible的hosts文件
    cd /etc/ansible
    cp example/hosts.allinone.example hosts # 然后根据实际情况修改此hosts文件,所有节点改成本虚机IP
    # 开始集群安装,如果你对集群安装流程不熟悉,请阅读分步安装讲解后一步一步安装,并对每步都进行验证
    # 分步安装
    ansible-playbook 01.prepare.yml
    ansible-playbook 02.etcd.yml
    ansible-playbook 03.docker.yml
    ansible-playbook 04.kube-master.yml
    ansible-playbook 05.kube-node.yml
    ansible-playbook 06.network.yml
    ansible-playbook 07.cluster-addon.yml
    # 一步安装
    #ansible-playbook 90.setup.yml
    
  1. 验证安装:

    # 如果提示kubectl: command not found,退出重新ssh登陆一下,环境变量生效即可
    kubectl version
    kubectl get componentstatus # 可以看到scheduler/controller-manager/etcd等组件 Healthy
    kubectl cluster-info # 可以看到kubernetes master(apiserver)组件 running
    kubectl get node # 可以看到单 node Ready状态
    kubectl get pod --all-namespaces # 可以查看所有集群pod状态
    kubectl get svc --all-namespaces # 可以查看所有集群服务状态
    

  2. 访问dashboard:

    [root@node1 ansible]# kubectl get pod --all-namespaces -o wide|grep dashboard
    kube-system   kubernetes-dashboard-66c9d98865-rsdzz   1/1       Running   0          8m        172.20.2.3       192.168.56.103
    [root@node1 ansible]# kubectl get svc --all-namespaces -o wide|grep dashboard
    kube-system   kubernetes-dashboard   NodePort    10.68.200.74    <none>        443:28523/TCP   8m        k8s-app=kubernetes-dashboard
    

    通过上述两条命令获取kubernetes-dashboard pod所在的node ip192.168.56.103以及端口28523,访问https://192.168.56.103:28523/,添加浏览器信任后,选择令牌登陆,通过kubectl -n kube-system describe secret $(kubectl -n kube-system get secret | grep admin-user | awk '{print $1}')复制冒号后的全部字符并粘贴到dashboard,点击登陆:

    002dashboard令牌登陆.png
    登陆成功后可以看到集群的监控,如果为节点视图:
    003登陆成功.png

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,294评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,493评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,790评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,595评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,718评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,906评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,053评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,797评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,250评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,570评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,711评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,388评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,018评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,796评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,023评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,461评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,595评论 2 350

推荐阅读更多精彩内容