设为首页 收藏本站
查看: 1232|回复: 1

[经验分享] MySQL CMake参数说明手册

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2013-12-3 17:49:38 | 显示全部楼层 |阅读模式
MySQL自5.5版本以后,就开始使用CMake编译工具了,因此,你在安装源文件中找不到configure文件是正常的。很多人下到了新版的MySQL,因为找不到configure文件,不知道该怎么继续下去。有没有一篇可供参考的文章呢?其实在http://forge.mysql.com网站上有一篇文章,专门介绍了如何用CMake工具进行新版MySQL的编译安装。
1、介绍
2、命令调用语法
3、安装参数选项
4、存储引擎选项
5、库文件加载选项
6、其他选项

介绍
本页将介绍常用编译工具的一些配置选项和这些配置选项在CMake中又是如何进行配置的,然后介绍如何使用CMake工具来构建编译MySQL。
命令调用语法
下表列出了常用编译工具的调用语法和等效的CMake命令。“.”表示你当前的工作目录路径,请根据你所在的目录,适当的替换掉路径“.”。
configure命令
CMake命令
./configurecmake .
./configure --helpcmake . -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无

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-11025-1-1.html 上篇帖子: Mysql数据库优化系列,为您的系统加速 下篇帖子: Mysql日期统计函数简介

尚未签到

发表于 2014-1-7 08:06:27 | 显示全部楼层
便利商店里谁也买不到 我们最想要的东西

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表