源码安装mysql-5.7.17(centos-6.8-minimal)

时间:2022-09-22 12:52:55
官方文档
http://dev.mysql.com/doc/refman/5.7/en/installing-source-distribution.html

准备工作
1.安装wget、gcc、gcc-c++、bison、ncurses、ncurses-devel
2.安装cmake
     $ cd /usr/local/src/
     $ wget https://cmake.org/files/v3.7/cmake-3.7.1.tar.gz
     $ tar zxvf cmake-3.7.1.tar.gz
     $ cd cmake-3.7.1
     $ ./bootstrap && gmake && gmake install
3.此版本需要boost_1_59_0,下载解压到某个目录,安装mysql时需要指定。另外,mysql官网提供含有boost的mysql源码包。
     $ wget https://nchc.dl.sourceforge.net/project/boost/boost/1.59.0/boost_1_59_0.tar.gz
     $ tar zxf boost_1_59_0.tar.gz
     $ mv boost_1_59_0 /usr/local/

4.下载mysql源码包(不含boost)并解压
     $ cd /usr/local/src/
     $ wget https://cdn.mysql.com//Downloads/MySQL-5.7/mysql-5.7.17.tar.gz
     $ tar zxvf mysql-5.7.17.tar.gz

安装过程
1.创建用户和组mysql:mysql
     $ groupadd mysql
     $ useradd -r -g mysql -s /sbin/nologin mysql

2.编译安装mysql
     $ cd /usr/local/src/mysql-5.7.17

     $ mkdir build
     $ cd build
     $ cmake ..   -DCMAKE_INSTALL_PREFIX=/usr/local/mysql  -DSYSCONFDIR=/etc  -DMYSQL_DATADIR=/data/mysql-DMYSQL_USER=mysql  -DMYSQL_UNIX_ADDR=/tmp/mysql.sock  -DMYSQL_TCP_PORT=3306  -DWITH_MYISAM_STORAGE_ENGINE=1  -DWITH_INNOBASE_STORAGE_ENGINE=1  -DWITH_MEMORY_STORAGE_ENGINE=1  -DWITH_PARTITION_STORAGE_ENGINE=1  -DDEFAULT_CHARSET=utf8  -DDEFAULT_COLLATION=utf8_general_ci  -DEXTRA_CHARSETS=all  -DENABLED_LOCAL_INFILE=1  -DWITH_BOOST=/usr/local/boost_1_59_0  
     $ make && make install             ###可以用多个线程同时编译安装   make -j4 && make -j4 install     ##表示用4个线程同时编译

3.初始化

     $ cd /usr/local/mysql
     $ chown -R mysql:mysql .
     $ mkdir -p /data/mysql
     $ chown -R mysql.mysql /data/mysql
     $ ./bin/mysqld --initialize   --user=mysql   --basedir=/usr/local/mysql   --datadir=/data/mysql
     $ ./bin/mysql_ssl_rsa_setup --datadir=/data/mysql

5.7.6及以上版本使用 ./bin/mysqld --initialize 初始化数据库;
初始化后,会生成随机密码,示例:[Note] A temporary password is generated for root@localhost: Wtng#?e&S5,-。
./bin/mysql_ssl_rsa_setup需要openssl支持,用于启用数据量ssl连接,需要进一步配置。


4.配置文件

     $ cp support-files/my-default.cnf /etc/my.cnf
     $ vim !$
     修改部分:
     basedir = /usr/local/mysql
     datadir = /data/mysql
     port = 3306
     socket = /tmp/mysql.sock

5.启动脚本

    $ cp support-files/mysql.server /etc/init.d/mysqld
    $ vim !$
    修改部分:
    basedir = /usr/local/mysql
    datadir = /data/mysql
启动脚本有两个,分别是 /usr/local/mysql/bin/mysqld_safe 和 /usr/local/mysql/support-files/mysql.server(即/etc/init.d/mysqld)。当启动mysqld时,mysqld_safe同时启动,mysqld_safe监控mysqld服务,记录错误日志,并在mysqld因故障停止时将其重启。

6.启动mysqld服务
    /etc/init.d/mysqld start

若想设置开机启动:(任选一个)

    $ chkconfig --add mysqld
    $ chkconfig mysqld on
    $ service mysqld start


建立一个软连接,方便使用mysql命令

ln -s /usr/local/mysql/bin/mysql mysql
重置root本地账户的密码
alter user 'root'@'localhost' identified by '新密码';
重置权限表
flush privileges;

===============创建用户===============
CREATE USER 'username'@'host' IDENTIFIED BY 'password';
释义:
username:将要创建的用户名
host:指定该用户在哪个主机上可以登陆;本地可用localhost或者127.0.0.1,如果可以从任意远程主机登陆为%
password:该用户的登录密码

===============授权==================
GRANT privileges ON databasename.tablename TO 'username'@'host';
释义:
privileges:用户的操作权限,如SELECT , INSERT , UPDATE 等(详细列表见该文最后面).如果要授予所的权限则使用ALL.
databasename:数据库名
tablename:表名,如果要授予该用户对所有数据库和表的相应操作权限则可用*表示, 如*.*

例子: GRANT SELECT, INSERT ON test.user TO 'pig'@'%';
GRANT ALL ON *.* TO 'pig'@'%';

注意:用以上命令授权的用户不能给其它用户授权,如果想让该用户可以授权,用以下命令:
GRANT privileges ON databasename.tablename TO 'username'@'host' WITH GRANT OPTION;

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