Docker实践—CentOS7上部署Kubernetes详解

发布时间 - 2026-01-10 22:33:03    点击率:

Kubernetes架构

Kubernetes的整体架构如下:

Master为主控节点,上面运行apiserver,scheduler,controller-manager等组件。Minion相当于工作节点,上面运行kubelet,proxy,cAdvisor以及最重要的docker等组件。下面来实际部署一下这套集群管理工具。

环境

yy1  10.193.6.35

yy2  10.193.6.36

yy1作为master,yy2作为minion。

# cat /etc/centos-release

CentOS Linux release 7.0.1406 (Core) 

安装kubernetes

# curl https://copr.fedoraproject.org/coprs/eparis/kubernetes-epel-7/repo/epel-7/eparis-kubernetes-epel-7-epel-7.repo -o /etc/yum.repos.d/eparis-kubernetes-epel-7-epel-7.repo

# yum install kubernetes -y

配置yy1

# cat /etc/kubernetes/apiserver

###

# kubernetes system config

#

# The following values are used to configure the kubernetes-apiserver

#

 

# The address on the local server to listen to.

KUBE_API_ADDRESS="10.193.6.35"

 

# The port on the local server to listen on.

KUBE_API_PORT="8080"

 

# How the replication controller and scheduler find the apiserver

KUBE_MASTER="10.193.6.35:8080"

 

# Comma seperated list of minions

MINION_ADDRESSES="10.193.6.36"

 

# Port minions listen on

MINION_PORT="10250"

 

# cat /etc/kubernetes/config

###

# kubernetes system config

#

# The following values are used to configure various aspects of all

# kubernetes services, including

#

#  kubernetes-apiserver.service

#  kubernetes-controller-manager.service

#  kubernetes-kubelet.service

#  kubernetes-proxy.service

 

# Comma seperated list of nodes in the etcd cluster

KUBE_ETCD_SERVERS="http://10.193.6.35:4001"

 

# logging to stderr means we get it in the systemd journal

KUBE_LOGTOSTDERR="true"

 

# journal message level, 0 is debug

KUBE_LOG_LEVEL=0

 

# Should this cluster be allowed to run privleged docker containers

KUBE_ALLOW_PRIV="true"

启动yy1上相关服务

master上需要运行etcd,kube-apiserver,kube-controller-manager,kube-scheduler这4个进程。

for SERVICES in etcd kube-apiserver kube-controller-manager kube-scheduler; do

  systemctl restart $SERVICES

  systemctl enable $SERVICES

  systemctl status $SERVICES

done

配置yy2

# cat /etc/kubernetes/kubelet

###

# kubernetes kublet (minion) config

 

# The address for the info server to serve on

MINION_ADDRESS="10.193.6.36"

 

# The port for the info server to serve on

MINION_PORT="10250"

# You may leave this blank to use the actual hostname

MINION_HOSTNAME="10.193.6.36"

# cat /etc/kubernetes/config 

###

# kubernetes system config

#

# The following values are used to configure various aspects of all

# kubernetes services, including

#

#  kubernetes-apiserver.service

#  kubernetes-controller-manager.service

#  kubernetes-kubelet.service

#  kubernetes-proxy.service

# Comma seperated list of nodes in the etcd cluster

KUBE_ETCD_SERVERS="http://10.193.6.35:4001"

 

# logging to stderr means we get it in the systemd journal

KUBE_LOGTOSTDERR="true"

# journal message level, 0 is debug

KUBE_LOG_LEVEL=0

# Should this cluster be allowed to run privleged docker containers

KUBE_ALLOW_PRIV="true"

修改yy2 kubelet的配置

CentOS7上没有docker.socket服务,注释掉kubelet中对docker.socket的依赖。

/usr/lib/systemd/system/kubelet.service

[Unit]

Description=Kubernetes Kubelet

#After=docker.socket cadvisor.service

After=cadvisor.service

#Requires=docker.socket cadvisor.service

Requires=cadvisor.service

启动yy2上的相关服务

minion上需要运行kube-proxy,kubelet以及docker。

for SERVICES in kube-proxy kubelet docker; do 
  systemctl restart $SERVICES
  systemctl enable $SERVICES
  systemctl status $SERVICES 
done

创建pod描述文件

创建一个apache的pod描述文件。

# cat apache.json

{

 "id": "apache",

 "desiredState": {

  "manifest": {

   "version": "v1beta1",

   "id": "apache-1",

   "containers": [{

    "name": "master",

    "image": "fedora/apache",

    "ports": [{

     "containerPort": 80,

     "hostPort": 80

    }]

   }]

  }

 },

 "labels": {

  "name": "apache"

 }

} 

创建pod

通过客户端工具kubecfg提交任务给apiserver,由scheduler选择一个minion部署容。

