红帽Linux中安装mysql8详细步骤(红帽linux如何安装图形界面)
ahcoder 2025-06-18 10:30 2 浏览
注意:我写的解压路径和截图路径不一致,仅供参考
先前往官网下载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
相关推荐
- Java程序员必备的Linux命令速查表
-
Java程序员必备的Linux命令速查表在Java开发的世界里,Linux就像一位默默支持的幕后英雄。作为一名Java开发者,掌握一些基本的Linux命令,不仅能提高工作效率,还能让你在团队中显得格外...
- Linux 命令速查手册:这 30 个高频指令,拯救 90% 的运维小白!
-
在Linux系统的世界里,命令行是强大的武器。对于运维小白而言,掌握一些高频使用的Linux命令,能极大提升工作效率,轻松应对各种系统管理任务。今天,就为大家奉上精心整理的30个Linu...
- linux磁盘管理相关命令(linux磁盘管理常用命令)
-
磁盘的使用情况会直接影响系统的性能,因此我们经常会用到以下命令,主要围绕:fdisk:磁盘分区df:文件系统的磁盘空间占用情况du:文件目录的磁盘空间占用情况查看磁盘关系lsblk查看磁盘分区情况fd...
- 第四章 Linux常用shell命令-4.5.磁盘管理
-
主要介绍一下跟磁盘管理相关命令,有比较多的内容摘抄自网络,如有侵权,请及时联系我删除:显示目前在Linux系统上的文件系统磁盘使用情况统计:df创建和维护分区表的程序:fdisk将磁盘分区或镜像挂...
- Linux新手必备:20个高效命令轻松掌握!
-
Linux基本命令使用指南在现代计算机操作系统中,Linux因其开放性、灵活性和强大的功能,广泛应用于服务器和开发环境中。作为技术人员,掌握Linux的基本命令是非常重要的。在本文中,我们将重点介绍2...
- 每日必学Linux命令:ls命令(linux命令详解之ls命令)
-
ls命令是linux下最常用的命令。ls命令就是list的缩写缺省下ls用来打印出当前目录的清单如果ls指定其他目录那么就会显示指定目录里的文件及文件夹清单。通过ls命令不仅可以查看linux文件...
- Linux系统dev和proc目录详解(linux dev/sr0)
-
简介:Linux系统里的/dev和/proc目录那可是相当重要的系统文件。在Linux系统中,/dev目录专门用来存放设备文件。不光有设备文件,系统里还有好多特殊功能也是通过设备的形式...
- Linux切换目录之cd命令(linux切换指定目录)
-
1.基本概念1.1命令作用当我们在Linux系统上工作时,做得相当多的一项任务就是在不同的目录之间进行切换,这时就需要用到cd命令了。cd是"changedirectory"的首...
- Linux切换目录(cd命令)(linux如何切换到目录)
-
cd命令,是ChangeDirectory的缩写,用来切换工作目录。Linux命令按照来源方式,可分为两种,分别是Shell内置命令和外部命令。所谓Shell内置命令,就是Shel...
- MongoDB数据库的快速部署和启动(mongodb的使用教程)
-
一、Mongodb介绍常见数据库介绍关系数据库RDBMS设计表结构,通过SQL语句进行操作。连表关系常见的关系型数据库:mysqloracle(商业)DB2(IBM)sqlserver(微软...
- 5分钟学会网络服务搭建,飞凌i.MX9352 + Linux 6.1实战示例
-
在“万物互联”的技术浪潮下,网络服务已成为连接物理世界与数字世界的核心纽带,它不仅赋予了终端设备“开口说话”的能力,更构建了智能设备的开发范式。本文就将以飞凌嵌入式OK-MX9352-C开发板(搭载了...
- centos安装geoserver并配置开机启动
-
前提条件:服务器已经安装了java环境一、下载下载地址:http://geoserver.org/release/maintain/下载后文件名为:geoserver-2.19.3-bin.zip二、...
- 开机启动流程(开机流程图)
-
grubandbootCentos5,6的开机启动流程grubCentos7的开机启动流程Centos5,6的开机启动流程initrd/initramfs一般存储在/boot目录下,以.img...
- Linux cron服务概述(crontab服务)
-
cron是Linux/Unix系统中一个非常重要的后台服务(守护进程),用于在预定的时间间隔自动执行命令或脚本。它使得自动化重复性任务成为可能,例如日志清理、数据备份、系统维护等。1.cron...
- CentOS 8利用rc.local进行开机自启动的配置
-
CentOS8利用rc.local进行开机自启动的配置CentOS8linux系统是不建议使用rc.local进行开机自启动的,建议创建systemdservice。我们为了方便以后多一个配置...
- 一周热门
- 最近发表
- 标签列表
-
- linux 远程 (37)
- u盘 linux (32)
- linux 登录 (34)
- linux 路径 (33)
- linux 文件命令 (35)
- linux 是什么 (35)
- linux 界面 (34)
- 查看文件 linux (35)
- linux 语言 (33)
- linux代码 (32)
- linux 查看命令 (33)
- 关闭linux (34)
- root linux (33)
- 删除文件 linux (35)
- linux 主机 (34)
- linux与 (33)
- linux 函数 (35)
- linux .ssh (35)
- cpu linux (35)
- 查看linux 系统 (32)
- linux 防火墙 (33)
- linux 手机 (32)
- linux 镜像 (34)
- linux ip地址 (34)
- linux 用户查看 (33)