基于Centos7构建Kubernetes平台

一、实验环境

3centos7的主机

master 192.168.111.131部署etcd,kube-apiserver,kube-controller-manager,kube-scheduler 4个应用。

node01 192.168.111.130部署dockerkubeletkube-proxy 3个应用

node02 192.168.111.129部署dockerkubeletkube-proxy 3个应用

二、实验步骤

1.修改主机名和ip,三个主机网卡均设置为桥接模式,能够联网。

2.分别修改/etc/hosts文件:

Master配置

#vim /etc/hosts

dfb247d8c8f9030af158b80bc925744c.png

Node01

#scp root@192.168.111.128:/etc/hosts/etc/

Node02

#scp root@192.168.111.128:/etc/hosts/etc/

3.三台均设置防火墙的默认区域为trusted。

ee14913cda9e6136612838b5ea8cd43a.png

edc7c7a738f8d14ccddc6e9e3e6d68ff.png

6d0452b50002cb23ba7c252ebcfb2efd.png

4.三台均关闭selinux.

16ba9914cf30d9bd2c4c230190772897.png

5.安装docker,并启动。因为master之后还需要做registry仓库,所以也需要安装docker.

#yum install -y docker

0161d2899f51f7d83b2aa3e03cd32c43.png

6.开启路由转发功能

2b64e2e20511279cdccdb0763a6348b0.png

7实现node01node02之间容器互通

1node01node02新建网桥,并固定网桥ip

node01上操作

删除网桥docker0,新建网桥kbr0:

a57508bd2557d3e92e3bb233c65e6abc.png

新建网桥的配置文件:

e1bf0987bc4280d5f3681817a27b24ed.png

新建路由文件:route-eth0eth0node1上的网卡名。

045e9c72261ffc3bc8be0738f3567640.png

修改docker配置文件,添加-b=kbr0参数

7536fc560d9c7651dae4de5e517a8dfc.png

reboot重启系统使网桥设置生效。

2node02做同样的设置:

新建网桥:

902c7272873851e9f4947cf44ee7c250.png

新建网桥配置文件:

#scp root@192.168.111.129:/etc/sysconfig/network-scripts/ifcfg-kbr0 /etc/sysconfig/network-scripts/

e444a1d8153fb2960b172cb94376b220.png

创建路由文件:

04dcf0b497c6e0963068bf46571a89ec.png

修改docker 配置文件:

#vim /etc/sysconfig/docker

3fda716a39723b9a3f371e9db6b7e850.png

重启系统reboot.

3)系统启动之后,查看网卡信息和路由信息。

#ifconfig

423107baf316d4c890712cb519425e44.png

f89d381183e623b7c2973c4aaab0e1e5.png

4)验证两个宿主机间容器的互通性:

node01上运行一个容器:

b4515d46dbd4bbab91735bbb122548bc.png

node02上运行一个容器:

03624400d8d502816adc9f556ff6ec59.png

容器间互ping:

#docker run -it docker.io/centos:centos6

# yum install -y iputils 进入容器安装

7a48343bf4af234450f5292c0918faa1.png

#dcoker run -it docker.io/centos:centos6

190ef4aa5c21c3b94e4b092357a3bf16.png

master上部署应用:

1、安装etcd.

b2ec6adccb7b54d00444701bfb8bec39.png

查看etcd配置文件:

3547be473cfe7605b646fa6b7fb7cca0.png

2、修改配置文件:

117b4cc2efc38c06753eb82eef6843fb.png

3、启动etcd服务

44aafb9685afc5b045e900dbfdc2beb9.png

查看服务端口号

7cbbdbf3aa69eb516490d5e9c12b22d7.png

