MySQL CMake引數說明手冊
MySQL CMake引數說明手冊
MySQL自5.5版本以後,就開始使用CMake編譯工具了,因此,你在安裝原始檔中找不到configure檔案是正常的。很多人下到了新版的MySQL,因為找不到configure檔案,不知道該怎麼繼續下去。有沒有一篇可供參考的文章呢?其實在網站上有一篇文章,專門介紹瞭如何用CMake工具進行新版MySQL的編譯安裝。
原文地址為:。
介紹
本頁將介紹常用編譯工具的一些配置選項和這些配置選項在CMake中又是如何進行配置的,然後介紹如何使用CMake工具來構建編譯MySQL。
命令呼叫語法
下表列出了常用編譯工具的呼叫語法和等效的CMake命令。“.”表示你當前的工作目錄路徑,請根據你所在的目錄,適當的替換掉路徑“.”。
configure命令 | CMake命令 |
./configure | cmake . |
./configure --help | cmake . -LH or ccmake . |
在重新配置或重新構建之前,需要先清除舊的物件檔案和快取資訊,方法如下:
Autotools:
- make clean
- rm config.cache
CMake (Unix/Linux):
- make clean
- rm CMakeCache.txt
CMake (Windows):
- devenv 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 |
儲存引擎選項
儲存引擎是以外掛的形式存在的,所以,該選項可以控制外掛的構建,比如指定使用某個特定的引擎。
--with-plugins配置選項接受兩種形式的引數值,它沒有對應的CMake配置引數:
① 以逗號(,)分隔的引擎名稱列表;
② a "group name" value that is shorthand for a set of engines
在CMake中,引擎被作為單個的選項來進行控制。假設有以下配置選項:
- --with-plugins=csv,myisam,myisammrg,heap,innobase,archive,blackhole
上面的引數指定MySQL資料庫可以支援哪些資料庫引擎,將上述編譯選項轉換成CMake編譯選項時,下面的幾個引擎名字可以被省略,因為編譯時,預設就支援:
- csv myisam myisammrg heap
然後使用下面的編譯引數,以啟用InnoDB、ARCHIVE和BLACKHOLE引擎支援:
- -DWITH_INNOBASE_STORAGE_ENGINE=1
- -DWITH_ARCHIVE_STORAGE_ENGINE=1
- -DWITH_BLACKHOLE_STORAGE_ENGINE=1
當然也可以使用“ON”來替代數字1,它們是等效的。
如果你想除去對某種引擎的支援,則在CMake編譯選項中使用-DWITHOUT_
- -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編譯選項,新老編譯選項的差別在於:之前的是小寫,現在全部變成了大寫,之前採用雙橫線,現在使用單橫線,之前使用的破折號,現在取而代之的是使用下劃線,例如:
- --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 | 無 |
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/29500582/viewspace-1377045/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- MySQL 5.5編譯安裝cmake引數說明MySql編譯
- MySQL引數說明MySql
- 【MYSQL】MHA引數列表說明MySql
- Mysql JDBC Url引數說明MySqlJDBC
- 【MySQL】SemisynchronousReplication配置和引數說明MySql
- mysql innodb相關引數說明MySql
- cmake使用說明
- Mysql my.cnf部分引數說明MySql
- mysql relay log相關引數說明MySql
- MYSQL: Handler_read_%引數說明MySql
- 【MySQL】Semisynchronous Replication 配置和引數說明MySql
- MySQL Galera cluster叢集常用引數說明MySql
- MySQL mysqldump命令的引數詳細說明MySql
- mysql常用引數使用說明及查詢MySql
- TOP引數說明
- mysqldump引數說明MySql
- mysqldump 引數說明MySql
- MySQL 5.7 自增欄位相關引數說明MySql
- MYSQL 5.6 安裝時cmake引數MySql
- Elasticsearch 引數配置說明Elasticsearch
- kafka 引數配置說明Kafka
- redis 3.0 引數說明Redis
- golden gate 引數說明Go
- oracle引數說明(zt)Oracle
- mysql 變數說明MySql變數
- MySQL引數DELAY_KEY_WRITE的詳細說明MySql
- Oracle Table建立引數說明Oracle
- Oracle Table 建立引數 說明Oracle
- mysqldump引數詳細說明MySql
- mosquitto命令引數說明UI
- Oracle Sequence Cache 引數說明Oracle
- MySQL配置檔案my.ini引數註釋說明MySql
- Nginx的gzip配置引數說明Nginx
- linux常用核心引數說明Linux
- GoldenGate HANDLECOLLISIONS引數使用說明Go
- 【7】JVM引數說明和分析JVM
- 2.--Goldgate常用引數說明Go
- Linux SHELL if 命令引數說明Linux