Centos7.6 安装mysql过程全记录

这篇具有很好参考价值的文章主要介绍了Centos7.6 安装mysql过程全记录。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

在centos 7.6上 离线安装mysql 的步骤,可参考下文:

一、查看当前MySQL的安装情况并卸载

1. 查看当前MySQL的安装情况

查找之前是否安装了MySQL

rpm -qa|grep -i mysql

Centos7.6 安装mysql过程全记录,数据库,mysql,数据库

2.卸载mysql

如果已经安装mysql,则需要先停止MySQL,再删除之前安装的MySQL ,把rpm -qa | grep mysql 得到的安装包名XXX 写上即 rpm -ev xxx 

rpm -ev bt-mysql56-5.6.47-1.el7.x86_64

3.删除老版本的目录

查找之前MySQL的目录,删除老版本的目录

find / -name mysql

删除MySQL对应的目录:

rm -rf xxxx/mysql

注意:卸载后配置文件 /etc/my.cnf 不会删除,需要手动删除

 rm -f /etc/my.cnf

4. 再次查看是否安装MySQL,确保MySQL完全卸载

rpm -qa|grep -i mysql

没有结果显示,说明MySQL已经被完全卸载干净,接下来就可以重新安装自己想要的MySQL版本了。

二、安装Mysql

1.创建mysql用户组和用户

检查mysql用户组和用户是否存在,如果没有,则创建

cat /etc/group | grep mysql

cat /etc/passwd |grep mysql

groupadd mysql

useradd -r -g mysql mysql

Centos7.6 安装mysql过程全记录,数据库,mysql,数据库

Centos7.6 安装mysql过程全记录,数据库,mysql,数据库

2.下载Mysql包

若服务器并不连接外网,需要将预先下载到的mysql安装包,通过内网导文件方式 导入服务器,之后再操作。

若服务器可联网,则可以通过命令:

wget https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.24-linux-glibc2.12-x86_64.tar.gz

下载mysql安装包。

3. 解压

tar -zvxf mysql-5.7.24-linux-glibc2.12-x86_64.tar.gz

Centos7.6 安装mysql过程全记录,数据库,mysql,数据库

解压完成后,可以看到当前目录下多了一个解压文件,移动该文件到/usr/local/下,并将文件夹名称修改为mysql。

如果/usr/local/下已经存在mysql,请将已存在mysql文件修改为其他名称,否则后续步骤可能无法正确进行。

4.创建data目录

在/usr/local/mysql目录下创建data目录

[root@localhost /]# mkdir /usr/local/mysql/data

5.修改目录属组

更改mysql目录下所有的目录及文件夹所属的用户组和用户,以及权限

chown -R mysql:mysql /usr/local/mysql

chmod -R 755 /usr/local/mysql

Centos7.6 安装mysql过程全记录,数据库,mysql,数据库

Centos7.6 安装mysql过程全记录,数据库,mysql,数据库

如果报以上错误,说明mysql用户不存在,执行以下命令,操作完再执行更改权限命令

groupadd mysql

useradd -r -g mysql mysql

6.编译安装并初始化mysql

编译安装并初始化mysql

cd /usr/local/l\mysql/bin

./mysqld --initialize --user=mysql --datadir=/usr/local/mysql/data --basedir=/usr/local/mysql

务必记住初始化输出日志末尾的密码(数据库管理员临时密码):A temporary password is generated for root@localhost:XXXXXXX

Centos7.6 安装mysql过程全记录,数据库,mysql,数据库

注意:

此处若报如下错误信息,表示该链接库文件有没有安装使用:

[root@ecs-xiaochengxu bin]# ./mysqld --initialize --user=mysql --datadir=/usr/local/mysql/data --basedir=/usr/local/mysql

./mysqld: error while loading shared libraries: libaio.so.1: cannot open shared object file: No such file or directory

./mysqld: error while loading shared libraries: libaio.so.1的处理办法

执行如下命令安装:

 1.首先检查该链接库文件有没有安装使用,运行该命令后发现系统中无该链接库文件

rpm -qa|grep libaio

# 2. 安装

yum install  libaio-devel.x86_64  

如果不能联网,则不能通过yum install 方式获取安装libaio-devel ; 需要单独下载到rpm 安装包,然后通过rpm -ivh xxx.rpm方式 进行安装

成功后如下:

Centos7.6 安装mysql过程全记录,数据库,mysql,数据库

7. 编辑配置文件my.cnf 

编辑配置文件my.cnf

vim /etc/my.cnf  //或者vi /etc/my.cnf

Centos7.6 安装mysql过程全记录,数据库,mysql,数据库

添加配置如下:在[mysqld]下添加 

[mysqld]

datadir=/usr/local/mysql/data #数据库data目录

port = 3306  #端口

sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES #sql模式

symbolic-links=0

max_connections=400  #最大连接数

innodb_file_per_table=1 

lower_case_table_names=1 #表名大小写不敏感

character_set_server=utf8  #服务器端编码为utf8

Centos7.6 安装mysql过程全记录,数据库,mysql,数据库参数注释:

