Linux下MySQL的安装

本文使用二进制文件包的方式安装,而不是yum install -y mysql-community-server方式。

安装步骤

安装环境:

  1. CentOS Linux release 7.7.1908 (Core)
  2. MySQL5.7
  3. 下载MySQL5.7的二进制包至/usr/local目录下。
# wget https://cdn.mysql.com//Downloads/MySQL-5.7/mysql-5.7.31-linux-glibc2.12-x86_64.tar.gz
  1. 校验文件md5与官方是否一致。
# md5sum mysql-5.7.31-linux-glibc2.12-x86_64.tar.gz 
bf1a97232dbab450cf73356fc74a02a3  mysql-5.7.31-linux-glibc2.12-x86_64.tar.gz
  1. 安装,参考官方文档https://dev.mysql.com/doc/refman/5.7/en/binary-installation.html。
# groupadd mysql
# useradd -r -g mysql -s /bin/false mysql
# cd /usr/local
# tar -zxvf mysql-5.7.31-linux-glibc2.12-x86_64.tar.gz
# ln -s mysql-5.7.31-linux-glibc2.12-x86_64 mysql
# cd mysql
# mkdir mysql-files
# chown mysql:mysql mysql-files
# chmod 750 mysql-files
# bin/mysqld --initialize --user=mysql
# bin/mysql_ssl_rsa_setup
# bin/mysqld_safe --user=mysql &
# cp support-files/mysql.server /etc/init.d/mysql

注意在bin/mysqld --initialize这个命令执行后会输出一个临时密码,记得保存。

  1. 设置MySQL随开机启动。
# chkconfig --add mysql
  1. 将MySQL的bin目录添加到环境变量中,在/etc/profile文件最后添加如下内存。
export PATH=$PATH:/usr/local/mysql/bin

记得让配置生效source /etc/profile

  1. 修改临时密码,使用临时密码登录后执行下面的命令,并授权远程可以连接。
mysql -uroot -p
> alter user 'root'@'localhost' identified by 'root';
> grant all privileges on *.* to root@'%' identified by "root";
> flush privileges; -- 这步好像可以省略

简单使用

连接MySQL:

mysql -uroot -p

退出MySQL连接:

mysql> quit
Bye

或者使用exit

关闭MySQL:

mysqladmin shutdown -p

启动MySQL:

systemctl start mysql

权限管理

使用Root用户,执行:

grant select on mall.* to 'dev'@'192.168.168.%' identified by 'dev'

很简单的一句sql,创建了一个dev的用户,密码为dev,仅仅运行在网段为192.168.168.*的客户端能够对mall数据库进行查询操作。

用户标识:在mysql中的权限不是单纯的赋予给用户的,而是赋予给”用户+IP”的。

再执行一条命令查看用户的权限:

mysql> show grants for 'dev'@'192.168.168.%';
+---------------------------------------------------+
| Grants for dev@192.168.168.%                      |
+---------------------------------------------------+
| GRANT USAGE ON *.* TO 'dev'@'192.168.168.%'       |
| GRANT SELECT ON `mall`.* TO 'dev'@'192.168.168.%' |
+---------------------------------------------------+

用户权限所涉及的表(位于mysql库):

  • user的一行记录代表一个用户标识。
  • db的一行记录代表对数据库的权限。
  • table_priv的一行记录代表对表的权限。
  • column_priv的一行记录代表对某一列的权限。
  • proxies_priv:角色权限,在mysql中角色就是用户。

公众号:架构师升级之路

Linux下MySQL的安装_linux