MySQL CMake參數說明手冊

來源:互聯網
上載者:User

標籤:style   http   io   ar   color   os   使用   sp   for   

MySQL自5.5版本以後,就開始使用CMake編譯工具了,因此,你在安裝源檔案中找不到configure檔案是正常的。很多人下到了新版的MySQL,因為找不到configure檔案,不知道該怎麼繼續下去。有沒有一篇可供參考的文章呢?其實在http://forge.mysql.com網站上有一篇文章,專門介紹了如何用CMake工具進行新版MySQL的編譯安裝。

原文地址為:http://forge.mysql.com/wiki/Autotools_to_CMake_Transition_Guide。

1、介紹
2、命令調用文法
3、安裝參數選項
4、儲存引擎選項
5、庫檔案載入選項
6、其他選項 介紹

本頁將介紹常用編譯工具的一些配置選項和這些配置選項在CMake中又是如何進行配置的,然後介紹如何使用CMake工具來構建編譯MySQL。

命令調用文法

下表列出了常用編譯工具的調用文法和等效的CMake命令。“.”表示你當前的工作目錄路徑,請根據你所在的目錄,適當的替換掉路徑“.”。

configure命令 CMake命令
./configure cmake .
./configure --help cmake . -LH or ccmake .

在重新設定或重新構建之前,需要先清除舊的對象檔案和緩衝資訊,方法如下:

Autotools:

                           view plain                          copy                            
 
  1. make clean 
  2. rm config.cache 

CMake (Unix/Linux):

                           view plain                          copy                            
 
  1. make clean 
  2. rm CMakeCache.txt 

CMake (Windows):

                           view plain                          copy                            
 
  1. devenv MySQL.sln /clean 
  2. 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中,引擎被作為單個的選項來進行控制。假設有以下配置選項:

                           view plain                          copy                            
 
  1. --with-plugins=csv,myisam,myisammrg,heap,innobase,archive,blackhole  

上面的參數指定MySQL資料庫可以支援哪些資料庫引擎,將上述編譯選項轉換成CMake編譯選項時,下面的幾個引擎名字可以被省略,因為編譯時間,預設就支援:

                           view plain                          copy                            
 
  1. csv myisam myisammrg heap 

然後使用下面的編譯參數,以啟用InnoDB、ARCHIVE和BLACKHOLE引擎支援:

                           view plain                          copy                            
 
  1. -DWITH_INNOBASE_STORAGE_ENGINE=1 
  2. -DWITH_ARCHIVE_STORAGE_ENGINE=1 
  3. -DWITH_BLACKHOLE_STORAGE_ENGINE=1 

當然也可以使用“ON”來替代數字1,它們是等效的。

如果你想除去對某種引擎的支援,則在CMake編譯選項中使用-DWITHOUT_<ENGINE>_STORAGE_ENGINE,例如:

                           view plain                          copy                            
 
  1. -DWITHOUT_EXAMPLE_STORAGE_ENGINE=1 
  2. -DWITHOUT_FEDERATED_STORAGE_ENGINE=1 
  3. -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                            
 
  1. --with-debug => WITH_DEBUG=1 
  2. --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

MySQL CMake參數說明手冊

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.