翼度科技»论坛 编程开发 mysql 查看内容

Linux安装Mysql

4

主题

4

帖子

12

积分

新手上路

Rank: 1

积分
12
前提

使用Centos7进行安装教程
1、查看是否安装过mysql
  1. rpm -qa | grep mysql
复制代码

如果你查看出来有东西,可以使用下面命令将其删除(xxx 为文件全名)
  1. rpm -e xxx
  2. # 强力删除模式,如果使用上面命令删除时,提示有依赖的其它文件,则用该命令可以对其进行强制删除
  3. rpm -e --nodeps mysql
复制代码
如果没有直接进入第2步
2、下载官方Mysql安装包:https://downloads.mysql.com/archives/community/
选择对应的包,如下5.7:

 已下载安装包:mysql-5.7.35-linux-glibc2.12-x86_64.tar.gz
 Mysql安装与配置

1、上传安装包至服务器并进行解压
  1. # 创建安装包上传路径
  2. mkdir -p /usr/local/mysql
  3. # 进入到该目录下
  4. cd /usr/local/mysql
  5. #(解压后可删除安装包,节省空间)
  6. tar -zxvf mysql-5.7.35-linux-glibc2.12-x86_64.tar.gz
  7. # 重命名解压后的mysql安装目录
  8. mv mysql-5.7.35-linux-glibc2.12-x86_64 mysql-5.7.35
  9. # 进入该目录
  10. cd mysql-5.7.35
复制代码
 2、创建用户组和用户

 Root用户是最高权限用户,所以一般都是创建用户和用户组,防止最高权限用户进行操作。
  1. # 添加用户组,命名为mysql
  2. groupadd mysql
  3. # 创建用户mysql,并指定所属群组为mysql
  4. useradd -r -g mysql mysql
复制代码
3、赋权,用用户组和用户具有操作权限

注意:.表示本级目录,一定要保证当前所在文件夹是/usr/local/mysql/mysql-5.7.35中
  1. # 变更mysql用户组有操作当前文件夹权限
  2. chgrp -R mysql .
  3. # 变更mysql用户具有操作本级目录权限
  4. chown -R mysql .
  5. # 上面两个命令也可换成一条命令
  6. chown -R mysql:mysql ./
复制代码
 4、初始化

 注意:保证当前所在文件夹是在/usr/local/mysql/mysql-5.7.35中
  1. # 判断/etc/my.cnf是否存在,存在则删除
  2. ls /etc/my.cnf
  3. # 存在删除,不存在跳过此步骤
  4. rm /etc/my.cnf
  5. # 初始化数据库
  6. ./scripts/mysql_install_db --user=mysql
复制代码
5、修改配置文件

配置my.cnf和启动文件,根据需要进行修改,不需要特殊操作,可以直接复制
 注意:保证当前所在文件夹是在/usr/local/mysql/mysql-5.7.35中
  1. # 复制my.cnf
  2. cp support-files/my-default.cnf /etc/my.cnf
  3. # 复制启动文件
  4. cp support-files/mysql.server /etc/rc.d/init.d/mysql
复制代码
启动、重启、关闭mysql服务
  1. # start:启动 restart:重启 关闭:stop
  2. service mysql start
复制代码
Mysql必须在启动状态下,才可修改密码(下一步操作)
6、操作Mysql数据库

进入到mysql编辑模式
mysql -u root -p
会提示要求输入密码,此时在mysql日志文件中找到初始密码,命令如下:
  1. # 从当前数据库的日志文件中找出初始随机密码
  2. grep "password" /var/log/mysqld.log
复制代码

再次进入mysql编辑模式:mysql -u root -p
输入初始密码,此时不能做任何事情,因为MySQL默认必须修改密码之后才能操作数据库
注意:输入密码期间不能输入其他内容,输入密码是隐藏不可见的
  1. -- 修改为自己的密码
  2. ALTER USER 'root'@'localhost' IDENTIFIED BY 'new password';
复制代码
注意:Mysql密码设定有默认策略,简单的密码设置不了,还会报以下错误

解决方法:

可先按照策略修改一个密码,然后使用密码重新登录过后修改策略,策略修改后即可重复修改密码语句进行重新设定密码
默认策略:大写+小写+数字+符号
如果提示没有mysql命令,需要添加软连接
ln -s /usr/local/mysql/mysql-5.7.35/bin/mysql /usr/bin/mysql
进入到mysql命令后,出现[mysql>]
此时就可以根据自己需要创建数据库、创建表等CRUD操作。
远程访问
  1. --进入mysql数据库--
  2. use mysql;
  3. --修改user表的root账户的host内容--
  4. update user set host="%" where user="root";
  5. --刷新修改立即生效--
  6. flush privileges;
复制代码
7、策略修改

对比Mysql8.+和Mysql5.7及一下版本策略,注意变量名称的不同
  1. -- 查看当前策略
  2. SHOW VARIABLES LIKE 'validate_password%';
复制代码

  1. -- 更改密码验证规则 Mysql5.7-
  2. set global validate_password_policy=0;
  3. set global validate_password_length=1;
  4. -- 更改密码验证规则 Mysql8.*
  5. set global validate_password.policy=0;
  6. set global validate_password.length=1;
复制代码
更改完成之后就可以重复修改密码步骤进行再次修改啦
8、忘记密码后修改方式

进入/etc/my.cnf在[mysql]下添加skip-grant-tables启动安全模式
vim /etc/my.cnf
登录mysql,输入密码时直接回车
mysql -u root -p
修改密码:update user set password = password("root123") where user = 'root';
刷新权限:flush privileges;
退出Mysql编辑模式:exit
 9、设置用户具有远程访问权限

进入mysql编辑模式:mysql -u root -p
执行远程连接权限赋予命令:GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root123' WITH GRANT OPTION;
刷新权限:flush privileges;
mysql8.0需要分步骤执行,命令如下:
  1. -- 创建新用户
  2. create user 'admin'@'%' identified by 'password';
  3. -- 执行授权
  4. GRANT ALL PRIVILEGES ON *.* TO 'admin'@'%';
  5. -- 刷新
  6. flush privileges;
  7. -- 授权远程
  8. ALTER USER 'admin'@'%' IDENTIFIED WITH mysql_native_password BY 'password';
  9. -- 刷新
  10. flush privileges;
复制代码
退出Mysql编辑模式:exit 

来源:https://www.cnblogs.com/aerfazhe/p/17167429.html
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x

举报 回复 使用道具