MySQL 源码安装详细记录

创建mysql数据目录
mkdir -p /usr/local/mysql       --安装目录  
mkdir -p /usr/local/mysql/data   ---数据目录  
创建mysql用户和组
groupadd mysql  
useradd -r -g mysql mysql  
安装必要依赖或者环境
yum install gcc gcc-c++ autoconf bison cmake automake zlib* fiex* libxml* ncurses-devel libmcrypt* libtool-ltdl-devel*  
编译安装

下载源码:http://dev.mysql.com/downloads/mysql/ 这里采用5.6

wget http://dev.mysql.com/get/Downloads/MySQL-5.6/mysql-5.6.29.tar.gz  
tar zxvf mysql-5.6.29.tar.gz

cmake \  
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
-DMYSQL_DATADIR=/usr/local/mysql/data \
-DSYSCONFDIR=/etc \
-DWITH_MYISAM_STORAGE_ENGINE=1 \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_MEMORY_STORAGE_ENGINE=1 \
-DWITH_FEDERATED_STORAGE_ENGINE=1 \
-DWITH_READLINE=1 \
-DMYSQL_UNIX_ADDR=/usr/local/mysql/data/mysql.sock \
-DMYSQL_TCP_PORT=3306 \
-DENABLED_LOCAL_INFILE=1 \
-DWITH_PARTITION_STORAGE_ENGINE=1 \
-DEXTRA_CHARSETS=all \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci

make  
make install  

具体选项可参考mysql官方:http://dev.mysql.com/doc/refman/5.5/en/source-configuration-options.html。

-DCMAKE_INSTALL_PREFIX=/usr/local/mysql        //安装目录
-DINSTALL_DATADIR=/usr/local/mysql/data         //数据库存放目录
-DDEFAULT_CHARSET=utf8                        //使用utf8字符
-DDEFAULT_COLLATION=utf8_general_ci            //校验字符
-DEXTRA_CHARSETS=all                            //安装所有扩展字符集
-DENABLED_LOCAL_INFILE=1                        //允许从本地导入数据
-DINSTALL_SBINDIR=                     mysqlid目录
-DSYSCONFDIR=                              my.cnf配置文件目录
-DINSTALL_PLUGINDIR=                 插件目录
-DINSTALL_MANDIR=                      手册文件目录
-DINSTALL_SHAREDIR=                  共享数据目录
-DINSTALL_LIBDIR=                        library库目录
-DINSTALL_INCLUDEDIR=               header安装目录
-DINSTALL_INFODIR=                            信息文档目录

存储引擎相关参数(- DWITH代表启用,-DWITHOUT代表不启用,mysql默认支持的数据库引擎有MyISAM, MERGE, MEMORY, CSV,无需在编译时再声明):

-DWITH_MYISAM_STORAGE_ENGINE=1 \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_MEMORY_STORAGE_ENGINE=1 \
-DWITH_FEDERATED_STORAGE_ENGINE=1 \
-DWITH_PARTITION_STORAGE_ENGINE=1 \
-DWITH_ARCHIVE_STORAGE_ENGINE=1
授予mysql用户权限
chown -R mysql:mysql /usr/local/mysql  
创建系统数据库和表
cd /usr/local/mysql  
scripts/mysql_install_db --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --user=mysql  
mysql_install_db 脚本的目的是生成新的MySQL授权表。不会覆盖已有的MySQL授权表,并且不影响任何其它数据。所有的数据库相关文件都会默认在/usr/local/mysql/data路径下  
mv /usr/local/mysql/my.cnf /etc/my.cnf  
chown -R mysql:mysql /usr/local/mysql  
配置mysql启动服务
进入源码包文件夹
cp support-files/mysql.server /etc/init.d/mysql  
chmod +x /etc/init.d/mysql   --授予文件可执行权限  
chkconfig mysql on  --配置mysql开机自动启动  
service mysql start  --启动MySQL  
配置环境变量
为了能直接调用mysql命令,需要配置环境变量
vim /etc/profile  
在/etc/profile文件末尾添加
export PATH=/usr/local/mysql/bin:$PATH  
使环境变量立即生效
source /etc/profile  
设置mysql root用户密码
默认mysql root用户安装完密码为空,另:MySQL5.7安装完的用户密码不为空,在安装日志文件会显示。
mysql -uroot  ---登入  
SET PASSWORD = PASSWORD('root');  --设置root密码