Linux 安装mysql 数据库通用教程(rpm傻瓜安装)

2024-09-01 01:44

本文主要是介绍Linux 安装mysql 数据库通用教程(rpm傻瓜安装),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

通用教程:Centos7.9安装mysql8.0.39(使用rpm 安装)

目录

前言

下载镜像源

删除或查看旧版本

安装mysql

启动mysql

mysql授权远程登录


前言

在本篇博客中,我将向您展示如何在CentOS 7.9系统上通过RPM包安装特定版本的MySQL 8.0.39。这篇博客旨在提供实用的指导,帮助读者学习如何在CentOS或其他Linux发行版上安装特定版本的MySQL。通过遵循本篇博客中提供的详细步骤,您将能够轻松地进行安装,为您的数据管理需求打下坚实的基础。

下载镜像源

Oracle 下载mysql官方网址 进入该链接下载mysql镜像源

https://dev.mysql.com/downloads/mysql/

非常建议!!非常建议!!非常建议!!下载rpm的mysql安装包,这在后来的mysql安装中可以省下不少力气

删除或查看旧版本

查看mysql和glibc的命令

mysql -V
rpm -q glibc

查看现有的mysql已安装的依赖

rpm -qa | grep mysql

删除已安装的mysql依赖

rpm -e --nodeps + 对应的依赖包的名字

查看已运行的mysql和mysqld的进程

grep mysql | grep -v grep
grep mysqld | grep -v grep

杀死已运行的mysql和mysqld的进程

kill -9 + 进程编号

删除mysql安装后生成的包

使用rpm 命令安装mysql是自动完成的,它会自动生成mysql的安装路径及对应的mysql安装路径,因此在安装新版本的mysql时最好将原有生成的mysql安装路径删除掉,避免安装出现冲突。

查看mysql文件的安装路径

find / -name mysql 

删除对应的安装路径

rm -rf + 文件路径

安装mysql

解压下载好的mysql安装捆绑包

.tar文件解压

例子:tar -xvf mysql-8.0.16-2.el7.x86_64.rpm-bundle.tar

tar -xvf mysql-8.0.16-2.el7.x86_64.rpm-bundle.tar

这里是命令参数的详细说明:

  • -x:表示解包(extract)操作。
  • -v:表示详细模式(verbose),它会在解包过程中显示正在处理的文件列表。
  • -f:表示指定文件名,后面跟着你要解包的 .tar.xz 文件的名称。

.gz文件解压

例子:tar -xvzf archive.tar.gz

tar -xvzf archive.tar.gz

强制安装rpm

在解压后的路径中使用rpm安装mysql及捆绑的相关依赖

rpm -ivh *.rpm --nodeps --force

命令解析:

  • rpm:命令本身,用于处理 RPM 软件包。
  • -i:表示安装(install)一个或多个软件包。
  • -v:表示详细模式(verbose),它会在安装过程中显示更多的信息。
  • -h:表示显示安装进度的散列(hash),通常显示为一个进度条。
  • *.rpm:指定要安装的文件,星号 * 是一个通配符,表示当前目录下所有以 .rpm 结尾的文件。
  • --nodeps:这个选项用于跳过依赖性检查。--no 是一个否定前缀,deps 表示依赖性。通常,rpm 会检查软件包的依赖性,确保所有必需的依赖都已安装。使用 --nodeps 会忽略这些检查,这可能会带来风险,因为缺少依赖可能导致软件包不能正常工作。
  • --force:这个选项用于强制安装软件包,即使某些条件不满足(例如,如果软件包已经安装或存在冲突)也会继续安装。

查找myql命令

whereis mysql

whereis mysql

可以看到,

  • MySQL的安装路径为/usr/bin/mysql
  • 其配套的mysqlclient库头文件位于/usr/include/mysql
  • 库文件位于/user/lib64/mysql

目录

chown -R mysql:mysql /var/lib/mysql/

chown -R mysql:mysql /var/lib/mysql/

综上所述,命令 chown -R mysql:mysql /var/lib/mysql/ 的作用是将 /var/lib/mysql/ 目录及其所有子目录和文件的所有者和所属组递归地更改为 mysql 用户和 mysql 组。这通常在安装或配置 MySQL 数据库时执行,确保 MySQL 服务有适当的权限来访问其数据目录。

一定要先给目录权限才能启动数据库文件不然会报错

[root@localhost ~]# systemctl start mysqld

Job for mysqld.service failed because the control process exited with error code. See "systemctl status mysqld.service" and "journalctl -xe" for details.

启动mysql

初始化数据库(建议到用户目录下 ~)