[root@yy1 ~]# kubecfg -c apache.json create pods

I0925 06:43:26.768122 09313 request.go:292] Waiting for completion of /operations/1

ID         Image(s)      Host        Labels       Status

----------     ----------     ----------     ----------     ----------

apache       fedora/apache    /          name=apache     Waiting

 

[root@yy1 ~]# kubecfg list pods 

ID         Image(s)      Host        Labels       Status

----------     ----------     ----------     ----------     ----------

apache       fedora/apache    10.193.6.36/    name=apache     Waiting

apache服务会自动部署到机器yy2,yy2上的docker会自动下载image,然后启动apache服务。顺利的话,过一会儿,apache服务就会在yy2上起来。

[root@yy1 ~]# kubecfg list pods 

ID         Image(s)      Host        Labels       Status

----------     ----------     ----------     ----------     ----------

apache       fedora/apache    10.193.6.36/    name=apache     Running

可以尝试访问一下,

 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# centos安装kubernetes  # kubernetes  # 安装部署  # CentOS部署Kubernetes  # 聊聊kubernetes1.20用containerd替换docker(shim)的问题  # 使用 kind 和 Docker 启动本地的 Kubernetes环境  # centos7搭建docker私人仓库的方法(kubernetes)  # docker kubernetes dashboard安装部署详细介绍  # Docker和Kubernetes中使用代理IP的操作方法  # 最重要  # 会在  # 这套  # 中对  # 创建一个  # 会儿  # 大家多多  # 客户端  # system  # config  # repos  # install  # values  # local  # server  # configure  # address  # yum  # org  # coprs 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel如何连接多个数据库_Laravel多数据库连接配置与切换教程  如何在阿里云完成域名注册与建站?  大学网站设计制作软件有哪些,如何将网站制作成自己app?  Gemini怎么用新功能实时问答_Gemini实时问答使用【步骤】  如何用虚拟主机快速搭建网站?详细步骤解析  html5的keygen标签为什么废弃_替代方案说明【解答】  Laravel如何实现用户注册和登录?(Auth脚手架指南)  微信小程序 input输入框控件详解及实例(多种示例)  Laravel怎么解决跨域问题_Laravel配置CORS跨域访问  今日头条微视频如何找选题 今日头条微视频找选题技巧【指南】  javascript中对象的定义、使用以及对象和原型链操作小结  如何在腾讯云服务器快速搭建个人网站?  专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?  大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊?  Laravel怎么调用外部API_Laravel Http Client客户端使用  微信小程序 五星评分(包括半颗星评分)实例代码  Laravel Blade组件怎么用_Laravel可复用视图组件的创建与使用  Laravel如何使用Eloquent ORM进行数据库操作?(CRUD示例)  如何在 Python 中将列表项按字母顺序编号(a.、b.、c. …)  厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?  java ZXing生成二维码及条码实例分享  Laravel如何使用withoutEvents方法临时禁用模型事件  品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?  利用vue写todolist单页应用  Laravel怎么实现API接口鉴权_Laravel Sanctum令牌生成与请求验证【教程】  JavaScript中的标签模板是什么_它如何扩展字符串功能  Laravel如何使用Gate和Policy进行权限控制_Laravel权限判定与策略规则配置  C++时间戳转换成日期时间的步骤和示例代码  网站优化排名时,需要考虑哪些问题呢?  Laravel模型关联查询教程_Laravel Eloquent一对多关联写法  网页制作模板网站推荐,网页设计海报之类的素材哪里好?  Python高阶函数应用_函数作为参数说明【指导】  LinuxCD持续部署教程_自动发布与回滚机制  Win11怎么恢复误删照片_Win11数据恢复工具使用【推荐】  佐糖AI抠图怎样调整抠图精度_佐糖AI精度调整与放大细化操作【攻略】  青岛网站建设如何选择本地服务器?  Laravel如何配置任务调度?(Cron Job示例)  javascript中闭包概念与用法深入理解  谷歌浏览器如何更改浏览器主题 Google Chrome主题设置教程  打造顶配客厅影院,这份100寸电视推荐名单请查收  php做exe能调用系统命令吗_执行cmd指令实现方式【详解】  HTML 中如何正确使用模板变量为元素的 name 属性赋值  HTML透明颜色代码怎么让图片透明_给img元素加透明色的技巧【方法】  Laravel如何实现多语言支持_Laravel本地化与国际化(i18n)配置教程  ,交易猫的商品怎么发布到网站上去?  Laravel distinct去重查询_Laravel Eloquent去重方法  网站制作报价单模板图片,小松挖机官方网站报价?  如何在IIS管理器中快速创建并配置网站?  北京网页设计制作网站有哪些,继续教育自动播放怎么设置?  Win11怎么查看显卡温度 Win11任务管理器查看GPU温度【技巧】