红帽Linux中安装mysql8详细步骤(红帽linux为什么安装失败)
ztj100 2025-01-24 14:52 16 浏览 0 评论
注意:我写的解压路径和截图路径不一致,仅供参考
先前往官网下载mysql8
下载地址:https://dev.mysql.com/downloads/
选择指定版本和系统
下载命令
进入root目录,执行wget命令下载
wget https://downloads.mysql.com/archives/get/p/23/file/mysql-8.0.33-linux-glibc2.28-x86_64.tar.gz
删除Linux中的mysql(如果有的话),上传安装包
先查看mysql是否存在
如下命令:rpm -qa|grep -i mysql
如果使用这个命令之后没有出现任何内容,表示没有安装过mysql,如果有出现,则删除。
如果存在,那么停止mysql,删除所有的服务
停止命令:service mysqld stop
检查是否存在命令:rpm -qalgrep -i mysql
查询所在路径:find / -name mysql
删除命令:rm -rf 路径 (例如:rm -rf /etc/rc.d/init.d/mysgl)
解压安装MySQL
解压至指定目录
tar -zvxf mysql-8.0.33-linux-glibc2.28-x86_64.tar.gz -C /mnt/soft/mysql-8.0.33
先给目录新增权限以便后面写文件使用(以免权限不足带来问题)
chmod 750 /mnt/soft/mysql-8.0.33
进入MySQL根目录,创建data文件夹
进入mysql解压目录
cd /mnt/soft/mysql-8.0.33
执行创建data命令:mkdir data
创建mysql组和用户
创建mysql组
groupadd mysql
创建mysq用户
useradd -g mysql mysql
执行如图:
出现这样的提示表示已经创建过mysql组和用户了。
将安装的MySQL权限给mysql用户
chown -R mysql.mysql /mnt/soft/mysql-8.0.33
MySQL初始化
初始化
在初始化之前提一嘴,Linux中的MySQL默认是区分表明大小写的,如果你是安装的也是MySQL8,那么不区分大小需要在数据库初始化时设置,不然初始化后,在配置文件在设置重启时是会报错的。
进入mysql解压目录
cd /mnt/soft/mysql-8.0.33/bin
./mysqld --user=mysql --basedir=/mnt/soft/mysql-8.0.33 --datadir=/mnt/soft/mysql-8.0.33/data --lower-case-table-names=1 --initialize
–lower-case-table-names=1 即设置不区分表明大小写,最后面的 dwW3</EIewj 为初始化生产的临时密码。
初始化失败
./mysqld: error while loading shared libraries: libaio.so.1: cannot open shared object file: No such file or directory
原因:
这是一个与运行MySQL数据库相关的问题。出现这个错误的原因是系统缺少了名为libaio.so.1的共享库文件。
使用命令查看是否已安装libaio软件包,命令如下:rpm -qa|grep libaio
可以看到并没有安装libaio软件包。
解决办法:
先安装numactl软件包,命令如下:yum -y install numactl.x86_64
然后安装libaio开发包,命令如下:yum install libaio-devel.x86_64
再次查看是否安装成功libaio软件包
rpm -qa|grep libaio
可以看到安装成功了,再次初始化应该就可以成功了。
修改MySQL配置文件
初次进入时配置是空的,进入命令
vim /etc/my.cnf
[mysqld]
#设置MySQL运行端口
port=3306
# MySQL根目录
basedir=/mnt/soft/mysql-8.0.33
# MySQL的data目录
datadir=/mnt/soft/mysql-8.0.33/data
#日志文件
log-error=/mnt/soft/mysql-8.0.33/logs/mysqld.log
#socket
socket=/mnt/soft/mysql-8.0.33/mysql.sock
#PID文件
pid-file=/mnt/soft/mysql-8.0.33/mysqld.pid
symbolic-links=0
#慢查询配置
slow_query_log=ON
long_query_time=200
slow_query_log_file=/mnt/soft/mysql-8.0.33/logs/mysql_slow_query.log
#问题原因
#MySQL8.0新增data dictionary的概念,数据初始化的时候在Linux下默认使用lower-case-table-names=0参数,数据库启动的时候读取my.cnf文件中的值。若二者值不一致则在MySQL的错误日志中记录报错信息。
lower_case_table_names = 1
#MySQL允许最大的进程连接数
max_connections = 3000
#设置在网络传输中一次消息传输量的最大值
max_allowed_packet = 32M
#解决“java.sql.SQLException: Expression #1 of ORDER BY clause is not in SELECT list,references column”
sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION'
保存退出
添加服务到系统
进入MySQL的/mnt/soft/mysql-8.0.33
cd /mnt/soft/mysql-8.0.33
cp -a ./support-files/mysql.server /etc/init.d/mysql
授权以及添加服务
授权
这里授权和添加服务都是在MySQL的根目录中操作。
chmod +x /etc/init.d/mysql
添加服务
chkconfig --add mysql
将MySQL命令添加到服务
命令: ln -s “你的MySQL根目录/bin/mysql” /usr/bin ,这一步是为了能在任何地方通过用户名和密码登录MySQL
ln -s /mnt/soft/mysql-8.0.33/bin/mysql /usr/bin
踩坑
直到上一步都没有出错,在登录mysql时报如下错:
可能是挂载的路径错了,到挂载目录查看,命令如下
cd /usr/bin
可以看到mysql服务是红色的,并且一直在闪,正常的应该是绿色的
我当前的mysql根目录是8.0.32,添加的时候写成了8.0.31,怪不得会报错。解决办法:删除当前mysql的服务,重新添加。先删除,命令如下:rm -rf /usr/bin/mysql
重新添加:ln -s /mnt/soft/mysql-8.0.33/bin/mysql /usr/bin
可以看到mysql服务添加成功,可以登录mysql了
启动MySQL
启动MySQL命令
service mysql start
查看MySQL状态
service mysql status
修改密码
mysql客户端连接
mysql -h 127.0.0.1 -uroot -p
输入密码:
执行命令:alter user 'root'@'localhost' identified by '123456';
修改允许远程连接
分别执行以下命令
#使用mysql库
use mysql;
#修改root用户远程连接配置
update user set Host = '%' where Host = 'localhost' and User='root';
#刷新保存数据库,此时远程连接生效
flush privileges;
防火墙
查看防火墙状态
firewall-cmd --state
重新加载配置
firewall-cmd --reload
查看开放的端口
firewall-cmd --list-ports
开启防火墙端口
命令含义:
–zone #作用域
–add-port=9200/tcp #添加端口,格式为:端口/通讯协议
–permanent #永久生效,没有此参数重启后失效
firewall-cmd --zone=public --add-port=3306/tcp --permanent
如果执行添加端口命令后,需要执行重新加载配置命令才生效
关闭防火墙端口
firewall-cmd --zone=public --remove-port=3306/tcp --permanent
相关推荐
- Vue3非兼容变更——函数式组件(vue 兼容)
-
在Vue2.X中,函数式组件有两个主要应用场景:作为性能优化,因为它们的初始化速度比有状态组件快得多;返回多个根节点。然而在Vue3.X中,有状态组件的性能已经提高到可以忽略不计的程度。此外,有状态组...
- 利用vue.js进行组件化开发,一学就会(一)
-
组件原理/组成组件(Component)扩展HTML元素,封装可重用的代码,核心目标是为了可重用性高,减少重复性的开发。组件预先定义好行为的ViewModel类。代码按照template\styl...
- Vue3 新趋势:10 个最强 X 操作!(vue.3)
-
Vue3为前端开发带来了诸多革新,它不仅提升了性能,还提供了...
- 总结 Vue3 组件管理 12 种高级写法,灵活使用才能提高效率
-
SFC单文件组件顾名思义,就是一个.vue文件只写一个组件...
- 前端流行框架Vue3教程:17. _组件数据传递
-
_组件数据传递我们之前讲解过了组件之间的数据传递,...
- 前端流行框架Vue3教程:14. 组件传递Props效验
-
组件传递Props效验Vue组件可以更细致地声明对传入的props的校验要求...
- 前端流行框架Vue3教程:25. 组件保持存活
-
25.组件保持存活当使用...
- 5 个被低估的 Vue3 实战技巧,让你的项目性能提升 300%?
-
前端圈最近都在卷性能优化和工程化,你还在用老一套的Vue3开发方法?作为摸爬滚打多年的老前端,今天就把私藏的几个Vue3实战技巧分享出来,帮你在开发效率、代码质量和项目性能上实现弯道超车!一、...
- 绝望!Vue3 组件频繁崩溃?7 个硬核技巧让性能暴涨 400%!
-
前端的兄弟姐妹们五一假期快乐,谁还没在Vue3项目上栽过跟头?满心欢喜写好的组件,一到实际场景就频频崩溃,页面加载慢得像蜗牛,操作卡顿到让人想砸电脑。用户疯狂吐槽,领导脸色难看,自己改代码改到怀疑...
- 前端流行框架Vue3教程:15. 组件事件
-
组件事件在组件的模板表达式中,可以直接使用...
- Vue3,看这篇就够了(vue3 从入门到实战)
-
一、前言最近很多技术网站,讨论的最多的无非就是Vue3了,大多数都是CompositionAPI和基于Proxy的原理分析。但是今天想着跟大家聊聊,Vue3对于一个低代码平台的前端更深层次意味着什么...
- 前端流行框架Vue3教程:24.动态组件
-
24.动态组件有些场景会需要在两个组件间来回切换,比如Tab界面...
- 前端流行框架Vue3教程:12. 组件的注册方式
-
组件的注册方式一个Vue组件在使用前需要先被“注册”,这样Vue才能在渲染模板时找到其对应的实现。组件注册有两种方式:全局注册和局部注册...
- 焦虑!Vue3 组件频繁假死?6 个奇招让页面流畅度狂飙 500%!
-
前端圈的朋友们,谁还没在Vue3项目上踩过性能的坑?满心期待开发出的组件,一到高并发场景就频繁假死,用户反馈页面点不动,产品经理追着问进度,自己调试到心态炸裂!别以为这是个例,不少人在电商大促、数...
- 前端流行框架Vue3教程:26. 异步组件
-
根据上节课的代码,我们在切换到B组件的时候,发现并没有网络请求:异步组件:...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- idea eval reset (50)
- vue dispatch (70)
- update canceled (42)
- order by asc (53)
- spring gateway (67)
- 简单代码编程 贪吃蛇 (40)
- transforms.resize (33)
- redisson trylock (35)
- 卸载node (35)
- np.reshape (33)
- torch.arange (34)
- npm 源 (35)
- vue3 deep (35)
- win10 ssh (35)
- vue foreach (34)
- idea设置编码为utf8 (35)
- vue 数组添加元素 (34)
- std find (34)
- tablefield注解用途 (35)
- python str转json (34)
- java websocket客户端 (34)
- tensor.view (34)
- java jackson (34)
- vmware17pro最新密钥 (34)
- mysql单表最大数据量 (35)