kubernetes部署微服务_kubernetes离线安装

kubernetes部署微服务_kubernetes离线安装微服务之容器化技术—kubernetes的安装

大家好,又见面了,我是你们的朋友全栈君。

Kubernetes的安装

配置集群时注意:时间同步

环境准备

三台机器

kube1-master:192.168.3.166
kube2-node1:192.168.3.242
kube3-node2:192.168.3.190

配置主机名(/etc/hostname)

  • 192.168.3.166(作为master)
> vim /etc/hostname
kube1-master
  • 192.168.3.242(作为node1)
> vim /etc/hostname
kube2-node1
  • 192.168.3.190(作为node2)
> vim /etc/hostname
kube3-node2

配置hosts(/etc/hosts)

  • 192.168.3.166(作为master)
> vim /etc/hosts
192.168.3.166 kube1-master
192.168.3.242 kube2-node1
192.168.3.190 kube3-node2
  • 192.168.3.242(作为node1)
> vim /etc/hosts
192.168.3.166 kube1-master
192.168.3.242 kube2-node1
192.168.3.190 kube3-node2
  • 192.168.3.190(作为node2)
> vim /etc/hosts
192.168.3.166 kube1-master
192.168.3.242 kube2-node1
192.168.3.190 kube3-node2

配置完成后,重启计算机,可以相互ping,如果可以ping通,则表示配置成功。

配置master

配置仓库

  • 获取docker repo
> cd /etc/yum.repos.d
> wget https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
> # 查询docker-ce可用版本
> yum list docker-ce --showduplicates|sort -r
  • 获取kubernetes
> vim kubernetes.repo
[kubernetes]
name=Kubernetes Repo
baseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64/
gpgcheck=1
gpgkey=https://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg
enabled=1
> :wq(保存退出)
> yum repolist

开始安装

> yum install docker-ce kubelet kubeadm kubectl

这样虽然可以安装,但是后续会出现docker和kubernetes版本不兼容的问题,kubernetes的当前stable版本是V1.12.2,docker的当前stable版本是V18.09,但是kubernetes V1.12.2并不兼容docker V18.09,而只支持docker V18.06,所以需要指定docker的版本,如下:

> yum install docker-ce-18.06.1.ce

安装完成后需要配置国内镜像,否则会出现下载速度很慢或者有的镜像无法获取的现象,配置镜像的方法如下:

> cd /etc/docker
{
  "registry-mirrors": ["https://krg1ud1i.mirror.aliyuncs.com"]
}
> systemctl daemon-reload
> systemctl restart docker

安装过程中会出现gpgcheck错误的问题,可以用如下方法解决:

> wget https://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg
> rpm --import yum-key.gpg
> wget https://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpg
> rpm --import rpm-package-key-gpg

继续安装,则安装成功!

修改相关配置文件

修改docker配置文件
> vim /usr/lib/systemd/system/docker.service
# 在ExecStart上面增加如下语句
Environment="HTTPS_PROXY=http://www.ik8s.io:10080" 
Environment="NO_PROXY=127.0.0.0/8,172.20.0.0/16"

修改完成后,启动docker

> systemctl daemon-reload
> systemctl start docker
> cat /proc/sys/net/bridge/bridge-nf-call-ip6tables
> 1
> cat /proc/sys/net/bridge/bridge-nf-call-iptables
> 1

确保这两个文件存储的都是1,就不用改了。
到这里,docker的配置修改完成。

修改kubernetes配置文件

首先使用如下命令查看:

> rpm -ql kubelet
> cat /etc/sysconfig/kubelet

启动kubelet

# 启动kubelet
> systemctl start kubelet
# 查看kubelet状态
> systemctl status kubelet
# 为失败:code=exited,status=255

使用如下命令查看:

> tail /var/log/messages

打印如下错误信息:

Nov 10 23:31:53 bigdata kubelet: F1110 23:31:53.115865    4150 server.go:190] failed to load Kubelet config file /var/lib/kubelet/config.yaml, error failed to read kubelet config file "/var/lib/kubelet/config.yaml", error: open /var/lib/kubelet/config.yaml: no such file or directory

这个时候,先停止kubelet:

> systemctl stop kubelet

设置开机自启动:

> systemctl enable kubelet
> systemctl enable docker
kubeadm 初始化

配置忽略kubelet:

> vim /etc/sysconfig/kubelet
KUBELET_EXTRA_ARGS="--fail-swap-on=false"

执行初始化命令前,需要先拉取镜像,因为这些镜像无法从国内docker镜像加速器获取

> kubeadm config images list

显示需要拉取的镜像:

k8s.gcr.io/kube-apiserver:v1.12.2
k8s.gcr.io/kube-controller-manager:v1.12.2
k8s.gcr.io/kube-scheduler:v1.12.2
k8s.gcr.io/kube-proxy:v1.12.2
k8s.gcr.io/pause:3.1
k8s.gcr.io/etcd:3.2.24
k8s.gcr.io/coredns:1.2.2

这里采用先从国内镜像加速器获取这些镜像,然后使用tag标记为kubernetes的镜像tag:

  • 先从国内镜像加速器获取镜像:
docker pull mirrorgooglecontainers/kube-apiserver:v1.12.2
docker pull mirrorgooglecontainers/kube-controller-manager:v1.12.2
docker pull mirrorgooglecontainers/kube-scheduler:v1.12.2
docker pull mirrorgooglecontainers/kube-proxy:v1.12.2
docker pull mirrorgooglecontainers/pause:3.1
docker pull mirrorgooglecontainers/etcd:3.2.24
docker pull coredns/coredns:1.2.2
  • 再标记为kubernetes的镜像tag
