http://www.sunchis.com/html/db/mysql/2012/0612/419.html
MySQL CMake参数说明手册
MySQL自5.5版本以后,就开始使用CMake编译工具了,因此,你在安装源文件中找不到configure文件是正常的。很多人下到了新版的MySQL,因为找不到configure文件,不知道该怎么继续下去。有没有一篇可供参考的文章呢?其实在http://forge.mysql.com 网站上有一篇文章,专门介绍了如何用CMake工具进行新版MySQL的编译安装。
原文地址为:http://forge.mysql.com/wiki/Autotools_to_CMake_Transition_Guide 。
介绍
本页将介绍常用编译工具的一些配置选项和这些配置选项在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_<ENGINE>_STORAGE_ENGINE,例如:
- -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 | 无 |
发表评论
-
在linux网站运维方向老男孩最近几年常用的免费的开源软件
2013-02-18 23:35 1603http://blog.chinaunix.net/uid- ... -
rsync服务部署
2013-02-18 22:40 872http://oplinux.com/app/rsync/r ... -
centos6.0 配置SVN
2013-02-04 14:52 1002http://blog.csdn.net/tonysz12 ... -
Centos搭建SVN服务器三步曲
2013-02-04 12:09 918搭建SVN服务,有效的管理代码,以下三步可以快速搞定。1、安 ... -
linux(centos)如何使用svn进行多个版本库的配置
2013-02-04 12:08 3560如果当前有svnserve进程在运行,指令 ... -
Nginx下搭建flv视频服务器且支持视频拖动进度条播放
2012-12-19 18:10 1168目前,由于Flash 的流行,网络上绝大多数的微视频网站 ... -
mysql主从部署
2012-12-18 09:06 647首先,假设我们有两台服务器,ip分别为192.168.1.1和 ... -
如何查询centos查看系统内核版本,系统版本,32位还是64位
2012-12-15 11:13 1231http://hi.baidu.com/tjbaso/item ... -
linux下磁盘I/O查看
2012-12-07 13:11 809http://zlbzhu.blog.51cto.co ... -
Centos5.5最小化安装后的优化
2012-11-20 23:16 1187购买了服务器(现在主流 ... -
Amoeba for MySQL学习研究之安装
2012-11-17 14:03 851http://blog.csdn.net/yongsheng0 ... -
如何用 Amoeba 进行mysql数据库读写分离
2012-11-16 10:32 912http://terryzhang25.blog.163.co ... -
MySQL数据库恢复(使用mysqlbinlog命令)
2012-11-12 16:48 839http://www.jb51.net/article/279 ... -
用mysqlbinlog恢复MySQL数据库
2012-11-12 16:43 686http://www.rongsen.com.cn/artic ... -
CentOS 6.2编译安装Nginx1.2.0+MySQL5.5.25+PHP5.3.13+博客系统WordPress3.3.2
2012-11-11 23:37 1032说明: 操作系统:CentOS 6.2 32 ... -
CentOS minimal 版安装图形界面的步骤分享,中文语言包.
2012-11-11 22:33 7381、连接网络: CentOS minimal.iso安装好 ... -
CentOS 6.3编译安装Nginx1.2.2+MySQL5.5.25a+PHP5.4.5
2012-11-04 19:56 903说明: 操作系统:CentOS 6.3 32位 系 ... -
零起步6-CentOS6.3源码安装mysql5.5.28
2012-11-04 19:42 821全新以最小化包安装了64位的CentOS6.3系统 ... -
centos下 MySQL 5.5.11 CMake 安装笔记
2012-11-04 19:33 740centos下 MySQL 5.5.11 CMake 安装笔记 ... -
[HTML5]配置Ngnix服务器支持manifest 离线存储
2012-10-08 14:09 1430[HTML5]配 ...
相关推荐
本手册将详细讲解如何在Linux系统上进行MySQL的安装与部署。 **一、系统需求** 在开始安装之前,确保你的Linux发行版已经更新至最新,并安装了必要的依赖库。这些通常包括GCC编译器、CMake构建工具以及一些开发库,...
在实际应用中,很多知名项目都采用了CMake来构建和管理其代码,比如KDE桌面环境、OpenCV计算机视觉库以及MySQL数据库管理系统等。 #### 构建工程的核心问题 构建一个完整的工程通常涉及以下几个关键环节: 1. **...
文档详细介绍了如何使用CMake工具来构建MySQL服务器,从简介到配置步骤、列举配置参数、修改配置参数以及构建调试配置。还提供了快速构建指南,以及在MySQL官方版本中使用相同选项进行构建的方法。此外,还有对平台...
- **CMake**:从 MySQL 5.5 开始,不再使用传统的 `configure` 方式编译,因此需要 CMake 来配置编译参数。 - **Boost**:从 MySQL 5.7.5 版本开始,Boost 库成为了必需项,因为它在 MySQL 源代码中被广泛使用。 ...
### 运维新手学习手册知识点概览 #### 1. LAMP(PHP环境配置) - **LAMP**:指的是Linux + Apache + MySQL + PHP组成的Web服务环境。 - **Linux**:作为操作系统基础,提供了安全稳定的运行环境。 - **Apache**...
### Zabbix 安装手册(CentOS 7) #### 环境准备 在开始安装 Zabbix 之前,首先确保你的系统环境满足以下版本要求: - **操作系统:** CentOS 7.3 - **数据库:** MariaDB 10.0.32 - **Web 服务器:** Nginx ...
此外,还需创建并配置my.cnf文件以设定MySQL的运行参数。 在MySQL运行阶段,启动服务并将其添加到环境变量,建立套接字软链接以便连接。然后,我们对初始密码进行修改,并使用新密码登录MySQL。在导入数据部分,将...
首先,要使用`corw`,你需要在CMakeLists.txt文件中配置项目,确保依赖库如`asio`、`boost`以及可选的`mysql`库已安装。在CMakeLists.txt中,你需要指定C++标准、包含目录和链接库。以下是一个示例: ```cmake ...
安装完成后,记得修改MySQL的安装路径(默认为`/usr/local/mysql`),并根据Jira的配置要求进行相应的数据库参数设置。 #### 四、安装JIRA 在JDK和MySQL都已准备就绪的情况下,接下来就可以安装Jira了。Jira的...
它可以支持多种数据库系统,包括MySQL、PostgreSQL、Oracle等。通过设置不同的参数,sysbench可以模拟不同级别的并发用户和请求,以观察数据库在不同工作负载下的响应时间和吞吐量。 对于I/O性能测试,sysbench能够...