lower_case_table_names:

       是否区分大小写,1表示存储时表名为小写,操作时不区分大小写;0表示区分大小写;不能动态设置,修改后,必须重启才能生效:

character_set_server:

       设置数据库默认字符集,如果不设置默认为latin1

innodb_file_per_table:

       是否将每个表的数据单独存储,1表示单独存储;0表示关闭独立表空间,可以通过查看数据目录,查看文件结构的区别;

解决中文乱码问题

show variables like '%character%'; 查询编码

show variables like '%character%';

 修改my.cnf文件  

#sudo vi /etc/my.cnf 

[mysqld]下加入代码:

      character_set_server=utf8

在[ mysql ]下加入代码:

      default-character-set=utf8

编辑/etc/my.cnf.d/client.cnf 

vi /etc/my.cnf.d/client.cnf

设置:

[client]

default-character-set=utf8

Centos7.6 安装mysql过程全记录,数据库,mysql,数据库

编辑vi /etc/my.cnf.d/mysql-clients.cnf

vi /etc/my.cnf.d/mysql-clients.cnf

在mysql下添加

default-character-set=utf8

Centos7.6 安装mysql过程全记录,数据库,mysql,数据库

8. 启动mysql服务器

/usr/local/mysql/support-files/mysql.server start

如果有报错信息:error: log-error set to '/var/log/mariadb/mariadb.log'

error: log-error set to '/var/log/mariadb/mariadb.log', however file don't exists. Create writable for user 'mysql'.

 ERROR! The server quit without updating PID file (/usr/local/mysql/data/localhost.localdomain.pid).

Centos7.6 安装mysql过程全记录,数据库,mysql,数据库

error: log-error set to '/var/log/mariadb/mariadb.log' 错误处理办法

首先需要理解报错信息:log-error 设置了日志为xxxx.log 然而文件不存在,建立一下对于mysql用户可写的xxx.log. 报错以及提示都非常明确。而这个日志路径则是配置在/etc/my.cnf 的【mysqld_safe】下的,指定了log-error 以及pid-file的路径:

于是针对错误很容易就能找到处理办法:新建/etc/my.cnf里指定路径的这个log以及pid文件(自己注意自己的路径,别瞎ctrl+c、v ,以下这个路径我的my.cnf是修改过的,但是本文里并没有截图,设置的路径与文件的文件不匹配还是会继续报错的) :

touch /usr/local/mysql/logs/mysql.log

touch /usr/local/mysql/logs/mysql.pid

创建了文件之后,还需要赋予权限,将文件所有者设置成 mysql用户:

chown -R mysql:mysql /usr/local/mysql/

Centos7.6 安装mysql过程全记录,数据库,mysql,数据库

开始处理这个问题的时候,没有理解到错误意思,所以我还修改了selinux的设置:

Centos7.6 安装mysql过程全记录,数据库,mysql,数据库

但是还是要报错:

Centos7.6 安装mysql过程全记录,数据库,mysql,数据库

然后就发现 my.cnf里配置 mysqld_safe配置的 /var/lib/mysql 文件夹不存在 所以报错:

mysqld_safe Directory '/var/lib/mysql' for UNIX socket file don't exists.

于是:mkdir -p var/lib/mysql  创建目录, 并设置目录权限,如下图所示:

Centos7.6 安装mysql过程全记录,数据库,mysql,数据库

重新执行:

/usr/local/mysql/support-files/mysql.server start

显示如下结果,说明数据库安装成功

Centos7.6 安装mysql过程全记录,数据库,mysql,数据库

9. 添加软链接,并重启mysql服务

ln -s /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql

ln -s /usr/local/mysql/bin/mysql /usr/bin/mysql

这里需要注意的是:如果是通过上述命令添加软链接,则mysql数据的服务名应该是mysql, 而不是常规的mysqld。

通过配置好的服务启动mysql数据库服务 :service mysql restart,注意此时不能用systemctl start mysql,不然会报错:

service mysql restart

Centos7.6 安装mysql过程全记录,数据库,mysql,数据库

Can't connect to local MySQL server through socket '/tmp/mysql.sock' 的解决方案

Centos7.6 安装mysql过程全记录,数据库,mysql,数据库

Enter password:

ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)

通过如下方式:

mysql -uroot -h 127.0.0.1 -p

Centos7.6 安装mysql过程全记录,数据库,mysql,数据库

10. 登录mysql,修改密码(密码为步骤6生成的临时密码)

mysql -u root -p

# 使用以下命令修改密码

set password for root@localhost = password('123456');

Centos7.6 安装mysql过程全记录,数据库,mysql,数据库

# 报错使用下面命令修改

从8.0开始修改密码有了变化,在user表加了字段authentication_string,修改密码前先检查authentication_string是否为空,如果不为空

use mysql;

update user set authentication_string='' where user='root';--将字段置为空

ALTER user 'root'@'localhost' IDENTIFIED BY 'root';--修改密码为root

2.如果为空,直接修改

ALTER user 'root'@'localhost' IDENTIFIED BY 'root';--修改密码为root