4、部署k8s-master组件(apiserver+controller-manager+scheduler

安装软件:

#yum install -y kubernetes-master

65bdc1f6c20f9fb86af9c59439d7d0c9.png

查看配置文件:

9f6e50472f9b1cb019cff62546d2b6a0.png

5修改配置文件:

#vim /etc/kubernetes/config

f8160a12218c224b2557aa95d513e933.png

解释:

KUBE_LOGTOSTDERR 日志设置

KUBE_LOG_KEVEL 日志级别设置

KUBE_ALLOW_PRIV 是否允许运行特权容器

KUBE_MASTER 主节点的地址,主要为replicationcontrollerschedulerkubelet可以顺利找到apiserver

#vim /etc/kubernetes/apiserver

f34a7f7536585e4053b5260459eaaa22.png

KUBE_API_ADDRESS监听的接口,如果配置为127.0.0.1则只监听localhost,配置为0.0.0.0会监听所有接口,这里配置为0.0.0.0

KUBE_API_PORT="--port=8080"apiserver的监听端口,默认8080,不用修改。

KUBELET_PORT="--kubelet_port=10250"kubelet监听的端口,默认10250,无需修改

KUBE_ETCD_SERVERS //指定etcd节点的地址

KUBE_SERVICE_ADDRESSES 这个是设置今后运行Service所在的ip网段

KUBE_API_ARGS=”--secure-port=0”默认是要求https安全通信,则不要求https安全通信

:这里需要注意原来KUBE_ADMISSION_CONTROL默认包含的要删掉,不然启动API server的时候会报错

6、启动服务:

5b8dd14a28f21aef29433d5e5d1f4eb8.png

查看服务端口:

63d2ba2c998cbfa73ba87301f2fe8d17.png

部署node主机:

1安装kubernetes-node软件

#yum install -y kubernetes-node

cc37a364afc6bac7462120e9047dd1c4.png

2修改配置文件:

#vim /etc/kubernetes/config

960aba70e03939223e9a4bdb51eb7102.png

#vim /etc/kubernetes/kubelet

4617ee2516c2d346177fcef4e549200c.png

配置项KUBELET_POD_INFRA_CONTAINER="--pod-infra-container-image=registry.access.redhat.com/rhel7/pod-infrastructure:latest"作用k8s创建pod的时候需要起一个基本容器,所以node节点要能连网。也可以自己搭建一个私有仓库,将pod-infrastructure:latest镜像上传到私有仓库中修改此配置文件的地址就可以

3、启动服务:

941a130a6a594b6f7fdf00339db79b30.png

4、在node02主机上重复上面的操作。

5master检查node 状态:

fd645fb0fefffb94c2f567d49b8fd16a.png

383c21067ee0922d81304ac0976cfe63.png

建私有仓库

Kubernetes管理容器如果是第一次操作,可能会有一定的等待时间,这是因为第一次下载images需要一段时间。如果本地没有docker registry,要确保节点能访问互联网,所以我们可以搭建一个私有仓库,由私有仓库提供所需要的镜像,

本实验环境中用kubernetes同时作为registry

1导入镜像:

0fb4f66daebd207bc5de445289b9af7a.png

2、基于私有仓库镜像运行容器

66b1d36919b589641fa594d6540523f4.png

3、本地访问私有仓库:

a66732ae83ba48d1a6dd2df0d8093eb5.png

4上传镜像到私有仓库

导入之后用到的镜像到本地

2a4a51981a656c6eea61a75e6a1fb21e.png

给基础镜像打个标签

5e927423385cf9e78bd916e03e296181.png

在三台主机上均修改docker 的配置文件,指定私有仓库的url.

b43a7c89dfa67d28876f2235f5e6816d.png

重启docker服务:

906ca0c0e995e10ebce97bf663f4f4c2.png

上传镜像到私有仓库并查看:

022afb8d27f67af86fe6c5812ecce871.png

测试,下载刚才上传的镜像:

deb2b7a58019d98c7c9829ccfd2f45b2.png

bac7fe1875675269eebb0b1d7392dea1.png

部署web应用

1为了部署pod的时候,下载镜像速度快点,把node节点主机配置文件中的pod镜像下载地址修改为本地私有仓库地址:

#vim /etc/kubernetes/kubelet

7c79026c79bda0eb2df7014d320e461c.png

#systemctl restart kubelet.service

2创建apache-rc.yaml文件,根据文件内容创建rcpod

859e50cb0790c2a919b501df31549f2f.png

注意:必须按照此格式编写否则会报错

#kubectl create -f apache-rc.yaml

error: error validating "apache-rc.yaml": error validating data: found invalid field spec for v1.ReplicationControllerSpec; if you choose to ignore these errors,turn validation off with --validate=false

8922902afa67688ccce834f574d00643.png

查看pods状态:

80f19fdbe81b01aec08306d69d9afd9d.png

查看pods详细状态:

18d8cc6694b9bee4754eac30b4d554f5.png

附:删除pod

kubectl delete pod podName

由于设置了两份副本,所以删除pod的时候,k8s会迅速起另外一个一模一样的pod以保持副本数量为2不变。

要彻底删除pod,只能删除创建它的replication controller

查看replication controller

kubectl get rc

删除replication controller

kubectl delete rc rcName

删除rc之后,其创建的pod会一并删除

3部署节点内部可访问的apache service

ServertypeClusterIPNodePort之分,缺省是ClusterIp,这种类型的service只能在集群内部访问

创建配置文件:

#vim apache-service-clusterip.yaml

918b925883281d36b5503a062c820c8a.png

创建service:

b2555de5ee8b225ff258c6d9ada2a1eb.png

查看service状态

928c44f47dc3015f42d1969c5bf498d4.png

验证apache服务:(在node节点执行)

d8f57ac4a6601bb5d896b09638e3d5dc.png

4部署外部可访问的apacheservice

创建nodeport类型的service .这种类型的Service在集群外部是可以访问

#vim apache-nodeport-service.yaml

ac10bb24a5849013e3c00de39e5cb1af.png

创建service:

716e73c2122df42822b97b9579994383.png

查看service:

c81450e7452d2a37414e9c5cdc5abf7c.png

验证service的可访问性

外部访问:

a4786eb847c076cea79de58f367bad67.png

dcfad9ef4b9b479aecf6eac2a7d02d79.png

内部访问:

92c7ae5dd5b86a6754d72cb94d5ad06d.png

到此为止kubernetes 集群搭建完毕!!!

基于 CentOS 7 搭建kubernetes集群的更多相关文章

  1. ios – Xcode找不到Alamofire,错误:没有这样的模块’Alamofire’

    我正在尝试按照github(https://github.com/Alamofire/Alamofire#cocoapods)指令将Alamofire包含在我的Swift项目中.我创建了一个新项目,导航到项目目录并运行此命令sudogeminstallcocoapods.然后我面临以下错误:搜索后我设法通过运行此命令安装cocoapodssudogeminstall-n/usr/local/bin

  2. ios – 1天后firebase crashlytics报告中没有数据

    解决方法对于那些仍然有问题的人.检查您的podfile中是否还有pod’Firebase/Crash’.当我删除旧的Firebase崩溃报告时,我的问题已修复.

  3. ios – 当我在xCode 5中验证我的应用程序时,获取错误的广告标识符[IDFA]错误

    在验证我的应用程序时,我收到错误消息“广告标识符使用不当.您的应用包含广告标识符[IDFA]API,但您尚未遵守iOS中的限制广告跟踪设置.”我在广告标识符的准备上传页面上检查了“是”.我在我的应用程序中使用revmob广告和flurry分析(COCOS2D-X项目).如何解决这个问题,我已经尝试了很多但没有成功.我使用下面的代码进入appdelegate但没有运气.解决方法这个IDFA问题今天仍

  4. 将POD规范属性与其Xcode配置中的不同构建设置相关联(例如,发布,调试)

    我正在尝试为现有的库项目创建POD规范.在Xcode项目中,构建设置为不同的构建配置定义了不同的预处理器宏例如:对于“调试”配置:对于“发布”配置:如何将这些设置映射到相应的POD规范?

  5. 你如何将xcode项目转换为cocoapod?

    我有一段代码,我发现我在多个不同的项目中重复使用,所以我想把它变成一个cocoapod并使用私人cocoapod仓库.我的问题是如何将xcode项目设置为cocoapod?它应该是一个静态库还是一个带有appdelegate的空“项目”?

  6. ios – 故事板UICollectionViewCell显示,然后变为空白

    问题:我在Storyboard/InterfaceBuilder上使用UIViewController,其中有一个UICollectionView,用于定义UICollectionViewCell.每当我在这个单元格中更改某些内容时,其所有子视图都会变为空白,从而无法看到任何内容.此外,当我更新约束时,即使我刷新,框架也不会移动,就像整个界面构建器被破坏一样.它只适用于这个UIViewContro

  7. ios – Xcode 7.3 – 警告未显示且无法搜索项目

    自从我升级到Xcode7.3后,我注意到在搜索我的工作区时总是得到“无结果”,并且警告窗格中也没有出现任何警告.偶尔它会工作几分钟而且会再次死亡.重新启动我的电脑,Xcode,并重新安装没有帮助.是否有其他人遇到此问题或找到解决方案/解决方法?

  8. ios – 与项目中包含的自定义框架共享cocoapods

    对于以下架构:_码___CustomFramework___ProjectA_____ProjectA_____Workspace_____Podfile_____Pods我正在使用ProjectA的工作区(由podfile生成),我在ProjectA中成功包含了CustomFramework,我可以使用ProjectA中的CustomFramework方法.现在,我想与CustomFramewo

  9. 通用iOS应用程序在TestFlight中的iPad Air 2上不兼容

    您应该为项目和目标设置“有效架构”:armv7,armv7s和arm64.

  10. ios – 如何在不创建新目标的情况下阻止`pod install`将libPods.a添加到“Link with Libraries”构建阶段?

    解决方法要防止集成,您可以使用:

随机推荐

  1. 在airgapped(离线)CentOS 6系统上安装yum软件包

    我有一个CentOS6系统,出于安全考虑,它已经被空气泄漏.它可能从未连接到互联网,如果有,它很长时间没有更新.我想将所有.rpm软件包放在一个驱动器上,这样它们就可以脱机安装而无需查询互联网.但是,我在测试VM上遇到的问题是,即使指定了本地路径,yum仍然会挂起并尝试从在线存储库进行更新.另外,有没有办法使用yum-utils/yumdownloader轻松获取该包的所有依赖项和所有依赖项?目前

  2. centos – 命名在日志旋转后停止记录到rsyslog

    CentOS6.2,绑定9.7.3,rsyslog4.6.2我最近设置了一个服务器,我注意到在日志轮换后,named已停止记录到/var/log/messages.我认为这很奇怪,因为所有日志记录都是通过rsyslog进行的,并且named不会直接写入日志文件.这更奇怪,因为我在更新区域文件后命名了HUPed,但它仍然没有记录.在我停止并重新启动命名后,记录恢复.这里发生了什么?

  3. centos – 显示错误的磁盘大小

    对于其中一个磁盘,Df-h在我的服务器上显示错误的空白区域:Cpanel表明它只有34GB免费,但还有更多.几分钟前,我删除了超过80GB的日志文件.所以,我确信它完全错了.fdisk-l/dev/sda2也显示错误:如果没有格式化,我该怎么做才能解决这个问题?并且打开文件描述符就是它需要使用才能做到这一点.所以…使用“lsof”并查找已删除的文件.重新启动写入日志文件的服务,你很可能会看到空间可用.

  4. 如何在centos 6.9上安装docker-ce 17?

    我目前正在尝试在centOS6.9服务器上安装docker-ce17,但是,当运行yuminstalldocker-ce时,我收到以下错误:如果我用跳过的标志运行它我仍然得到相同的消息,有没有人知道这方面的方法?

  5. centos – 闲置工作站的异常负载平均值

    我有一个新的工作站,具有不寻常的高负载平均值.机器规格是:>至强cpu>256GB的RAM>4x512GBSSD连接到LSI2108RAID控制器我从livecd安装了CentOS6.564位,配置了分区,网络,用户/组,并安装了一些软件,如开发工具和MATLAB.在启动几分钟后,工作站负载平均值的值介于0.5到0.9之间.但它没有做任何事情.因此我无法理解为什么负载平均值如此之高.你能帮我诊断一下这个问题吗?

  6. centos – Cryptsetup luks – 检查内核是否支持aes-xts-plain64密码

    我在CentOS5上使用cryptsetupluks加密加密了一堆硬盘.一切都很好,直到我将系统升级到CentOS6.现在我再也无法安装磁盘了.使用我的关键短语装载:我收到此错误:在/var/log/messages中:有关如何装载的任何想法?找到解决方案问题是驱动器使用大约512个字符长的交互式关键短语加密.出于某种原因,CentOS6中的新内核模块在由旧版本创建时无法正确读取512个字符的加密密钥.似乎只会影响内核或cryptsetup的不同版本,因为在同一系统上创建和打开时,512字符的密钥将起作用

  7. centos – 大量ssh登录尝试

    22个我今天登录CentOS盒找到以下内容这是过去3天内的11次登录尝试.WTF?请注意,这是我从我的提供商处获得的全新IP,该盒子是全新的.我还没有发布任何关于此框的内容.为什么我会进行如此大量的登录尝试?是某种IP/端口扫描?基本上有4名匪徒,其中2名来自中国,1名来自香港,1名来自Verizon.这只发生在SSH上.HTTP上没有问题.我应该将罪魁祸首子网路由吗?你们有什么建议?

  8. centos – kswap使用100%的CPU,即使有100GB的RAM也可用

    >Linux内核是否应该足够智能,只需从内存中清除旧缓存页而不是启动kswap?

  9. centos – Azure将VM从A2 / 3调整为DS2 v2

    我正在尝试调整前一段时间创建的几个AzureVM,从基本的A3和标准A3到标准的DS2v2.我似乎没有能力调整到这个大小的VM.必须从头开始重建服务器会有点痛苦.如果它有所不同我在VM中运行CentOS,每个都有一个带有应用程序和操作系统的磁盘.任何人都可以告诉我是否可以在不删除磁盘的情况下删除VM,创建新VM然后将磁盘附加到新VM?

  10. centos – 广泛使用RAM时服务器计算速度减慢

    我在非常具体的情况下遇到服务器速度下降的问题.事实是:>1)我使用计算应用WRF>2)我使用双XeonE5-2620v3和128GBRAM(NUMA架构–可能与问题有关!

返回
顶部