237 lines
		
	
	
		
			6.3 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			237 lines
		
	
	
		
			6.3 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
使用源码构建 OceanBase 数据库 
 | 
						|
=========================================
 | 
						|
 | 
						|
通过源代码,您可以自行构建 OceanBase 数据库,并测试其最新特性。本文介绍如何通过源代码构建OceanBase 数据库。
 | 
						|
 | 
						|
前提条件 
 | 
						|
-------------------------
 | 
						|
 | 
						|
在构建 OceanBase 数据库之前,确保您的构建机器满足以下要求:
 | 
						|
 | 
						|
* 操作系统:CentOS 7/8 (x86 架构)
 | 
						|
 | 
						|
  
 | 
						|
 | 
						|
* 机器数量:1 台
 | 
						|
 | 
						|
  
 | 
						|
 | 
						|
* 最低硬件规格:
 | 
						|
 | 
						|
  
 | 
						|
 | 
						|
* 推荐硬件规格:
 | 
						|
 | 
						|
  
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
获取源代码 
 | 
						|
--------------------------
 | 
						|
 | 
						|
运行以下命令,克隆 OceanBase 数据库源代码到您的构建机器:
 | 
						|
 | 
						|
```shell
 | 
						|
git clone git@${GIT_MIRROR_ADDRESS}/oceanbase/oceanbase
 | 
						|
```
 | 
						|
 | 
						|
 | 
						|
**注意**
 | 
						|
 | 
						|
 | 
						|
 | 
						|
