linux cmake编译安装mysql_cmake编译安装MySQL-5.5

从mysql5.5起,mysql的源码安装开始使用cmake了。“CMake”是“cross platform make” 的缩写。即是一个跨平台的安装(编译)工具,可以用简单的语句来描述所有平台的安装(编译过程)。

一、安装cmake# tar xf cmake-2.8.8.tar.gz

# cd cmake-2.8.8

# ./bootstrap

# make

# make install

二、编译安装mysql-5.5.33

1、使用cmake编译mysql-5.5是的常用选项

cmake指定编译选项的方式不同于make,如下为configure选项如何映射到CMake的等值参数。configure CommandCMake Command

./configurecmake .

./configure --helpcmake . –LH or ccmake .

如果需要重新编译时,可用下面命令清除旧的对象文件和缓存信息# make clean

# rm -f CMakeCache.txt

指定安装文件的安装路径时常用的选项:

-DCMAKE_INSTALL_PREFIX=/usr/local/mysql      --安装的基本目录

-DMYSQL_DATADIR=/data/mysql            --数据文件所在目录

-DSYSCONFDIR=/etc           --配置文件my.cnf所在目录

mysql存储引擎是插件式的,因此插件控制选项可以指定那个存储引擎安装。CSV、MyISAM、MERGE和MEMORY引擎为默认强制安装。若要安装其它存储引擎,使用-DWITH_engine_STORAGE_ENGINE=1可以使用类似如下编译选项:

-DWITH_INNOBASE_STORAGE_ENGINE=1

-DWITH_ARCHIVE_STORAGE_ENGINE=1

-DWITH_BLACKHOLE_STORAGE_ENGINE=1

-DWITH_FEDERATED_STORAGE_ENGINE=1

若要明确指定不编译某存储引擎,则使用-DWITHOUT__STORAGE_ENGINE=1 比如:

-DWITHOUT_EXAMPLE_STORAGE_ENGINE=1

-DWITHOUT_FEDERATED_STORAGE_ENGINE=1

-DWITHOUT_PARTITION_STORAGE_ENGINE=1

lib库选项:如若要编译进其它功能,则可使用类似如下选项来实现编译时使用某库或不使用某库:

-DWITH_READLINE=1      --支持使用数据的批量导入导出功能

-DWITH_SSL=system       --支持SSL安全功能

-DWITH_ZLIB=system       --支持压缩功能

-DWITH_LIBWRAP=0        --安全机制

其它常用的选项有:

-DMYSQL_TCP_PORT=3306           --默认TCP端口

-DMYSQL_UNIX_ADDR=/tmp/mysql.sock        --默认套接字文件路径

-DENABLED_LOCAL_INFILE=1      --是否允许从本地导入数据

-DEXTRA_CHARSETS=all              --额外字符集

-DDEFAULT_CHARSET=utf8             --默认字符集

-DDEFAULT_COLLATION=utf8_general_ci      --排序规则

-DWITH_DEBUG=0           --是否启用调试功能

-DENABLE_PROFILING=1           --性能数据收集

2、安装配置mysql

1)创建目录和用户# mkdir /usr/local/mysql

# mkdir /mydata/data

# groupadd -r mysql

# useradd -g mysql -r -d /mydata/data mysql //创建mysql用户并赋予数据存放目录权限

2) cmake安装mysql# tar xf mysql-5.5.33.tar.gz

# cd mysql-5.5.33

# cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/mydata/data

-DSYSCONFDIR=/etc

-DWITH_INNOBASE_STORAGE_ENGINE=1

-DWITH_ARCHIVE_STORAGE_ENGINE=1

-DWITH_BLACKHOLE_STORAGE_ENGINE=1

-DWITH_READLINE=1

-DWITH_SSL=system -DWITH_ZLIB=system

-DWITH_LIBWRAP=0

-DMYSQL_UNIX_ADDR=/tmp/mysql.sock

-DDEFAULT_CHARSET=utf8

-DDEFAULT_COLLATION=utf8_general_ci

# make

# make install

3. 配置并初始化数据库# cd /usr/local/mysql/

# chown -R .mysql .

# ls -lh

# cp support-files/my-large.cnf /etc/my.cnf //创建my.cnf配置文件到/etc 下

# vim /etc/my.cnf //编辑my.cnf 文件并插入数据文件所在目录 datadir = /mydata/data

# scripts/mysql_install_db --user=mysql --datadir=/mydata/data //初始化数据库

# cp support-files/mysql.server /etc/rc.d/init.d/mysqld //创建管理MySQL数据库的shell脚本

# chmod +x /etc/rc.d/init.d/mysqld //赋予脚本可执行权限

# chkconfig --add mysqld //加入开机自起列表

# chkconfig --list mysqld //确认开机mysqld 开机自起

# service mysqld start //启动

# ss -tanl //确认3306端口处于监听状态

# vim /etc/profile.d/mysql.sh //插入 export PATH=/usr/local/mysql/bin:$PATH

# . /etc/profile.d/mysql.sh //source 文件

4. 为mysql设置密码,消除安全隐患# mysql //初始空密码登录数据库

mysql> SELECT user, host, password FROM user; //查看所有用户

mysql> DROP USER ''@localhost //删除两个默认匿名用户

mysql> DROP USER root@'::1'; //删除本机ipv6用户

mysql> UPDATE user SET password=PASSWORD('mypass') WHERE user='root'; //给用户添加密码

mysql>FLUSH PRIVILEGES; //刷新授权表

mysql> \q //退出

#mysql -uroot –p //使用密码登入

你可能感兴趣的:(linux,cmake编译安装mysql)