Rancher(V2.6.3)安装K8s教程

一,安装前环境准备:

1,升级Linux服务器内核

Ubuntu20.04:
#查看当前内核版本
uname -rs

#查看软件库中可下载的内核
sudo apt list | grep linux-generic*

如果已经是最新的就不必更新

#下载最新的内核(具体版本以软件库中为准)
sudo apt-get install linux-generic-hwe-20.04-edge/focal-updates

这里等它更新完毕后需要重启服务器,所以等下一步完成后一并重启检测

2,修改hostname

vim /etc/hostname 即可设置全限定域名,删除原有内容,输入完整的全限定域名保存退出即可,例如k8s-master。

修改后依然要重启才能生效

3,hosts设置

vim /etc/hosts 即可设置hosts。K8S集群一般包含多台计算机,hosts的内容应该包含集群内的所有机器。如:

在安装 Kubernetes(K8s)之前,配置 /etc/hosts 文件可以解决 Kubernetes 集群中的 DNS 问题。在 Kubernetes 集群中,DNS 负责将服务名称解析为对应的 IP 地址。在默认情况下,Kubernetes 使用一个名为 kube-dns 的组件作为集群的 DNS 服务器。这个组件通常会被部署在 Kubernetes 集群内部,并由 Kubernetes 自动配置其 DNS 解析规则。

在某些情况下,kube-dns 可能无法识别您的服务名称,从而导致服务无法被正确解析。这种情况通常发生在您的本地网络配置中存在一些问题,例如您的网络 DNS 服务器无法识别 Kubernetes 的服务名称。为了解决这个问题,您可以在您的主机上手动配置一个 DNS 解析规则,以便将 Kubernetes 的服务名称解析为正确的 IP 地址。

配置 /etc/hosts 文件是一种简单有效的方法,它可以将一个服务名称映射到一个 IP 地址。这样,在您的主机上执行 ping my-service 命令时,就会将该服务名称解析为对应的IP 地址,从而成功地访问该服务。

需要注意的是,对 /etc/hosts 文件的修改只会对当前主机生效。如果要在多台主机上部署 Kubernetes,需要在每台主机上都手动修改 /etc/hosts 文件,以便正确地解析 Kubernetes 的服务名称。另外,由于 /etc/hosts 文件通常是一个受保护的系统文件,因此在修改之前,请确保已经有相应的权限。

4,关闭防火墙

#uwf:
#开启防火墙
ufw enable
#关闭防火墙
ufw disable
#firewall
# 关闭防火墙
systemctl stop firewalld
# 关闭防火墙开机启动
systemctl disable firewalld

5,关闭selinux

Ubuntu20.04:
#查看SELinux状态
/usr/sbin/sestatus -v
#如果SELinux status参数为enabled即为开启状态

SELinux status: enabled

#也可以用这个命令
getenforce

临时关闭(不用重启机器):

#设置SELinux 成为permissive模式
setenforce 0
#设置SELinux 成为enforcing模式
setenforce 1

修改配置文件需要重启机器:

修改/etc/selinux/config 文件,将SELINUX=enforcing改为SELINUX=disabled。

vi /etc/selinux/config

重启机器即可

在安装 Rancher 和 Kubernetes 之前关闭 SELinux 是为了解决一些安全限制问题。SELinux(Security-Enhanced Linux)是一个 Linux 内核安全模块,用于限制程序对系统资源的访问和操作。它为 Linux 提供了更高的安全性和完整性,但有时候也会导致一些问题。

在 Rancher 和 Kubernetes 的安装过程中,可能会出现某些 SELinux 相关的问题,例如:

  • Rancher 系统初始化时可能会出现 SELinux 安全策略的限制,从而导致初始化失败;
  • Kubernetes 集群的某些组件可能会试图访问一些被 SELinux 限制的系统资源,从而导致组件无法正常启动。

为了解决这些问题,一种简单的方法是在安装 Rancher 和 Kubernetes 之前暂时关闭 SELinux。关闭 SELinux 可以暂时解除对系统资源的限制,从而使 Rancher 和 Kubernetes 的安装和初始化过程更容易成功。

