mysql5.1之前编译mysql使用的是make工具,编译步骤如下:

./configure --prefix=

make &&make install


mysql5.5之后编译mysql使用的是cmake工具,编译步骤如下:

cmake .

查看帮助使用: cmake -LH 或ccmake .


1.创建mysql用户及安装依赖软件包.

[root@mytest2 mnt]# groupadd  mysql

[root@mytest2 mnt]# useradd  -g mysql  -s /sbin/nologin mysql

[root@mytest2 mnt]# id mysql

uid=101(mysql) gid=102(mysql) groups=102(mysql)


安装mysql依赖的软件包

yum install gcc gcc-c++ ncurses  ncurses-devel  openssl openssl-devel zlib bison cmake

到www.mysql.com下载mysql的源码包.

2.编译安装mysql

cd mysql源码目录

cmake .  -LH

若产生异常,可以删除CMakeCache.txt,重新执行cmake . -LH


[root@mytest2 mysql-5.5.38]# cmake . -LH

-- Running cmake version 2.6.4

-- MySQL 5.5.38

-- Packaging as: mysql-5.5.38-Linux-x86_64

-- Library mysqlclient depends on OSLIBS -lpthread;m;rt;dl

Warning: Bison executable not found in PATH

-- Configuring done

-- Generating done

-- Build files have been written to: /tmp/mysql-5.5.38

-- Cache values

// Choose the type of build, options are: None(CMAKE_CXX_FLAGS or

CMAKE_C_FLAGS used) Debug Release RelWithDebInfo MinSizeRel

CMAKE_BUILD_TYPE:STRING=RelWithDebInfo


// install prefix

CMAKE_INSTALL_PREFIX:PATH=/usr/local/mysql


// Set to true if this is a community build

COMMUNITY_BUILD:BOOL=ON


// Enable profiling

ENABLED_PROFILING:BOOL=ON


// Enable debug sync (debug builds only)

ENABLE_DEBUG_SYNC:BOOL=ON


// Enable gcov (debug, Linux builds only)

ENABLE_GCOV:BOOL=OFF


// Installation directory layout. Options are: STANDALONE (as in zip or tar.gz installer), RPM, DEB, SVR4

INSTALL_LAYOUT:STRING=STANDALONE


// default MySQL data directory

MYSQL_DATADIR:PATH=/usr/local/mysql/data


// MySQL maintainer-specific development environment

MYSQL_MAINTAINER_MODE:BOOL=OFF


// PATH to MySQL TMP dir. Defaults to the P_tmpdir macro in

TMPDIR:PATH=P_tmpdir


// Link ARCHIVE statically to the server

WITH_ARCHIVE_STORAGE_ENGINE:BOOL=OFF


// Enable address sanitizer

WITH_ASAN:BOOL=OFF


// Link BLACKHOLE statically to the server

WITH_BLACKHOLE_STORAGE_ENGINE:BOOL=OFF


// Use dbug/safemutex

WITH_DEBUG:BOOL=OFF


// Compile MySQL with embedded server

WITH_EMBEDDED_SERVER:BOOL=OFF


// Options are: none, complex, all

WITH_EXTRA_CHARSETS:STRING=all


// Link FEDERATED statically to the server

WITH_FEDERATED_STORAGE_ENGINE:BOOL=OFF


// Link INNOBASE statically to the server

WITH_INNOBASE_STORAGE_ENGINE:BOOL=ON


// Use bundled libedit

WITH_LIBEDIT:BOOL=ON


// Compile with tcp wrappers support

WITH_LIBWRAP:BOOL=OFF


// Link PARTITION statically to the server

WITH_PARTITION_STORAGE_ENGINE:BOOL=ON


// Link PERFSCHEMA statically to the server

WITH_PERFSCHEMA_STORAGE_ENGINE:BOOL=ON


// Generate PIC objects

WITH_PIC:BOOL=OFF


// Use bundled readline

WITH_READLINE:BOOL=OFF


// Options are : no, bundled, yes (prefer os library if present otherwise use bundled), system (use os library)

WITH_SSL:STRING=no


// Compile MySQL with unit tests

WITH_UNIT_TESTS:BOOL=ON


// Valgrind instrumentation

WITH_VALGRIND:BOOL=OFF


// Use bundled zlib

WITH_ZLIB:STRING=bundled


[root@mytest2 mysql-5.5.38]# 


2.1 执行编译.

--启用SSL的编译---------------------------------------------

cmake . -DCMAKE_INSTALL_PREFIX:PATH=/usr/local/mysql-5.5.38 \

-DMYSQL_DATADIR:PATH=/data/mysql \

-DSYSCONFDIR=/etc \

-DWITH_INNOBASE_STORAGE_ENGINE:BOOL=ON \

-DWITH_ARCHIVE_STORAGE_ENGINE:BOOL=On \

-DWITH_BLACKHOLE_STORAGE_ENGINE:BOOL=On \

-DWITH_EXTRA_CHARSETS:STRING=all \

-DWITH_READLINE:BOOL=On \

-DWITH_SSL:STRING=system \

-DWITH_ZLIB=system \

-DWITH_LIBWRAP:BOOL=OFF \