11. 开放远程连接

mysql>use mysql;

msyql>update user set user.Host='%' where user.User='root';

mysql>flush privileges;

执行完上边命令后,通过数据库客户端就可以连上数据库文章来源地址https://www.toymoban.com/news/detail-644469.html

到了这里,关于Centos7.6 安装mysql过程全记录的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • openGauss数据库安装,配置连接 完整版Centos7

    服务器版本:Centos7.6 || 7.9 数据库版本:openGauss-5.0.0-CentOS-64bit.tar.bz2  极简版 目录 修改系统参数 安装环境 安装openGauss数据库 配置连接数据库 使用navicat连接数据库 ##修改 /etc/selinux/config 文件中的“SELINUX”值为“disabled”。 vi  /etc/selinux/config SELINUX=disabled 关闭防火墙 ##检查

    2024年02月09日
    浏览(42)
  • Ladp数据库安装和配置自定义schema ,Centos7环境

    最近安装ldap看了不少教程,整理下用到的有用的资料,并把自己的搭建过程分享。 ldap介绍:openLDAP入门与安装 官方文档:https://www.openldap.org/doc/admin22/schema.html 安装配置:Centos7 搭建openldap完整详细教程(真实可用) bug解决:ldap运维中遇到的问题 schema自定义:导入schema到openL

    2024年02月12日
    浏览(53)
  • 磐维数据库panweidb单节点服务器在centos7.9安装(研发环境)

    使用omm用户登录到openGauss包安装的主机,解压openGauss压缩包到安装目录(假定安装目录为/opt/panweidb/soft,请用实际值替换)。 假定解压包的路径为/opt/panweidb/soft,进入解压后目录下的simpleInstall。 执行install.sh脚本安装openGauss。 上述命令中,-w是指初始化数据库密码(gs_initdb指

    2024年02月06日
    浏览(48)
  • 初识mysql数据库之mysql数据库安装(centos)

    目录 一、卸载不需要的环境 二、安装mysql yum源 三、安装mysql 四、登录mysql 1. 直接登录 2. 设置免密码登录 五、配置my.cnf 六、mysql登录时的一些选项介绍 要注意,在安装mysql数据库时,最好将用户切换为root,避免一些不必要的问题。当数据库安装好后,普通用户也可以使用的

    2024年02月03日
    浏览(50)
  • 【MySQL数据库】最全安装过程及配置详解

    🧛‍♂️iecne个人主页: : iecne的学习日志 💡每天 关注 iecne的作品,一起进步 💪一起学习,必看iecne 🐳希望大家多多支持🥰一起进步呀!

    2024年02月02日
    浏览(40)
  • MySQL8.0数据库超详细安装教程全过程

    1、官网下载MySQL8.0地址:MySQL :: Download MySQL Installer (Archived Versions) 2、 双击安装包进行安装 3、自定义安装 4、选择MySQL Server8.0   5、创建MYSQL数据存储目录及安装目录 6、配置安装路径及数据存储目录 7、确认继续 8、选择MySQL,下一步 9、开始安装 10、第一次安装需要C++的依赖

    2024年02月08日
    浏览(68)
  • 数据库应用:CentOS 7离线安装MySQL与Nginx

    目录 一、理论 1.安装依赖 二、实验 1.离线安装MySQL与Nginx 2.离线安装Nginx 三、问题 1.执行nginx -v命令报错 四、总结 (1)概念 安装依赖是指在软件开发中,为了运行或者编译一个程序或者库,在计算机上安装与其相依赖并且需要使用的其它程序或者库。根据查询相关公开信息

    2024年02月16日
    浏览(59)
  • Influxdb数据库(centos7)

    简介 InfluxDB是一个由InfluxData开发的开源时序型数据库,专注于海量时序数据的高性能读、高性能写、高效存储与实时分析等,在DB-Engines Ranking时序型数据库排行榜上排名第一: InfluxDB广泛应用于DevOps监控、IoT监控、实时分析等场景。除了具有成本优势的高性能读、高性能写、

    2024年02月12日
    浏览(47)
  • CentOS7自动备份数据库到git

    虽然数据库没什么数据,但是有就是珍贵的啦,为了服务器什么的无了,所以还是要自动备份一下比较好。 Open备忘第一页 步骤 在Gitee(github)上创建一个 私有 仓库 Gitee(github)配置好服务器的ssh 在服务器一个好位置克隆仓库下来刚刚创建的私有仓库 在服务器写脚本 : 为

    2024年01月25日
    浏览(43)
  • [Linux][CentOs][Mysql]基于Linux-CentOs7.9系统安装并配置开机自启Mysql-8.0.28数据库

    目录 一、准备工作:获取安装包和相应工具 (一)所需安装包 (二)安装包下载链接 (三)在服务器上创建文件夹并上传安装包 二、安装MySql (一)删除系统自带的mariadb (二)安装MySQL依赖包libaio (三)创建MySQL组和用户并设置密码 (四)将MySQL目录的权限授给MySQL用户

    2024年03月25日
    浏览(56)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包