centos6.5编译安装mysql5.6.20

centos6.5编译安装mysql5.6.20

一.   准备工作

1     yum安装各个依赖包

[root@WebServer ~]# yum –y install gcc gcc-devel gcc-c++ gcc-c++-devel  zlib*  ncurses-devel ncurses openssl openssl-devel bison bison-devel libaio

[root@WebServer ~]# yum –y install cmake

 

2.新建mysql组和用户

[root@WebServer ~]# groupadd mysql

[root@WebServer ~]# useradd –g mysql –s /sbin/nologin mysql

 

3.目录准备

[root@WebServer ~]# mkdir –p /hywl/mysql/etc

[root@WebServer ~]# mkdir –p / hywl/mysql/data

[root@WebServer ~]# mkdir –p / hywl/mysql/tmp

[root@WebServer ~]# chown –R mysql.mysql /hywl/mysql

 

4.解压MySQL并进入安装目录

拷贝mysql-5.6.20.tar.gz/home/mysql目录下

[root@WebServer ~]# tar zxvf mysql-5.6.20.tar.gz

[root@WebServer ~]# cd mysql-5.6.20

 

 

二.   编译并安装

1 .下载gmock-1.6.0.zip/home/mysql/mysql-5.6.20/source_downloads目录下并编译安装:

[root@WebServer mysql-5.6.20]# cd source_downloads/

[root@WebServer source_downloads]# unzip gmock-1.6.0.zip

root@WebServer source_downloads]# cd gmock-1.6.0

[root@WebServer gmock-1.6.0]# ./configure

[root@WebServer gmock-1.6.0]# make

[root@WebServer gmock-1.6.0]# cd ..

 

2.编译MySQL

[root@WebServer mysql-5.6.20]# cmake –DCMAKE_INSTALL_PREFIX=/hywl/mysql \

-DSYSCONFDIR=/hywl/mysql/etc \

-DMYSQL_DATADIR=/hywl/mysql/data \

-DMYSQL_TCP_PORT=3306 \

-DMYSQL_UNIX_ADDR=/hywl/mysql/tmp/mysqld.sock \

-DMYSQL_USER=mysql \

-DEXTRA_CHARSETS=all \

-DWITH_READLINE=1 \

-DWITH_SSL=system \

-DWITH_EMBEDDED_SERVER=1 \

-DENABLED_LOCAL_INFILE=1 \

-DWITH_INNOBASE_STORAGE_ENGINE=1 \

-DENABLE_DOWNLOADS=1

*如果出现错误,删除mysql-5.6.20目录下的CmakeCache.txt重新使用cmake进行编译安装

 

3.安装

[root@WebServer mysql-5.6.20]# make && make install 时间有点长。

 

.MySQL配置

1.客户端库文件的链接(未执行此步骤的话,在PHP编译时会提示找不到MySQL文件)

[root@WebServer mysql-5.6.20]# ln –s /hywl/mysql/lib/libmysqlclient.so.18 /usr/lib64/libmysqlclient.so.18

 

ps:我使用的是64CentOS,如果使用的是32位请使用ln –s / hywl /mysql/lib/libmysqlclient.so.18 /usr/lib/libmysqlclient.so.18

 

2.MySQL启动文件的配置

[root@WebServer mysql-5.6.20]# cp support-files/mysql.server /etc/init.d/mysqld

[root@WebServer mysql-5.6.20]# chmod +x /etc/init.d/mysqld

[root@WebServer mysql-5.6.20]# vim /etc/init.d/mysqld

basedir=/hywl/mysql

datadir=/hywl/mysql/data

//修改以上这2行的路径即可

 

3.设置MySQL配置文件

[root@WebServer mysql-5.6.20]# cp support-files/my-default.cnf / hywl /mysql/etc/my.cnf

[root@WebServer mysql-5.6.20]# rm –rf /etc/my.cnf

[root@WebServer mysql-5.6.20]# ln –s / hywl /mysql/etc/my.cnf /etc/my.cnf

 

4.初始化数据库

[root@WebServer mysql-5.6.20]# cd / hywl /mysql

[root@WebServer mysql]# ./scripts/mysql_install_db –user=mysql –basedir=/hywl/mysql –datadir=/ hywl /mysql/data

 

5.链接MySQL命令(这一步可以让我们方便很多,可以不用写出命令的路径,也可以写入/etc/profilePATH中)

可以修改环境变量:vi  /etc/profile

增加一行:export PATH=/hywl/mysql/bin:$PATH

[root@WebServer mysql]#source /etc/profile

这时再查看系统环境变量,就能看见刚才加的东西已经生效了

 

[root@WebServer mysql]#echo $PATH

 

也可以:

[[root@WebServer mysql]#cd /usr/sbin

[root@WebServer sbin]# ln –s / hywl /mysql/bin/*

 

6.启动MySQL并设置为开机启动

[root@WebServer sbin]# service mysqld start ;chkconfig mysqld on

Starting MySQL.. SUCCESS!

 

7.设置MySQL root用户的密码

[root@WebServer ~]# mysqladmin –u root password mysql

强烈不建议将数据库的密码设的简单

 

8.删除用户密码为空的用户

[root@WebServer ~]# mysql –u root –p

Enter password:

mysql> use mysql;

mysql> select Host,User,Password from user;

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

| Host      | User | Password                                  |

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

| localhost | root | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 |

| webserver | root |                                          |

| 127.0.0.1 | root |                                          |

| ::1      | root |                                          |

| localhost |      |                                          |

| webserver |      |                                          |

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

6 rows in set (0.00 sec)

mysql> delete from user where password=””;

Query OK, 5 rows affected (0.00 sec)

mysql> flush privileges;

Query OK, 0 rows affected (0.00 sec)

mysql> select Host,User,Password from user;

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

| Host      | User | Password                                  |

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

| localhost | root | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 |

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

1 row in set (0.00 sec)

mysql> exit;

9.如何知道你的数据目录在哪里。如果你运行多个服务器,你应该知道所有数据目录在哪里,但是如果你不知道确切的位置,由多种方法找到它:

9.1使用mysqladmin variables从你的服务器直接获得数据目录路径名。查找datadir变量的值,在Unix上,其输出类似于:
%mysqladmin -u username -p variables

+----------------------+----------------------+
| variable_name        | Value                |
+----------------------+----------------------+
| back_log             | 5                    |
| connect_timeout      | 5                    |
| basedir              | /var/local/          |
| datadir              | /usr/local/var/      |
....
9.2查找mysql运行的路径
%ps -ef | grep mysqld  

本文出自 “jack” 博客,请务必保留此出处http://396386.blog.51cto.com/386386/1543301

centos6.5编译安装mysql5.6.20,古老的榕树,5-wow.com

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。