红帽Linux中安装mysql8详细步骤(红帽linux安装详细过程)
sinye56 2024-11-02 13:21 5 浏览 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
相关推荐
- linux安装FTP
-
1、在nkftp目录下安装ftp,进入到nkftp里面[root@localhostbin]#cd/data/nkftp执行安装命令:[root@localhostnkftp]#rpm-i...
- LINUX下搭建FTP服务器
-
FTP服务器介绍FTP是FileTransferProtocol(文件传输协议)的英文简称,而中文简称为“文传协议”。用于Internet上的控制文件的双向传输。同时,它也是一个应用程序(App...
- Linux下如何进行FTP设置
-
目录:一、Redhat/CentOS安装vsftp软件二、Ubuntu/Debian安装vsftp软件一、Redhat/CentOS安装vsftp软件1.更新yum源yumupdate-y2.安...
- 推荐使用集串口 SSH远程登录和FTP传输三合一工具MobaXterm
-
来源:百问网作者:韦东山本文字数:1216,阅读时长:4分钟在以前的资料里,串口和SSH远程登使用SecureCRT,window与ubuntu数据传输使用filezilla,窗口切换来切换去,麻烦也...
- 如何搭建FTP服务器(Linux系统)
-
上次说了Windows操作系统下搭建的FTP服务器,那有朋友问我,说买的XX轻量应用服务器都是属于Linux的操作系统,我该如何为搭建FTP服务器呢?...
- Linux 命令 ncftp(文件传输)——想玩转linux就请一直看下去
-
我是IT悟道,点击右上方“关注”,每天分享IT、科技、数码方面的干货。Linuxncftp命令...
- 如何用 ftp 实现一键上传
-
简介ftp是Internet标准文件传输协议的用户界面,它允许用户与远程网络站点之间传输文件...
- Linux安装ftp
-
1安装vsftpd组件安装完后,有/etc/vsftpd/vsftpd.conf文件,是vsftp的配置文件。[root@bogon~]#yum-yinstallvsftpd2添加一个...
- 一天一点点:linux - ftp命令
-
linuxftp命令设置文件系统相关功能。FTP是ARPANet的标准文件传输协议,该网络就是现今Internet的前身。语法ftp[-dignv][主机名称或IP地址]参数:-d详细显示指令执...
- Centos 7 搭建FTP
-
目录安装软件以及启动服务添加防火墙规则关闭selinuxftp配置常用常用参数详解特殊参数配置文件没有的参数也可以添加到配置中1.安装软件以及启动服务yuminstall-yvsftpdsys...
- 【Linux】Linux中ftp命令,没有你想的那么简单
-
本文介绍了Linux中FTP命令的基本用法,包括连接与登录远程服务器,以及解析了FTP协议中五个最常用的操作命令的使用和解析过程。同时,提供了一个包含常用FTP操作命令的表格,供读者参考。通过熟练掌握...
- linux 命令行操作ftp
-
以下是linuxftp命令参数的详解。FTP>!从ftp子系统退出到外壳?FTP>?显示ftp命令说明??和help相同?格式:?[command]说明:[com...
- 多学习才能多赚钱之:linux如何使用ftp
-
linux如何使用ftp步骤1:建立FTP连接想要连接FTP服务器,在命令上中先输入ftp然后空格跟上FTP服务器的域名'domain.com'或者IP地址例如:ftpdom...
- linux常用网络操作方法:ftp命令使用方法
-
常用网络操作方法Linux提供了一组强有力的网络命令来为用户服务,这些工具能够帮助用户登录到远程计算机上、传输文件和执行远程命令等。本节介绍下列几个常用的有关网络操作的命令:ftp传输文件tel...
- Linux 5.15有望合并Memory Folios方案 内核构建速度可提升7%
-
甲骨文公司的长期内核开发人员MatthewWilcox已经研究了“内存对开区”概念相当长的一段时间,这可以改善Linux的内存管理,使其具有更大的效率。例如,使用内存对开的基准测试表明,内核的构建速...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- oracle忘记用户名密码 (59)
- oracle11gr2安装教程 (55)
- mybatis调用oracle存储过程 (67)
- oracle spool的用法 (57)
- oracle asm 磁盘管理 (67)
- 前端 设计模式 (64)
- 前端面试vue (56)
- linux格式化 (55)
- linux图形界面 (62)
- linux文件压缩 (75)
- Linux设置权限 (53)
- linux服务器配置 (62)
- mysql安装linux (71)
- linux启动命令 (59)
- 查看linux磁盘 (72)
- linux用户组 (74)
- linux多线程 (70)
- linux设备驱动 (53)
- linux自启动 (59)
- linux网络命令 (55)
- linux传文件 (60)
- linux打包文件 (58)
- linux查看数据库 (61)
- linux获取ip (64)
- linux进程通信 (63)