mysqld --initialize --console

mysqld --initialize --console

启动mysql

systemctl start mysqld
systemctl status mysqld

获取随机的root密码

MySQL安装后,会给root一个随机密码,可以通过命令获取。

cat /var/log/mysqld.log

cat /var/log/mysqld.log

修改root密码为123456

使用 mysql -u root -p 命令输入给出的随机root密码进行登录,

然后使用 ALTER USER 'root'@'localhost' IDENTIFIED BY '123456' 将root密码修改为123456。

ALTER USER 'root'@'localhost' IDENTIFIED BY '123456' 

mysql授权远程登录

进入mysql命令行下,依次输入下面的命令,注意每输入完一条mysql命令都要在末尾加 ;号

SHOW databases;

USE mysql;

UPDATE user SET host = "%" WHERE user='root';

SELECT host, user, authentication_string, plugin FROM user;

FLUSH privileges;

SHOW databases;	
USE mysql;
UPDATE user SET host = "%" WHERE user='root';
SELECT host, user, authentication_string, plugin FROM user;
FLUSH privileges;

这个 SQL 语句用于获取 user 表中所有记录的 hostuserauthentication_stringplugin 字段的值。这通常用于查看数据库用户的账号信息,包括他们的密码和认证插件。

使用Navicat测试远程连接情况,需要先关闭Centos的防火墙

这篇关于Linux 安装mysql 数据库通用教程(rpm傻瓜安装)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1125590

相关文章

SpringBoot集成redisson实现延时队列教程

《SpringBoot集成redisson实现延时队列教程》文章介绍了使用Redisson实现延迟队列的完整步骤,包括依赖导入、Redis配置、工具类封装、业务枚举定义、执行器实现、Bean创建、消费... 目录1、先给项目导入Redisson依赖2、配置redis3、创建 RedissonConfig 配

MySQL的JDBC编程详解

《MySQL的JDBC编程详解》:本文主要介绍MySQL的JDBC编程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、前置知识1. 引入依赖2. 认识 url二、JDBC 操作流程1. JDBC 的写操作2. JDBC 的读操作总结前言本文介绍了mysq

java.sql.SQLTransientConnectionException连接超时异常原因及解决方案

《java.sql.SQLTransientConnectionException连接超时异常原因及解决方案》:本文主要介绍java.sql.SQLTransientConnectionExcep... 目录一、引言二、异常信息分析三、可能的原因3.1 连接池配置不合理3.2 数据库负载过高3.3 连接泄漏

防止Linux rm命令误操作的多场景防护方案与实践

《防止Linuxrm命令误操作的多场景防护方案与实践》在Linux系统中,rm命令是删除文件和目录的高效工具,但一旦误操作,如执行rm-rf/或rm-rf/*,极易导致系统数据灾难,本文针对不同场景... 目录引言理解 rm 命令及误操作风险rm 命令基础常见误操作案例防护方案使用 rm编程 别名及安全删除

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

如何通过try-catch判断数据库唯一键字段是否重复

《如何通过try-catch判断数据库唯一键字段是否重复》在MyBatis+MySQL中,通过try-catch捕获唯一约束异常可避免重复数据查询,优点是减少数据库交互、提升并发安全,缺点是异常处理开... 目录1、原理2、怎么理解“异常走的是数据库错误路径,开销比普通逻辑分支稍高”?1. 普通逻辑分支 v

MySQL中On duplicate key update的实现示例

《MySQL中Onduplicatekeyupdate的实现示例》ONDUPLICATEKEYUPDATE是一种MySQL的语法,它在插入新数据时,如果遇到唯一键冲突,则会执行更新操作,而不是抛... 目录1/ ON DUPLICATE KEY UPDATE的简介2/ ON DUPLICATE KEY UP

MySQL分库分表的实践示例

《MySQL分库分表的实践示例》MySQL分库分表适用于数据量大或并发压力高的场景,核心技术包括水平/垂直分片和分库,需应对分布式事务、跨库查询等挑战,通过中间件和解决方案实现,最佳实践为合理策略、备... 目录一、分库分表的触发条件1.1 数据量阈值1.2 并发压力二、分库分表的核心技术模块2.1 水平分

RabbitMQ 延时队列插件安装与使用示例详解(基于 Delayed Message Plugin)

《RabbitMQ延时队列插件安装与使用示例详解(基于DelayedMessagePlugin)》本文详解RabbitMQ通过安装rabbitmq_delayed_message_exchan... 目录 一、什么是 RabbitMQ 延时队列? 二、安装前准备✅ RabbitMQ 环境要求 三、安装延时队