构建方式
Kubernetes的构建方式可以分为3种,分别是本地环境构建、容器环境构建、Bazel环境构建。
Kubernetes构建方式:
- 本地环境构建
- make
- make all
- 容器环境构建
- make release
- make quick-release
- Bazel环境构建
- make bazel-build
下面将详细介绍前两种构建方式:
本地环境构建
执行make或者make all命令,会编译Kubernetes的所有组件,组件二进制文件输出的相对路径是_output/bin。如果我们需要对Makefile的执行过程进行调试,可以在make命令后面加-n参数,输出但不执行所有执行命令,这样可以展示更详细的编译构建过程。假设我们想单独构建某个组价,如kubectl组件,则需要指定WHAT参数。命令示例如下:
make WHAT=cmd/kubectl
Makefile是一个非常自动化构建工具,可以用来构建和测试Go语言的应用程序,Makefile还适用于大多数编程语言,在Kubernetes的源码根目录中,有两个与Makefile相关的文件,功能分别如下:
- Makefile:顶层Makefile文件,描述了整个项目所有代码文件的编译顺序、编译规则及编译后的二进制文件输出等。
- Makefile.generated_file:描述了代码生成的逻辑。
本地构建过程
通过调用hack/make-rules/build.sh脚本开始构建组件,传入要构建的组件名称,不指定组件名称则构建所有组件。hack/make-rules/build.sh代码示例如下:
kube::golang::build_binaries "$@"
build_binaries接收构建的组件名称,设置构建所需要的环境及一些编译时所需的Go flags选项,然后通过go install构建组件:
go install "${build_args[@]}" "$@"
在go install命令执行完成后,二进制输出的目录为_output/bin。
最后,可以使用make clean命令来清理构建环境。
容器环境构建
通过容器(Docker)进行Kubernetes构建也非常简单,Kubernetes提供了两种容器环境下得构建方式:make release 和make quick-release,它们之间的区别如下:
- make release:构建所有目标平台(Darwin、Linux、Windows),构建过程会比较久,并同时执行单元测试过程。
- make quick-release:快速构建,只构建当前平台,并略过单元测试过程。
Kubernetes容器环境构建流程:
构建环境的配置及验证:kube::build::verify_prereqs
构建容器镜像:kube::build::build_image
构建代码:kube::build::run_build_command make cross
将文件从容器复制到主机:kube::build::copy_output
打包:kube::release::package_tarballs