docker tag mirrorgooglecontainers/kube-apiserver:v1.12.2 k8s.gcr.io/kube-apiserver:v1.12.2
docker tag mirrorgooglecontainers/kube-controller-manager:v1.12.2 k8s.gcr.io/kube-controller-manager:v1.12.2
docker tag mirrorgooglecontainers/kube-scheduler:v1.12.2 k8s.gcr.io/kube-scheduler:v1.12.2
docker tag mirrorgooglecontainers/kube-proxy:v1.12.2 k8s.gcr.io/kube-proxy:v1.12.2
docker tag mirrorgooglecontainers/pause:3.1 k8s.gcr.io/pause:3.1
docker tag mirrorgooglecontainers/etcd:3.2.24 k8s.gcr.io/etcd:3.2.24
docker tag coredns/coredns:1.2.2 k8s.gcr.io/coredns:1.2.2

执行初始化:

> kubeadm init --kubernetes-version=v1.12.2 --pod-network-cidr=10.244.0.0/16 --service-cidr=10.96.0.0/12 --ignore-preflight-errors=Swap

执行初始化命令前,需要启动kubelet

> systemctl start kubelet

初始化完成后,会输出一些信息,这些信息在后面配置node集群中是必须的,所以需要保存,如下:

To start using your cluster, you need to run the following as a regular user:
  mkdir -p $HOME/.kube
  sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
  sudo chown $(id -u):$(id -g) $HOME/.kube/config

You can now join any number of machines by running the following on each node
as root:
  kubeadm join 192.168.3.166:6443 --token sjh8aj.5nashad8b75bwkh8 --discovery-token-ca-cert-hash sha256:e31b4a3086ad933e7ca25bbf8ca711c10257c2a3b022649c8747ff182e305a95

初始化完成后,需要使用flannel配置网络:

> kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml

接着执行如下命令:

> mkdir -p $HOME/.kube
> sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config

使用下列命令查看节点信息:

> kubectl get nodes
> kubectl get pods -n kube-system -o wide

配置nodes

在node1和node2上同样需要配置docker,kubeadm,kubelet,kubectl,首先将master上的一些资源文件复制到node1和node2上:

> scp docker-ce.repo kubernetes.repo rpm-package-key.gpg root@kube2-node1:/etc/yum.repos.d
> scp docker-ce.repo kubernetes.repo rpm-package-key.gpg root@kube3-node2:/etc/yum.repos.d

然后按照在master上安装的方式,分别安装docker,kubeadm,kubelet,kubectl

转载于:https://www.cnblogs.com/xiaotutu365/p/9947695.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/107201.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 下载和安装MySQL(傻瓜)教程[通俗易懂]

    下载和安装MySQL(傻瓜)教程[通俗易懂]1.下载MySQL打开MySQL官网:MYSQL官网2.安装安装mysql时一直卡在startingtheserver这一位置,解决办法3.检查是否安装成功4.安装成功后进行登录

    2022年5月6日
    64
  • 小波变换和小波阈值法去噪[通俗易懂]

    小波变换和小波阈值法去噪[通俗易懂]小波变换是一种信号的时间——尺度(时间——频率)分析方法,它具有多分辨分析的特点,而且在时频两域都具有表征信号局部特征的能力,。在小波分析中经常用到近似和细节,近似表示信号的高尺度,即低频信息;细节表示信号的低尺度,即高频信息。对含有噪声的信号,噪声分量的主要能量集中在小波解的细节分量中。在以上过程中,小波基和分解层数的选择,阈值的选取规则,和阈值函数的设计,都是影响最终去噪效果的关键因素。

    2022年5月29日
    37
  • 操作系统的定义与基本概念_计算机系统的概念

    操作系统的定义与基本概念_计算机系统的概念1、操作系统的概念及定义1.1操作系统的层次结构从上至下,用户——应用程序——操作系统——裸机(纯硬件)。操作系统OS(OperatingSystem)是指控制和管理整个计算机系统的硬件和软

    2022年8月4日
    2
  • 一份简短又全面的数学建模技能图谱:常用模型&算法总结

    本文总结了常用的数学模型方法和它们的主要用途,主要包括数学和统计上的建模方法,关于在数学建模中也挺常用的机器学习算法暂时不作补充,以后有时间就补。至于究竟哪个模型更好,需要用数据来验证,还有求解方法也不唯一,比如指派问题,你可以用线性规划OR动态规划OR整数规划OR图与网络方法来解。总的来说,常用主成分分析来降维,综合评价的方法有因子分析法、层次分析法、….,用蒙特卡罗方法来随机模拟求解;…

    2022年4月7日
    79
  • zookeeper系列学习——(1)zookeeper的简单介绍

    这一篇大概整理一下zookeeper的一下基本的知识点,不能自己研究出新的技术,就先看别人造出来的轮子! 我一直在模仿,从未有创新!但我相信从模仿开始,总归是有成长和进步的! 首先学习一个新的技术,看官方文档是最好的一种方式。对我来说不仅可以学习技术,还可以提升一下自己的英语能力。 [zookeeper官方网站(http://zookeeper.apache.org/)。Zookeeper中文

    2022年2月25日
    36
  • ccproxy代理搭建_自动代理

    ccproxy代理搭建_自动代理由于公司内网windows系统要更新,特设置代理访问外网https://blog.csdn.net/cyl937/article/details/21330607

    2025年7月28日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号