Linux下MySQL的安装
本文使用二进制文件包的方式安装,而不是yum install -y mysql-community-server
方式。
安装步骤
安装环境:
- CentOS Linux release 7.7.1908 (Core)
- MySQL5.7
- 下载MySQL5.7的二进制包至/usr/local目录下。
# wget https://cdn.mysql.com//Downloads/MySQL-5.7/mysql-5.7.31-linux-glibc2.12-x86_64.tar.gz
- 校验文件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
- 安装,参考官方文档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
这个命令执行后会输出一个临时密码,记得保存。
- 设置MySQL随开机启动。
# chkconfig --add mysql
- 将MySQL的bin目录添加到环境变量中,在
/etc/profile
文件最后添加如下内存。
export PATH=$PATH:/usr/local/mysql/bin
记得让配置生效source /etc/profile
。
- 修改临时密码,使用临时密码登录后执行下面的命令,并授权远程可以连接。
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中角色就是用户。
公众号:架构师升级之路