源码编译Kubeadm二进制文件

kubeadm是Kubernetes官方提供的用于快速安装Kubernetes集群的工具,伴随Kubernetes每个版本的发布都会同步更新,kubeadm会对集群配置方面的一些实践做调整,通过实验kubeadm可以学习到Kubernetes官方在集群配置上一些新的最佳实践。

最近发布的Kubernetes 1.15中,kubeadm对HA集群的配置已经达到beta可用,说明kubeadm距离生产环境中可用的距离越来越近了。

受以下消息影响,决定作一次K8S升级的探索。

漏洞详细信息

  • Netflix最近宣布了一项安全公告,该公告确定了几个可能影响HTTP/2协议服务器实现的拒绝服务攻击向量,并发布了8个CVE。[1]
  • Go受两个漏洞(CVE-2019-9512和CVE-2019-9514)的影响,因此服务于HTTP/2流量(including / healthz)的Kubernetes组件也会受到影响。[2]
  • 这些漏洞允许不受信任的客户端分配无限量的内存,直到服务器崩溃。产品安全委员会已将这组漏洞分配为CVSS评分为7.5 [3]


如何解决漏洞?

Go发布了go1.12.8和go1.11.13版本,我们也发布了使用修补版本的Go构建的以下版本的Kubernetes。

  • Kubernetes v1.15.3 - go1.12.9
  • Kubernetes v1.14.6 - go1.12.9
  • Kubernetes v1.13.10 - go1.11.13

升级到上面列出的Kubernetes修补版本。

 

本文档以kubernetes 1.14.6作为升级目标。由于kubeadm历来是手工下载升级,籍由此次机会,顺便更改证书过期时间,并手工编译成二进制文件。
一,生成编译镜像

    1,Dockerfile内容(注意,一定要下载go1.12.9以后版本,才修复了漏洞):

FROM centos:centos7.6.1811

MAINTAINER 4k

ENV GOROOT /usr/local/go
ENV GOPATH /usr/local/gopath
ENV PATH /usr/local/go/bin:$PATH

RUN yum install rpm-build which where rsync gcc gcc-c++ automake autoconf libtool make -y \
    && curl -L https://studygolang.com/dl/golang/go1.12.9.linux-amd64.tar.gz | tar zxvf - -C /usr/local

 

    2,生成镜像

docker build –t harbor.xxx.cn/4k/build-k8s:centos-7.6-go-1.12.9-k8s-1.14.6 .

 

二,下载github源码

    Github下载地址(注意linux下载tar.gz包,不要下载zip包):

wget https://github.com/kubernetes/kubernetes/releases/download/v1.14.6/kubernetes.tar.gz

 

三,镜像挂载目录

    1,运行docker run 命令,将生成的镜像和下载的源码解压挂载

docker run -it --rm –v \
/build-k8s/kubernetes-1.14.6:/usr/local/gopath/src/k8s.io/kubernetes \
harbor.xxx.cn/build-k8s:centos-7.6-go-1.12.9-k8s-1.14.6

 

四,编译二进制

    1,进入容器,在k8s项目根目录下运行如下命令,编译Kubeadm

KUBE_BUILD_PLATFORMS=linux/amd64 make all WHAT=cmd/kubeadm GOFLAGS=-v GOGCFLAGS="-N -l"

 

五,kubeadm二进制验证

    1,运行命令进行验证

   

./kubeadm version
kubeadm version: &version.Info{Major:"1", Minor:"14", GitVersion:"v1.14.6", GitCommit:"96fac5cd13a5dc064f7d9f4f23030a6aeface6cc", GitTreeState:"archive", BuildDate:"2019-09-05T02:41:12Z", GoVersion:"go1.12.9", Compiler:"gc", Platform:"linux/amd64"}

 

    2,将此kubeadm二进制下载保存,用于将来升级。

六,kubeadm修改记录(证书100年过期)

    1,kubernetes-1.14.6\staging\src\k8s.io\client-go\util\cert\cert.go

    2,kubernetes-1.14.6\cmd\kubeadm\app\util\pkiutil\pki_helpers.go

转载于:https://www.cnblogs.com/aguncn/p/11465584.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
编译ceph源码生成二进制文件,可以按照以下步骤进行操作: 1. 首先,从GitHub上下载ceph源码。使用命令`git clone --recursive https://github.com/ceph/ceph.git`,加上`--recursive`参数以下载源码中的子模块。 2. 进入源码根目录,并选择要编译的版本。使用`git tag`命令显示已有的版本,并使用`git checkout <版本号>`切换到要编译的版本。 3. 下载依赖项并开始编译。运行以下命令: - `./install-deps.sh`:下载编译所需的依赖项。 - `./autogen.sh`:生成配置脚本。 - `./configure`:配置编译选项。 - `make`:编译源码。如果遇到编译器错误,可以使用`-j`参数指定处理器数量,例如`make -j2`。 4. 编译完成后,可以使用`make install`命令将生成的二进制文件和配置文件安装到本地系统。也可以手动将二进制文件放置在`/usr/bin`目录下,将库文件放置在`/usr/lib`目录下,配置文件存放在`/etc/ceph`目录中。 需要注意的是,如果从GitHub上获取ceph源码进行编译,可能会遇到一些问题。例如,报告找不到特定文件的错误,可能是因为没有获取到所有的子模块代码。在使用`git clone`命令时,需要添加`--recursive`参数以获取完整的源码及其子模块。 此外,还可能遇到编译过程中出现内存不足的问题,导致编译失败。如果出现类似"internal compiler error: Killed (program cc1plus)"的错误提示,可能是因为内存不足。可以尝试增加系统的可用内存或者优化编译环境来解决这个问题。 综上所述,要编译ceph源码生成二进制文件,可以按照上述步骤进行操作,同时注意处理可能遇到的子模块获取和内存不足的问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [编译ceph源码](https://blog.csdn.net/mary0712/article/details/117467780)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值