6,关闭swap

Ubuntu20.04:

编辑/etc/fstab

vim /etc/fstab

找到如下行并把它注释掉,重启系统并验证

sudo swapon --show

如果已经关闭那么该命令不会有输出

如图为没关闭的:

下图是已关闭的:

7,安装Docker,版本选择为20.10.13,契合Rancher版本

Ubuntu20.04安装教程

Centos安装教程

二,安装Rancher

1,Docker安装Rancher

只需要其中一台机器安装Rancher,所以在机器中任选一台进行安装。

安装Rancher只需要执行如下命令:

docker run -d --restart=unless-stopped  --name rancher -p 8080:80 -p 8443:443 --privileged rancher/rancher:v2.6.3

然后打印日志查看Rancher是否运行成功,中途会有很多error,但是不必管它。

待日志结束后出现一下几行就代表运行成功,可以访问Rancher了

浏览器输入https://[你的IP]:8443访问Rancher

访问链接的时候会出现

点高级,无视风险继续访问。

2,配置Rancher

进入Rancher后会出现如下界面,根据操作提示完成即可。

docker logs  <container-id>  2>&1 | grep "Bootstrap Password:"

首先是从Rancher容器获得初始密码

输入密码点击登录,然后创建新密码

根据密码要求重置密码后,同意下方的使用要求,点击Continue。

进入主页面后,点击左上方,切换语言为中文

下面显示有一个local集群就证明Rancher已经安装成功了

三,Rancher搭建集群

如上图,点击创建集群

点击自定义:

给集群写好名字,选择k8s版本,这里选的是V1.19.16。

点击下一步后,进入添加主机命令页面。点选Etcd,Control Plane,Woker三个选项,然后复制下方的命令,到master节点执行。

点击下一步后,进入添加主机命令页面。点选Etcd,Control Plane,Woker三个选项,然后复制下方的命令,到master节点执行。

在执行的过程中需要等待很长的时间,中途在Rancher界面可能会看到报错信息,类似于以下两个。这是安装过程中会出现的。

Cluster must have at least one etcd plane host: please specify one or more etcd in cluster config

Cluster must have at least one etcd plane host: please specify one or more etcd in cluster config

判断集群是否安装成功只需要看日志。首先点击管理集群,点击自己刚创建的集群,点击Provisioning Log。

安装完成后会有如下日志。

四,在master节点上安装安装和配置kubectl工具

1,安装

在Ubuntu上可以通过以下命令安装。

snap install kubectl

另一种安装方法,在linux机器上执行以下命令下载:

curl -LO https://storage.googleapis.com/kubernetes-release/release/$(curl -s https://storage.googleapis.com/kubernetes-release/release/stable.txt)/bin/linux/amd64/kubectl
#授权
chmod +x kubectl
#将kubectl移动到可以全局访问的目录下
mv ./kubectl /usr/local/bin/
2,配置参数

在浏览集群中,点击刚创建好的集群

点击按钮复制配置文件

首先创建目录,复制yaml配置文件的内容,添加到config中然后保存:wq

mkdir ~/.kube
cd ~/.kube
vi config

然后执行命令就能看到我们刚创建的集群信息了

kubectl config get-contexts

