首页 > 数据库 >linux下安装绿色版(glibc版)mysql-5.7.31

linux下安装绿色版(glibc版)mysql-5.7.31

时间:2023-03-18 14:31:43浏览次数:60  
标签:初始化 绿色版 5.7 glibc 数据库 etc mysql 3306 目录

linux下安装绿色版(glibc版)mysql-5.7.31_mysql

linux下安装绿色版(glibc版)mysql-5.7.31_mysql_02

安装依赖库libaio库

# yum install libaio -y

上传软件包解压

# tar -xf mysql-5.7.31-linux-glibc2.12-x86_64.tar.gz

软件的安装

第一步:创建一个数据库专用账号mysql(其所属组也为mysql)。-r 表示创建系统用户

# useradd -r -s /sbin/nologin mysql
# id mysql

第二步:清空系统中的原有mariadb的配置文件(/etc/my.cnf)

# rm -rf /etc/my.cnf

第三步:把mysql解压后的压缩包(GBLIC版本)移动到/根目录下,然后更名为mysql_3306

# mv mysql-5.7.31-linux-glibc2.12-x86_64 /mysql_3306

第四步:切换到mysql工作目录/mysql_3306,创建一个mysql-files

# cd /mysql_3306
# mkdir mysql-files

第五步:更改mysql-files权限

# chown mysql:mysql mysql-files
# chmod 750 mysql-files