-DENABLED_PROFILING:BOOL=ON \

-DMYSQL_UNIX_ADDR=/data/mysql/mysql.sock \

-DDEFAULT_CHARSET=utf8 \

-DDEFAULT_COLLATION=utf8_general_ci


make && make install


--不启用SSL的编译---------------------------------------------

cmake . -DCMAKE_INSTALL_PREFIX:PATH=/usr/local/mysql-5.5.38 \
-DMYSQL_DATADIR:PATH=/data/mysql \
-DSYSCONFDIR=/etc \
-DWITH_INNOBASE_STORAGE_ENGINE:BOOL=ON \
-DWITH_ARCHIVE_STORAGE_ENGINE:BOOL=On \
-DWITH_BLACKHOLE_STORAGE_ENGINE:BOOL=On \
-DWITH_EXTRA_CHARSETS:STRING=all \
-DWITH_READLINE:BOOL=On \
-DWITH_SSL:STRING=bundled \
-DWITH_ZLIB=bundled \
-DWITH_LIBWRAP:BOOL=OFF \
-DENABLED_PROFILING:BOOL=ON \
-DMYSQL_UNIX_ADDR=/data/mysql/mysql.sock \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci


make && make install

----------------------------------------------------------


2.2初始化mysql.

chown -R root:mysql /usr/local/mysql

cd /usr/local/mysql

scripts/mysql_install_db --user=mysql --datadir=/data/mysql

cp support-files/my-medium.cnf /etc/my.cnf

cp support-files/mysql.server /etc/init.d/mysqld

echo "export PATH=$PATH:/usr/local/mysql/bin;" >/etc/profile.d/mysql.sh

. /etc/profile.d/mysql.sh

vi /etc/my.cnf,在[mysqld]中增加datadir=/data/mysql 与innodb-file-per-table=1

bin/mysqld_safe  --user=mysql &

chkconfig --add mysqld

chkconfig mysqld on

service mysqld status


2.3验证并删除匿名用户.

[root@mytest2 mysql]# service mysqld status

MySQL running (1581)[确定]

[root@mytest2 mysql]# mysql

Welcome to the MySQL monitor.  Commands end with ; or \g.

Your MySQL connection id is 1

Server version: 5.5.38-log Source distribution


Copyright (c) 2000, 2014, Oracle and/or its affiliates. All rights reserved.


Oracle is a registered trademark of Oracle Corporation and/or its

affiliates. Other names may be trademarks of their respective

owners.


Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.


mysql> show databases;

+--------------------+

| Database           |

+--------------------+

| information_schema |

| mysql              |

| performance_schema |

| test               |

+--------------------+

4 rows in set (0.01 sec)


mysql> select user,host,password from mysql.user;

+------+-----------+----------+

| user | host      | password |

+------+-----------+----------+

| root | localhost |          |

| root | mytest2   |          |

| root | 127.0.0.1 |          |

| root | ::1       |          |

|      | localhost |          |

|      | mytest2   |          |

+------+-----------+----------+

6 rows in set (0.01 sec)


mysql> drop user ''@'localhost';

Query OK, 0 rows affected (0.00 sec)


mysql> drop user ''@mytest2;

Query OK, 0 rows affected (0.00 sec)


mysql> drop user 'root'@'::1';

Query OK, 0 rows affected (0.00 sec)


mysql> select user,host,password from mysql.user;

+------+-----------+----------+

| user | host      | password |

+------+-----------+----------+

| root | localhost |          |

| root | mytest2   |          |

| root | 127.0.0.1 |          |

+------+-----------+----------+

3 rows in set (0.00 sec)

2.4修改权限

[root@localhost sbin]# chown -R root.mysql /usr/local/mysql-5.5.38

[root@localhost sbin]# chown -R mysql.mysql /data/mysql

[root@localhost local]# ln -s mysql-5.5.38 mysql

[root@localhost local]# chown root.mysql mysql


至此mysql安装完成.


mysql默认配置文件查找路径顺序如下:

/etc/my.cnf

/etc/mysql/my.cnf

$MYSQL_HOME/my.cnf

~/.my.cnf

启动mysql时指定的--default_extra路径.


异常的处理方法: 错误:‘SSL_OP_NO_COMPRESSION’ 未声明 (在此函数内第一次使用)

1.下载较新的openssl.

2.编译安装

./config shared zlib-dynamic --prefix=/usr/local/openssl

make && make install

3.配置

mv /usr/bin/openssl /usr/bin/openssl_bak

mv /usr/lib/include/openssl /usr/lib/include/openssl_bak

mv /usr/lib/libssl.so  /usr/lib/libssl.so_bak

mv /usr/lib64/libssl.so /usr/lib64/libssl.so_bak


ln -s /usr/local/openssl/bin/openssl /usr/bin/openssl

ln -s /usr/local/openssl/include/openssl   /usr/include/openssl

ln -s /usr/local/openssl/lib/libssl.so /usr/lib/libssl.so

ln -s /usr/local/openssl/lib/libssl.so /usr/lib64/libssl.so


echo "/usr/local/openssl/lib" >>/etc/ld.so.conf

ldconfig -v

4.配置完成后,重新编译mysql即可.