Linux下MySQL的安装

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中角色就是用户。

更多精彩内容关注本人公众号:架构师升级之路
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

morris131

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值