ubuntu 14.04 64位 下 编译安装MySQL 5.7.11

步骤一:

先去mysql的官方网站 去down 编译源码包

mysql 网址:www.mysql.com

downloads (MySQL Community Server

下载版本选择 source code 然后找到

Generic Linux (Architecture Independent), Compressed TAR Archive5.5.2923.7M

Download

(mysql-5.5.29.tar.gz)

步骤二:

先要安装几个插件要不然 cmake不成功

1.apt-get install cmake

2.apt-get install libncurses5-dev (我忘了这个是在哪里需要的了,不是cmake时候就是make的时候,如果你没有安装他会提醒你的注意看输出的信息就行)

3.apt-get install gcc c++ bison libaio1

4. 安装基本编译工具apt-get install build-essential automake autoconf cmake

5.需要在下boost组件

https://sourceforge.net/projects/boost/files/boost/

放到 /usr/local/boost 目录下

此时boost目录下应该有 boost_1_59_0 文件夹

对下载下来的源码包进行解压 编译安装

tar zxvf mysql-5.7.11. tar.gz

cd mysql-5.7.11

5.运行以下命令行编译 mysql,比较长,记得编译时是把下面的多行一起复制到命令窗口编译

cmake \

-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \

-DMYSQL_DATADIR=/mysql/data \

-DMYSQL_UNIX_ADDR=/tmp/mysql.sock \

-DDEFAULT_CHARSET=utf8 \

-DDEFAULT_COLLATION=utf8_general_ci \

-DEXTRA_CHARSETS=all \

-DENABLED_LOCAL_INFILE=1 \

-DDOWNLOAD_BOOST=1 \

-DWITH_BOOST=/usr/local/boost/boost_1_59_0

6.make

7.make install

//注意新版的mysql 安装完毕以后会自动在 etc下创建一个mysql 文件夹 ,文件夹内有my.cnf配置文件

8. sudo cp /usr/local/mysql/support-files/my-default.cnf /etc/my.cnf (复制原mysql的配置文件 作为etc下的配置文件)

9. 编辑 my.cnf 文件以支持 innodb,(去掉配置文件中前面带# )去掉#以后的如下:

[mysqld]

basedir=/usr/mysql

datadir=/usr/mysql/data

user=mysql

  1. # Uncomment the following if you are using InnoDB tables
  2. innodb_data_home_dir = /home/mysql/3306/data
  3. innodb_data_file_path = ibdata1:10M:autoextend
  4. innodb_log_group_home_dir = /home/mysql/3306/data
  5. # You can set .._buffer_pool_size up to 50 - 80 %
  6. # of RAM but beware of setting memory usage too high
  7. innodb_buffer_pool_size = 16M
  8. innodb_additional_mem_pool_size = 2M
  9. # Set .._log_file_size to 25 % of buffer pool size
  10. innodb_log_file_size = 5M
  11. innodb_log_buffer_size = 8M
  12. innodb_flush_log_at_trx_commit = 1
  13. innodb_lock_wait_timeout = 50

10.

sudo adduser xxx 这样的命令会在home目录下添加一个帐号

sudo useradd xxx 仅仅是添加用户, 不会在home目录添加帐号

cd /usr/local/mysql

chown -R mysql:mysql . (所有的文件都属组属主)

11.

初始化数据库

sudo /usr/local/mysql/scripts/mysql_install_db --defaults-file=/home/mysql/3306/my.cnf --user=mysql --basedir=/usr/local/mysql --datadir=/home/mysql/3306/data

12.

启动数据库

sudo /usr/local/mysql/bin/mysqld_safe --defaults-file=/home/mysql/3306/my.cnf --user=mysql --basedir=/usr/local/mysql --datadir=/home/mysql/3306/data &

13.

修改用户名密码,其中的 NEW_PASSWORD 换成你自己想要设置的密码

/usr/local/mysql/bin/mysqladmin -u root password 'YOUR PASSWORD'

关闭数据库使用如下命令

/usr/local/mysql/bin/mysqladmin -u root -p shutdown

14. 做一个符号链接:ln -s /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql

15 启动:mysql start...这里遇到一问题:Couldn't find MySQL manager (/usr/bin/mysqlmanager) or server (/usr/bin/mysqld_safe),解决:在/usr/bin下面建立一个/usr/local/mysql/bin/mysqld_safe的软连接。

=========================================================================================================

如果出现该错误 The server quit without updating PID file (/var/run/mysqld/mysqld.pid).

请用以下办法进行解决,

然后在/home/mysql/3306/ 下 建立 一个软链接

sudo /etc/my.cnf /home/mysql/3306/

然后在:

sudo vi /etc/init/mysql

修改:

basedir=/usr/local/mysql

datadir=/home/mysql/3306/data

然后在重启 sudo /etc/init.d/mysql restart

就成功了