第六步:初始化数据库(可以实现数据库的初始化,而且会产生一个随机密码

# bin/mysqld --initialize --user=mysql --basedir=/mysql_3306
选项说明:
--initialize 初始化(真正开始干活)
--user=mysql 以mysql用户的身份初始化数据库,产生文件都是mysql作为拥有者
--basedir=xxx mysql其安装目录,非常重要

运行完毕后,观察最后一行,保存root账号的密码,以备后期使用。
2020-08-24T06:46:24.889735Z 1 [Note] A temporary password is generated for root@localhost: (cn_jS+*n2wh

经验之谈:想查看mysql软件有没有初始化成功,主要看mysql目录下有没有产生data文件夹且文件夹中至少要有一个mysql的文件夹。

第七步:设置安全加密连接(SSL),数据传输会采用加密形式,适合敏感数据

# bin/mysql_ssl_rsa_setup --datadir=/mysql_3306/data

第八步:启动MySQL数据库

# cp support-files/mysql.server /etc/init.d/mysql_3306

注:默认情况下,GBLIC版本的数据库要求安装到/usr/local/mysql目录,其mysql.server脚本中对应的目录也是/usr/local/mysql,这会导致mysql无法启动。所以可以更改其basedir以及datadir两个变量

# vim /etc/init.d/mysql_3306
46行 basedir=/mysql_3306
47行 datadir=/mysql_3306/data

第九步:启动MySQL数据库(不能使用systemctl,只能使用service)

# service mysql_3306 start
Starting MySQL.Logging to '/mysql_3306/data/mysql.itcast.cn.err'.

特别说明:当MySQL启动成功后,其日志会自动写入到data数据目录中的主机名称.err文件中,这个文件一定要多看,涉及MySQL无法启动、启动报错,其详细的原因99%在.err文件中可以找到问题所在!

软件的安装常见问题答疑

问题1:为什么一定要删除/etc/my.cnf文件,不删除有何影响?

答:/etc/my.cnf文件是操作系统为mariadb软件预留的配置的文件,之所以一定要删除这个文件,主要原因在于数据库在初始化时,首先在自己的安装目录下寻找有没有my.cnf配置文件,如果有,会自动根据里面的配置信息进行初始化。如果找不到,则到/etc目录下寻找my.cnf文件,如果有,依然会按照其内部的配置进行初始化,但是由于/etc目录下的my.cnf文件是mariadb的,这会导致我们的初始化如果按照mariadb的配置,会导致初始化失败。

问题2:mysql-files文件夹到底干什么的?

答:目前mysql-files没有什么用,但是你必须要创建,因为GLIBC属于二进制软件包,其很多配置已经默认了,包括mysql-files文件夹,如果没有这个文件夹可能导致mysql无法启动。

mysql-files:主要用于数据文件的导入与导出(备份与还原),MySQL的备份会产生一个文件,可以xxx.sql或xxx.txt。mysql-files就是导入与导出时,所指定的默认目录。

问题3:到底怎么判断数据库是否初始化成功了?

答:数据库的安装容易出错的地方就是初始化,一旦初始化失败了,数据库100%启动报错。如何确认数据库是否初始化成功了呢?主要看安装目录下有没有生成一个data的文件夹。

一定要看准一点,文件夹名称叫data(数据目录),不是date(时间)

问题4:为什么一定要把mysql.server放在/etc/init.d目录下,不放行不行?

答:不放也可以,但是这个时候就不能使用service命令启动以及添加到开机启动项了。只能通过bin/mysqld_safe脚本启动数据库。

/etc/init.d是CentOS6以及早期版本中的服务脚本目录,只要把Shell启动脚本放在这个目录下,你就可以使用service进行管理。

问题5:为什么一定要改变/etc/init.d/mysql_3306中的basedir与datadir?

答:GLIBC版本属于二进制版本,默认已经配置了很多内容,包括默认的安装路径/usr/local/mysql,一旦你的mysql没有安装在这个目录下,则必须手工设置basedir以及datadir其位置,否则脚本无法启动mysql程序

问题6:如何让mysql自动启动?

# chkconfig --list              查询系统中的所有开机启动项
# chkconfig --add mysql_3306 必须与/etc/init.d目录下的脚本名称一致
# chkconfig mysql_3306 on 把2345四种模式全部开启(3字符界面,5图形界面)

CentOS6及以前版本中,控制服务的开机启动的

MySQL GLIBC版本后续配置

第一步:更改管理员root账号的密码

  • 方法1:
[root@node1 mysql_3306]# bin/mysqladmin -uroot password '123' -p
Enter password:输入刚刚初始化产生的临时密码
  • 方法2
mysql> set password=password('456');        //未来版本将会弃用
或者
mysql> set password='123'; //推荐

重置完成后,建议刷新权限,让其立即生效
mysql> flush privielges;

第二步:把mysql客户端命令添加到环境变量,以后随时可以访问

# echo 'export PATH=$PATH:/mysql_3306/bin' >> /etc/profile
# source /etc/profile

设置完成后,我们可以在任意位置调用mysql客户端命令
# mysql -uroot -p
Enter password:123

第三步:手工定义MySQL的配置文件(非常重要)

# vim /mysql_3306/my.cnf
[mysqld]
basedir=/mysql_3306
datadir=/mysql_3306/data
socket=/tmp/mysql.sock
选项说明:
[mysqld] 代表针对服务器端进行配置
basedir 代表数据库的安装目录
datadir 代表数据目录,以后专门用于存放数据文件的(核心目录)
socket 代表套接字文件,专门为客户端与服务器端连接提供一个桥梁

# service mysql_3306 restart

C(Client) === mysql命令 连(socket套接字)接 mysqld服务器端程序

第四步:安全配置(对于生产环境比较重要)

# mysql_secure_installation

一路Y,搞定!

其主要就是是否启动密码脚尖器、是否设置root密码、是否允许root远程连接、是否移除测试数据库等等一系列功能。

常见问题:如何关闭MySQL密码强度检测?

# vim /mysql_3306/my.cnf
[mysqld]
...
validate_password=OFF

# service mysql_3306 restart




标签:初始化,绿色版,5.7,glibc,数据库,etc,mysql,3306,目录
From: https://blog.51cto.com/zwl28/6129658

相关文章

  • wifi大师管理后台源码+微擎框架v2.7.8、2.5.7+wifi大师小程序
    最近很火的wifi大师管理后台源码只要给商家推荐就可赚取广告收益,这种是怎么实现的呢,我们来看一下下面先把源码给大家放出来,大家可以试着玩一下!wifi大师源码及详细安装......
  • 16.MySQL数据库之mysql-5.7 show engine innodb status 详解,常用的地方一、死锁分析 
     一、show engine innodb status 简介:show engine innodb status 是mysql提供的一个用于查看innodb引擎时间信息的工具,就目前来说有两处比较常用的地......
  • docker my5.7 主从部署
    主配置文件:[mysqld]##设置server_id,同一局域网中需要唯一server_id=101##指定不需要同步的数据库名称binlog-ignore-db=mysql##开启二进制日志功能log-bin=mall-mysql-......
  • Docker部署mysql5.7与redis6.2.6
    Linux环境:centos7.6#首先创建docker相关数据卷挂载目录mkdir-pdocker/{nexus3,mysql,redis}一、部署mysql1.搜索版本dockersearchmysql2.安装mysql5.7dockerpu......
  • mysql5.7msi安装
    本文介绍的是只安装MySQL数据库的过程,并不包含各种其他附加工具。安装完成之后通常使用Navicat或SQLyog进行可视化操作。清华的镜像网站只保存最新的几个MySQL版本,所以直......
  • MySQL5.7主从复制教程
     MySQL5.7主从复制教程 ​简述:主从复制,是用来建立一个和主数据库完全一样的数据库环境,称为从数据库,主数据库一般是准实时的业务数据库、事务处理库,从库做查询库。......
  • mysql5.7修改密码
    mysql>updatemysql.usersetauthentication_string=password('123qwe')whereuser='root'andHost='localhost';mysql>alteruser'root'@'localhost'identifie......
  • Linux离线安装mysql5.7
    下载mysql:https://dev.mysql.com/downloads/mysql/5.7.html#downloads  切换到root用户解压mysql压缩包tar-zxvfmysql-5.7.24-linux-glibc2.12-x86_64.tar.......
  • mysql5.7之JSON数据类型
    1、json对象1.1、方法使用对象操作的方法进行查询:字段->'$.json属性'使用函数进行查询:json_extract(字段,'$.json属性')获取JSON数组/对象长度:JSON_LENGTH()1.2、......
  • 5.76 float类型如何强转为6 int类型
    看到LINFLEXD驱动里面,在float转int类型时,有如下操作(红圈处),  NXPsupport回复如下: 大致意思如下例:错误做法:5.76强转为int类型,会丢掉0.76,最终成为5,与实际数值......