Rancher(V2.6.3)安装K8s教程的更多相关文章

  1. 在 Ubuntu 上安装 K8S教程

    在 Ubuntu 上安装 K8S教程 1,更新系统源 如果系统本身自带得镜像地址,服务器在国外,下载速度会很慢,可以打开 /etc/apt/sources.lis 替换为国内得镜像源. apt upg ...

  2. kubernetes教程第一章-kubeadm高可用安装k8s集群

    目录 Kubeadm高可用安装k8s集群 kubeadm高可用安装1.18基本说明 k8s高可用架构解析 kubeadm基本环境配置 kubeadm基本组件安装 kubeadm集群初始化 高可用Mas ...

  3. 如何使用Rancher在OpenStack上创建K8S集群

    不可否认的是,OpenStack仍然是可行的云操作系统,并且被全世界许多互联服务提供商使用.而Rancher是业界最为广泛使用的Kubernetes管理平台,通过简洁直观的GUI集中管理企业IT中的多 ...

  4. Rancher 下图形界面 搭建 K8S 集群

    首先我们准备4台 2核3G 的 centos 7 温馨提示:先安装好一台 CentOS 的虚拟机,并且安装好 docker,永久关闭防火墙. 再这个基础上我们分别克隆出四台 Rancher.K8S1. ...

  5. 使用rke快速安装K8s集群

    操作系统 centos 7.5 yum update -y yum install docker -y 关闭防火墙.selinux 下载rke helm https://github.com/helm ...

  6. k8s教程

    k8s教程地址 安装https://github.com/gjmzj/kubeaszhttps://github.com/opsnull/follow-me-install-kubernetes-cl ...

  7. kubespray 一键安装k8s集群

    1. clone代码 git clone https://github.com/kubernetes-incubator/kubespray.git 2. 添加inventory/inventory ...

  8. [k8s]kubespray(ansible)自动化安装k8s集群

    kubespray(ansible)自动化安装k8s集群 https://github.com/kubernetes-incubator/kubespray https://kubernetes.io ...

  9. k8s-离线安装k8s

    1.开始 目标 coreos的igniton.json有很强的可配置性,通过安装时指定集群配置的ignition.json, 安装完成后打开https://{{Master_IP}}:6443/ui直 ...

  10. Pro Tools安装图文教程

    Pro Tools安装图文教程   Avid Pro Tools是Digidesign公司出品的一款音质最佳.音频制作强大的软件,能够在Mac或PC上为影片编曲.录制.编辑和混制高品质音乐或声音,生成 ...

随机推荐

  1. 零知识证明(Zero-Knowledge Proof)

    零知识证明(Zero Knowledge Proof)指的是,证明的人可以向验证的人,在不透露任何有用信息的情况下,使得验证者相信该结论是对的. 三种零知识证明技术:zk-SNARKs, Zk-STA ...

  2. 【JSON】Python读取JSON文件报错json.decoder.JSONDecodeError的问题

    报错 json.decoder.JSONDecodeError: Expecting property name enclosed in double quotes: line * column * ...

  3. 10s后再次获取手机验证码

    一般手机验证码获取都会加个间隔时间 js代码如下: function getDxCode(btn){ var reg = /^1[3|4|5|7|8][0-9]{9}$/; //验证规则 var mo ...

  4. Alibaba Cloud Linux 3.2104 64位安装php7.2.12

    1 安装php所需要的扩展 yum -y install libxml2 libxml2-devel openssl openssl-devel bzip2 bzip2-devel curl curl ...

  5. Nginx 监听同一端口号配置多个域名

    同一台nginx服务器通过配置多个server块实现在同一端口号下监听多个域名. 需要注意的是:端口号(listen)+主机名(server_name) 需要在多个server中唯一,否则会报错. 实 ...

  6. Typora 基本功能

    Typora 基本功能 typora 下载官网:https://www.typora.io/       "安装到C盘" 基本使用 1.该文件后缀 .md2.六级标题 :ctrl+ ...

  7. cmake 实现交叉编译注意事项

    (1)确保安装交叉编译工具安装成功 在终端输入arm-linux-gnueabihf-g++ -v 或 arm-linux-gnueabihf-gcc -v ,能看到相应交叉C编译器和C++编译器的版 ...

  8. egret tween 屏幕震动动画 ts

    let orig = { x: this.x, y: this.y }; var dir = 1; var tox = 0; var toy = 0; var count = 40; // if (n ...

  9. Navicat 通过ssh链接远程数据库

    首先需要下载一个Navicat数据库管理工具,有了Navicat工具需要完成一下步骤就可以实现本地链接远程数据库了 一.打开Navicat,点击连接按钮,找到MySQL并点击 二.点击"常规 ...

  10. 2020.4.2关于java.pta的总结

    0.前言 本文是有关pta2020.3至2020.4所有面向对象程序课程(java)共三次作业的阶段性总结,是java学习最开始起步时期的成果. 1.作业过程总结 这三次作业,是从c++过渡到java ...