CentOS76 安装k8s1.18的简单步骤
1. 前提条件就不再详细描写了:
关闭防火墙
升级内核到至少4.
关闭swap
关闭selinux 等
2. 本次安装采用酸酸乳和privoxy的方式进行, 不过发现部分rpm 包还是特别慢,没办法用vps从境外下载rpm包进行安装.
酸酸乳的方式不在描述
我这边是买了一个 某商的月5.88刀的service
设置到CentOS的服务器上面
然后设置privoxy
设置 proxy
我还有有一个年费49刀的vps
(自费 !-_-!)
3. 发现docker iamges 可以pull 但是 rpm包 下载实在是非常非常的缓慢, 没办法 改用某商vps下载rpm包
在 vps 上面上 首先创建 rpm 源
vim /etc/yum.repos.d/kubernetes.repo 添加内容 [kubernetes]
name=Kubernetes
baseurl=https://packages.cloud.google.com/yum/repos/kubernetes-el7-x86_64
enabled=
gpgcheck=
repo_gpgcheck=
gpgkey=https://packages.cloud.google.com/yum/doc/yum-key.gpg https://packages.cloud.google.com/yum/doc/rpm-package-key.gpg
exclude=kube*
下载最新的rpm包
yumdownloader kubelet-1.18.- kubectl-1.18.- kubeadm-1.18. --disableexcludes=kubernetes
将下载好的文件放到 安装好 酸酸乳的centos服务器上面
4. centos 上面安装这三个包
yum localinstall *.rpm
5. kubeadm 进行初始化
kubeadm init --pod-network-cidr=10.244.0.0/ 注意如果之前有 kubeadm的集群的化 需要先执行
kubeadm reset
等待教程时间就可以完成操作了 注意 这个时候需要能连网下载部分images才可以
注意设置好了之后需要进行一下 配置文件更新
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
这样就可以直接执行命令
kubectl get nodes
注意单节点测试服务时需要将master节点设置能够部署pod
kubectl taint nodes --all node-role.kubernetes.io/master-
不然无法使用.
另外部署calico 时 要保证 80端口不被占用
lsof -i:80
如果端口被占用 会造成 pod无法正常开启.
6. 安装calico
一般说 flannel的性能不如calico 所以这次实验改用 calico
建议还是在能上外网的情况下进行 获取配置文件
mkdir /root/calico
wget -c https://docs.projectcalico.org/v3.8/getting-started/kubernetes/installation/hosted/kubernetes-datastore/calico-networking/1.7/calico.yaml
下载完成之后执行命令
kubectl apply -f calico.yaml
7. 安装ingress-nginx
mkdir /root/ingress-nginx
wget https://raw.githubusercontent.com/kubernetes/ingress-nginx/master/deploy/static/mandatory.yaml 修改一下配置文件 在 image 上一层的配置文件加上
hostNetwork: true
使之能够提供服务
注意层级与containers 这一层相同
spec:
# wait up to five minutes for the drain of connections
terminationGracePeriodSeconds:
serviceAccountName: nginx-ingress-serviceaccount
hostNetwork: true
nodeSelector:
kubernetes.io/os: linux
containers:
- name: nginx-ingress-controller
image: quay.io/kubernetes-ingress-controller/nginx-ingress-controller:0.30.0 然后一样的执行一下 kubectl apply -f manadatory.yaml 即可
8. 重启一下服务器进行验证
我这边的效果为
[root@k8s143 ingress-nginx]# kubectl get nodes
NAME STATUS ROLES AGE VERSION
k8s143 Ready master 51m v1.18.0
[root@k8s143 ingress-nginx]# kubectl get pods --all-namespaces
NAMESPACE NAME READY STATUS RESTARTS AGE
ingress-nginx nginx-ingress-controller-77db54fc46-cfnsl / Running 34m
kube-system calico-kube-controllers-77c5fc8d7f-pwk68 / Running 26m
kube-system calico-node-lsqg2 / Running 26m
kube-system coredns-66bff467f8-gv4m7 / Running 51m
kube-system coredns-66bff467f8-hnrxb / Running 51m
kube-system etcd-k8s143 / Running 51m
kube-system kube-apiserver-k8s143 / Running 51m
kube-system kube-controller-manager-k8s143 / Running 51m
kube-system kube-proxy-hx74q / Running 51m
kube-system kube-scheduler-k8s143 / Running 51m
[root@k8s143 ingress-nginx]#
9. 下载好的 images和rpm包如下
REPOSITORY TAG IMAGE ID CREATED SIZE
calico/node v3.8.8- 3610c051aa19 days ago 192MB
calico/cni v3.8.8- ca2a236d9210 days ago 161MB
calico/kube-controllers v3.8.8 7125b7d47e9f days ago .9MB
k8s.gcr.io/kube-proxy v1.18.0 43940c34f24f days ago 117MB
k8s.gcr.io/kube-controller-manager v1.18.0 d3e55153f52f days ago 162MB
k8s.gcr.io/kube-apiserver v1.18.0 74060cea7f70 days ago 173MB
k8s.gcr.io/kube-scheduler v1.18.0 a31f78c7c8ce days ago .3MB
calico/pod2daemon-flexvol v3.8.8 cacd6d732f12 weeks ago .38MB
quay.io/kubernetes-ingress-controller/nginx-ingress-controller 0.30. 89ccad40ce8e weeks ago 323MB
k8s.gcr.io/pause 3.2 80d28bedfe5d weeks ago 683kB
k8s.gcr.io/coredns 1.6. 67da37a9a360 months ago .8MB
sapcc/tiller v2.15.2 9bdad03644c7 months ago .1MB
k8s.gcr.io/etcd 3.4.- 303ce5db0e90 months ago 288MB
需要的rpm包为
-rw-r--r-- root root Apr : 2d6ec4ae24a355c5818174f39e212f116cbd796cabcc113a68fc613d3d1fe147-kubeadm-1.18.-.x86_64.rpm
-rw-r--r-- root root Apr : 3d1298e3f34961565204febc5da169d1ac3673b7eb772a7bc19c2b310526b0e8-kubelet-1.18.-.x86_64.rpm
-rw-r--r-- root root Apr : cf6754a3497c5c05de050f2409eb3b2854467967cf359a8ed9c6e6c32808c7de-kubectl-1.18.-.x86_64.rpm
CentOS76 安装k8s1.18的简单步骤的更多相关文章
- Flume1.9.0的安装、部署、简单应用(含分布式、与Hadoop3.1.2、Hbase1.4.9的案例)
目录 目录 前言 什么是Flume? Flume的特点 Flume的可靠性 Flume的可恢复性 Flume的一些核心概念 Flume的官方网站在哪里? Flume在哪里下载以及如何安装? 设置环境变 ...
- VMware 安装CentOS 6.5图文步骤 以及安装后无法联网的解决办法
一.VMwareWorkstation10 中安装Centos6.5(64位)步骤: 首先下载vmware 和centos6.5 1. 打开VMware-workstation点击“新建虚拟机”,到向 ...
- dell 7559 安装Manjaro 18
本来是装黑苹果的,折腾好几天都装好了,是可以正常使用的,可是clover始终有一个问题,每次启动前需要覆盖一遍EFI分区内EFI目录的CLOVER目录内的所有文件,方能引导MAC. 不然就卡Init ...
- linux下vsftpd的安装及配置使用详细步骤(推荐)
vsftpd 是“very secure FTP daemon”的缩写,安全性是它的一个最大的特点. vsftpd 是一个 UNIX 类操作系统上运行的服务器的名字,它可以运行在诸如 Linux.BS ...
- eclipse安装Axis2插件和简单的webservice发布
2019独角兽企业重金招聘Python工程师标准>>> Axis2与CXF是现在很主流的WebService开发框架(java6也已经支持了),项目上还都是基本上用前两种做开发,今天 ...
- Nodejs学习笔记(1) Nodejs安装+借助express模块简单部署服务器
1 安装 1.1 下载和安装 1.2 什么是REPL?如何使用? 1.3 npm对单一模块的安装和删除功能 1.4 通过package.json自定义模块(安装模块) 1.5 设置全局目录 2 部署网 ...
- 使用autotools工具用configure、make、make install编译安装linux工程的详细步骤
使用autotools工具用configure.make.make install编译安装linux工程的详细步骤 转载tmxkwzy 最后发布于2016-11-24 10:20:15 阅读数 324 ...
- kubespray-2.14.2安装kubernetes-1.18.10(ubuntu-20.04.1)
欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...
- VirtualBox安装Debian6的方法和步骤(详细)
下面是用VirtualBox安装Debian6的方法和步骤 l 新建一个文件夹,用于存放虚拟硬盘,如Debian l 打开VirtualBox,点击新建 l 输入虚拟机名称,Debian_6 l 给虚 ...
随机推荐
- Web图片资源的加载与渲染时机
此文研究页面中的图片资源的加载和渲染时机,使得我们能更好的管理图片资源,避免不必要的流量和提高用户体验. 浏览器的工作流程 要研究图片资源的加载和渲染,我们先要了解浏览器的工作原理.以Webkit引擎 ...
- 使用 Hexo 创建项目文档网站
当我们发布一个开源项目的时候,最重要的事情之一就是要创建项目文档.对使用项目的用户来说,文档是非常有必要的,通常我们可以使用下面这些方式来创建文档: GitHub Wiki:在 Github 上我们可 ...
- 关于localStorage面试的那点事
最近面试的时候关于html5API总会被问到localStorage的问题, 对于一般的问题很简单,无非就是 localStorage.sessionStorage和cookie这三个客户端缓存的区别 ...
- 原型模式故事链(3)--JS的数据类型、以及区别、区分、转化
上一章--原型链讲解:传送门:https://segmentfault.com/a/11... 在上一章讲解原型链时提到了:所有的引用类型都有一个_proto_属性,称之为隐式原型.那么引用类型是什么 ...
- 关于css 的垂直居中
对于元素的水平居中,我根据我自己之前的一些学习来进行一些总结,如果有不对的地方,欢迎指正~ 一.让大小不固定的元素垂直居中 因为:表格的单元格的特别属性:垂直居中等: `div.parent { di ...
- 《第31天:JQuery - 轮播图》
源码下载地址:链接:https://pan.baidu.com/s/16K9I... 提取码:0ua2 写这篇文章,当做是对自已这一天的一个总结.写轮播图要准备的东西:三张尺寸大小一样的图片.分为三个 ...
- Sketchup二次开发教程
Sketchup提供了两套API: C API,主要用于读写SU文件.我们的SU文件导入功能就是用这套API做的 Ruby API,用于开发SU插件 这次我们主要关注Ruby API,因为它是实现更丰 ...
- 群ping
找出单位内所有电脑手机 通常情况下,ping只能ping一个IP地址.一个网络值班只有255台电脑,除非是大的网络断,把子网掩码改了,可以扩充更多电脑.如: 如果我们要一次性检查内网所有机器,则可以输 ...
- RocketMQ-2.RocketMQ的负载均衡
目录 RocketMQ的负载均衡 producer对MessageQueue的负载均衡 producer负载均衡 系统计算路由MessageQueue 自定义路由MessageQueue Consum ...
- Oracle根据实体类比对2个数据库结构差异(demo)
源起 在公司做项目时 经常出现 实体结构和线上的数据结构以及公司开发库数据结构不匹配的问题 但是又不能直接把开发库导入到生产库因为生产库已经有实际数据了 所以弄了一个小工具 此处只做记录用 demo级 ...