克隆代码需要先安装配置 Git。详细信息,参考 [Git 文档](https://git-scm.com/doc)。
 | 
						|
 | 
						|
获取构建依赖 
 | 
						|
---------------------------
 | 
						|
 | 
						|
您可以通过以下方式获取构建依赖:
 | 
						|
 | 
						|
* **方案一:** **使用 yum 源** **获取依赖包(推荐)**
 | 
						|
 | 
						|
  
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
构建过程中,您所依赖的大多数工具和库都可以通过公共yum源及 OceanBase 的官方 yum 源获取。如您的操作系统在我们的支持范围内,您可以通过我们预制的脚本,直接下载对应的软件包以节约您的构建时间
 | 
						|
 | 
						|
第一步、安装必要的工具
 | 
						|
 | 
						|
您需要提前准备好以下软件:
 | 
						|
 | 
						|
```bash
 | 
						|
yum install wget rpm* cpio make glibc-devel glibc-headers
 | 
						|
```
 | 
						|
 | 
						|
 | 
						|
 | 
						|
第二步、执行以下命令确认您的编译机可以访问OceanBase官方yum源
 | 
						|
 | 
						|
```shell
 | 
						|
curl http://mirrors.aliyun.com/oceanbase/OceanBase.repo
 | 
						|
```
 | 
						|
 | 
						|
 | 
						|
 | 
						|
第三步、执行初始化脚本,下载构建依赖
 | 
						|
 | 
						|
```shell
 | 
						|
# 进入代码根目录
 | 
						|
cd oceanbase
 | 
						|
 | 
						|
# 执行build.sh脚本并传入init参数
 | 
						|
sh build.sh init
 | 
						|
```
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
* **方案二:自行编译依赖** 
 | 
						|
 | 
						|
  您也可以在 `deps/3rd` 目录下自行编译依赖。构建软件要求见下表:
 | 
						|
  
 | 
						|
 | 
						|
  |    **所** **需软** **件**     |  **推荐版本(最低版本)**  | **软件用途** | **提供依赖** | **必选** |
 | 
						|
  |---------------------------|------------------|----------|----------|--------|
 | 
						|
  | cmake                     | 3.20.0           | 构建工具     | 是        | 是      |
 | 
						|
  | make                      | 3.8.2            | 构建工具     | 否        | 是      |
 | 
						|
  | gcc                       | 5.2.0            | 构建工具/依赖库 | 是        | 是      |
 | 
						|
  | llvm/clang/lld            | 11.0.1 (7.1.0)   | 构建工具     | 是        | 是      |
 | 
						|
  | binutils                  | 2.30             | 构建工具     | 是        | 否      |
 | 
						|
  | flex                      | 2.5.35           | 代码生成     | 是        | 仅开发    |
 | 
						|
  | python2                   | 2.7(2.6)         | 代码生成     | 否        | 仅开发    |
 | 
						|
  | bison                     | 2.4.1            | 代码生成     | 是        | 仅开发    |
 | 
						|
  | ccache                    | 3.7.12           | 构建工具     | 是        | 否      |
 | 
						|
  | isa-l                     | 2.22.0           | 依赖库      | 是        | 是      |
 | 
						|
  | libaio                    | 0.3.112(0.3.109) | 依赖库      | 是        | 是      |
 | 
						|
  | libcurl                   | 7.29.0           | 依赖库      | 是        | 是      |
 | 
						|
  | libunwind                 | 1.5.0            | 依赖库      | 是        | 是      |
 | 
						|
  | mariadb-connector-c       | 3.1.12           | 依赖库      | 是        | 是      |
 | 
						|
  | openssl-static            | 1.0.1e           | 依赖库      | 是        | 是      |
 | 
						|
  | glibc-devel/glibc-headers | 2.17             | 依赖库      | 否        | 是      |
 | 
						|
  | oss-c-sdk                 | 3.9.2            | 依赖库      | 否        | 否      |
 | 
						|
  | rpm\*                     | 4.14.1(4.11)     | 打包工具     | 否        | 仅打包    |
 | 
						|
 | 
						|
  
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
构建/打包 OceanBase 数据库 
 | 
						|
----------------------------------------
 | 
						|
 | 
						|
OceanBase 数据库使用 CMake 作为构建工具,您可以直接使用 CMake 命令自行创建目录进行构建,也可以使用 `build.sh` 脚本使用预制的构建选项进行构建:
 | 
						|
 | 
						|
* DEBUG 构建
 | 
						|
 | 
						|
  ```shell
 | 
						|
  # 在源码目录下执行debug版的预制构建命令
 | 
						|
  sh build.sh debug
 | 
						|
  
 | 
						|
  # 进入生成的 debug 构建目录
 | 
						|
  cd build_debug
 | 
						|
  
 | 
						|
  # 进行构建
 | 
						|
  make -j{N} observer
 | 
						|
  
 | 
						|
  # 查看构建产物
 | 
						|
  stat src/observer/observer
 | 
						|
  ```
 | 
						|
 | 
						|
  
 | 
						|
 | 
						|
* RELEASE 构建
 | 
						|
 | 
						|
  ```shell
 | 
						|
  # 在源码目录下执行 release 版的预制构建命令
 | 
						|
  sh build.sh release
 | 
						|
  
 | 
						|
  # 进入生成的 release 构建目录
 | 
						|
  cd build_release
 | 
						|
  
 | 
						|
  # 进行构建
 | 
						|
  make -j{N} observer
 | 
						|
  
 | 
						|
  # 查看构建产物
 | 
						|
  stat src/observer/observer
 | 
						|
  ```
 | 
						|
 | 
						|
  
 | 
						|
 | 
						|
* 创建 RPM 包
 | 
						|
 | 
						|
  ```shell
 | 
						|
  # 在源码目录下执行 rpm包 的预制构建命令
 | 
						|
  sh build.sh rpm
 | 
						|
  
 | 
						|
  # 进入生成的 rpm 打包目录
 | 
						|
  cd build_rpm
 | 
						|
  
 | 
						|
  # 构建 rpm 包依赖的文件
 | 
						|
  make -j{N} rpm
 | 
						|
  
 | 
						|
  # 查看构建产物
 | 
						|
  stat *rpm
 | 
						|
  ```
 | 
						|
 | 
						|
  
 | 
						|
 | 
						|
 | 
						|
 | 
						|
**说明**
 | 
						|
 | 
						|
 | 
						|
 | 
						|
为加快构建速度,您可以使用 `-j` 参数并行构建。并行数量 `N` 建议为 min(CPU(Core)\* 2,内存(GB) / 2)。
 | 
						|
 | 
						|
构建选项说明 
 | 
						|
---------------------------
 | 
						|
 | 
						|
构建参数说明见下表:
 | 
						|
 | 
						|
 | 
						|
|          **构建选项**          |  **默认值**   |                 **软件用途**                 |
 | 
						|
|----------------------------|------------|------------------------------------------|
 | 
						|
| OB_USE_LLVM_LIBTOOLS       | ON         | 使用 llvm-ar/ld.lld 等作为库工具,关闭则使用 binutils。 |
 | 
						|
| OB_USE_CLANG               | ON         | 使用 clang 作为编译器,关闭则使用gcc。                 |
 | 
						|
| OB_COMPRESS_DEBUG_SECTIONS | OFF        | 压缩二进制中的 DEBUG SECTIONS。                  |
 | 
						|
| OB_STATIC_LINK_LGPL_DEPS   | ON(打包时OFF) | 静态链接LGPL协议的依赖                            |
 | 
						|
| OB_ENABLE_PCH              | ON         | 启用预编译头                                   |
 | 
						|
| OB_ENALBE_UNITY            | ON         | 启用联合构建                                   |
 | 
						|
| OB_USE_CCACHE              | OFF        | 启用编译缓存                                   |
 | 
						|
| ENABLE_DEBUG_LOG           | OFF        | 开启调试日志。                                  |
 | 
						|
 | 
						|
 | 
						|
 | 
						|
后续操作 
 | 
						|
-------------------------
 | 
						|
 | 
						|
您在成功构建 OceanBase 数据库之后,可以使用 OBD 部署 OceanBase 数据库。详细信息参考 [使用 OBD 部署 OceanBase 数据库](../2.quickstart/4.deploy-the-oceanbase-database-by-using-obd.md)。
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 |