linux centos7 下源码 tar 安装 mysql5.7.24 图文详解

环境

  • Centos7

安装依赖

 yum install -y cmake make gcc gcc-c++ bison ncurses ncurses-devel

有兴趣的同学也可以看看这个 CentOS7.2 创建本地 YUM 源 CentOS 二进制包 / 源码安装方式的 MySQL 卸载

下载和解压

 cd /usr/local/lib64 #我之前从官网下载好了 mysql-5.7.24-linux-glibc2.12-x86_64.tar.gz 放到了此目录

tar -zxvf mysql-5.7.24-linux-glibc2.12-x86_64.tar.gz
#复制
cp -r mysql-5.7.24-linux-glibc2.12-x86_64.tar.gz /usr/local/mysql

添加系统 mysql 组和 mysql 用户

#添加系统 mysql 组 
groupadd mysql
#添加 mysql 用户,(添加完成后可用id mysql查看)
useradd -r -g mysql mysql 

安装数据库

#切到 mysql 目录 
cd /usr/local/mysql
#修改当前目录拥有者为 mysql 用户 
chown -R mysql:mysql ./
#安装数据库 
bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data
#生成了临时密码 4Q2HAvA>PI2g

#执行以下命令创建 RSA private key 
bin/mysql_ssl_rsa_setup --datadir=/usr/local/mysql/data
#修改当前目录拥有者为 mysql 用户 
chown -R mysql:mysql ./
#修改当前 data 目录拥有者为 mysql 用户 
chown -R mysql:mysql data

配置 my.cnf

vi /etc/my.cnf (直接把下面内容复制上就行)
[mysqld]
character_set_server=utf8
init_connect='SET NAMES utf8'
basedir=/usr/local/mysql
datadir=/usr/local/mysql/data
socket=/tmp/mysql.sock
#不区分大小写 (sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES 这个简单来说就是sql语句是否严格)
lower_case_table_names = 1
log-error=/var/log/mysqld.log
pid-file=/usr/local/mysql/data/mysqld.pid

其他配置

#添加开机启动
cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld
#修改
vi /etc/init.d/mysqld
basedir=/usr/local/mysql
datadir=/usr/local/mysql/data

#启动
mysql service mysqld start
#加入开机起动
chkconfig --add mysqld

登录修改密码 mysql -uroot -p 上面初始化时的密码

#如果出现错误 需要添加软连接
ln -s /usr/local/mysql/bin/mysql /usr/bin
#第一件事先修改密码
alter user 'root'@'localhost' identified by 'root';
#刷新权限
flush privileges;
#授权新用户
GRANT ALL PRIVILEGES ON *.* TO 'root1'@'%' IDENTIFIED BY 'root' WITH GRANT OPTION;