MySQL自5.5版本之後,就開始使用CMake編譯工具了,所以,你在安裝源文件中找不到configure文件是正常的。mysql
本頁將介紹經常使用編譯工具的一些配置選項和這些配置選項在CMake中又是如何進行配置的,而後介紹如何使用CMake工具來構建編譯MySQL。linux
下表列出了經常使用編譯工具的調用語法和等效的CMake命令。「.」表示你當前的工做目錄路徑,請根據你所在的目錄,適當的替換掉路徑「.」。c++
configure命令 | CMake命令 |
./configure | cmake . |
./configure --help | cmake . -LH or ccmake . |
在從新配置或從新構建以前,須要先清除舊的對象文件和緩存信息,方法以下:sql
Autotools:數據庫
view plain copymake clean rm config.cache
CMake (Unix/Linux):緩存
view plain copymake clean rm CMakeCache.txt
CMake (Windows):安全
view plain copydevenv MySQL.sln /clean del CMakeCache.txt
在下表中,「CMAKE_INSTALL_PREFIX」的值表示的是安裝根目錄,其餘參數值的路徑都是相對於根目錄的,固然你也能夠直接使用絕對路徑,具體以下:服務器
參數值說明 | 配置選項 | CMak選項 |
安裝根目錄 | --prefix=/usr | -DCMAKE_INSTALL_PREFIX=/usr |
mysqld目錄 | --libexecdir=/usr/sbin | -DINSTALL_SBINDIR=sbin |
數據存儲目錄 | --localstatedir=/var/lib/mysql | -DMYSQL_DATADIR=/var/lib/mysql |
配置文件(my.cnf)目錄 | --sysconfdir=/etc/mysql | -DSYSCONFDIR=/etc/mysql |
插件目錄 | --with-plugindir=/usr/lib64/mysql/plugin | -DINSTALL_PLUGINDIR=lib64/mysql/plugin |
手冊文件目錄 | --mandir=/usr/share/man | -DINSTALL_MANDIR=share/man |
共享數據目錄 | --sharedstatedir=/usr/share/mysql | -DINSTALL_SHAREDIR=share |
Library庫目錄 | --libdir=/usr/lib64/mysql | -DINSTALL_LIBDIR=lib64/mysql |
Header安裝目錄 | --includedir=/usr/include/mysql | -DINSTALL_INCLUDEDIR=include/mysql |
信息文檔目錄 | --infodir=/usr/share/info | -DINSTALL_INFODIR=share/info |
存儲引擎是以插件的形式存在的,因此,該選項能夠控制插件的構建,好比指定使用某個特定的引擎。socket
--with-plugins配置選項接受兩種形式的參數值,它沒有對應的CMake配置參數:tcp
① 以逗號(,)分隔的引擎名稱列表;
② a "group name" value that is shorthand for a set of engines
在CMake中,引擎被做爲單個的選項來進行控制。假設有如下配置選項:
view plain copy--with-plugins=csv,myisam,myisammrg,heap,innobase,archive,blackhole
上面的參數指定MySQL數據庫能夠支持哪些數據庫引擎,將上述編譯選項轉換成CMake編譯選項時,下面的幾個引擎名字能夠被省略,由於編譯時,默認就支持:
view plain copycsv myisam myisammrg heap
而後使用下面的編譯參數,以啓用InnoDB、ARCHIVE和BLACKHOLE引擎支持:
view plain copy-DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_ARCHIVE_STORAGE_ENGINE=1 -DWITH_BLACKHOLE_STORAGE_ENGINE=1
固然也可使用「ON」來替代數字1,它們是等效的。
若是你想除去對某種引擎的支持,則在CMake編譯選項中使用-DWITHOUT_<ENGINE>_STORAGE_ENGINE,例如:
view plain copy-DWITHOUT_EXAMPLE_STORAGE_ENGINE=1 -DWITHOUT_FEDERATED_STORAGE_ENGINE=1 -DWITHOUT_PARTITION_STORAGE_ENGINE=1
該選項指明Mysql使用庫的狀況:
參數值說明 | 配置選項 | CMak選項 |
readline庫 | --with-readline | -DWITH_READLINE=1 |
SSL庫 | --with-ssl=/usr | -DWITH_SSL=system |
zlib庫 | --with-zlib-dir=/usr | -DWITH_ZLIB=system |
libwrap庫 | --without-libwrap | -DWITH_LIBWRAP=0 |
CMake編譯選項支持大部分以前版本的MySQL編譯選項,新老編譯選項的差異在於:以前的是小寫,如今所有變成了大寫,以前採用雙橫線,如今使用單橫線,以前使用的破折號,如今取而代之的是使用下劃線,例如:
view plain copy--with-debug => WITH_DEBUG=1 --with-embedded-server => WITH_EMBEDDED_SERVER
下面是編譯MySQL的新老參數對照表:
參數值說明 | 配置選項 | CMak選項 |
TCP/IP端口 | --with-tcp-port-=3306 | -DMYSQL_TCP_PORT=3306 |
UNIX socket文件 | --with-unix-socket-path=/tmp/mysqld.sock | -DMYSQL_UNIX_ADDR=/tmp/mysqld.sock |
啓用加載本地數據 | --enable-local-infile | -DENABLED_LOCAL_INFILE=1 |
擴展字符支持 | --with-extra-charsets=all(默認:all) | -DEXTRA_CHARSETS=all(默認:all) |
默認字符集 | --with-charset=utf8 | -DDEFAULT_CHARSET=utf8 |
默認字符校對 | --with-collation=utf8_general_ci | -DDEFAULT_COLLATION=utf8_general_ci |
Build the server | --with-server | 無 |
嵌入式服務器 | --with-embedded-server | -DWITH_EMBEDDED_SERVER=1 |
libmysqld權限控制 | --with-embedded-privilege-control | 無 |
安裝文檔 | --without-docs | 無 |
Big tables支持 | --with-big-tables, --without-big-tables | 無 |
mysqld運行用戶 | --with-mysqld-user=mysql | -DMYSQL_USER=mysql |
調試模式 | --without-debug(默認禁用) | -DWITH_DEBUG=0(默認禁用) |
GIS支持 | --with-geometry | 無 |
社區功能 | --enable-community-features | 無 |
Profiling | --disable-profiling(默認啓用) | -DENABLE_PROFILING=0(默認啓用) |
pstack | --without-pstack | 無(新版移除該功能) |
彙編字符串函數 | --enable-assembler | 無 |
構建類型 | --build=x86_64-pc-linux-gnu | 沒有等效參數 |
交叉編譯主機 | --host=x86_64-pc-linux-gnu | 沒有等效參數 |
客戶端標誌 | --with-client-ldflags=-lstdc++ | 無 |
線程安全標誌 | --enable-thread-safe-client | 無 |
註釋存儲類型 | --with-comment='string' | -DWITH_COMMENT='string' |
Shared/static binaries | --enable-shared --enable-static | 無 |
內存使用控制 | --with-low-memory | 無 |