Linux系统安装Mysql5.7数据库图文笔记(CentOS7)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
日志服务 SLS,月写入数据量 50GB 1个月
简介: Linux系统安装Mysql5.7数据库图文笔记(CentOS7)



Linux Centos安装Mysql5.7.23

阿里云服务器安装Mysql数据官方帮助文档
https://help.aliyun.com/document_detail/116727.html?source=5176.11533457&type=copy

我写的教程参考了上面的帮助文档。

需要一台服务器阿里云或者腾讯云。选服务器的时候选择Linux操作系统

推荐tar.gz压缩包进行安装

通过安装tar.gz压缩包版本,也就是二进制包,能在同一台机器上安装多个MySQL。

建议是安装tar.gz压缩包版本的,这个安装全部都是手动配置,包括启动服务,环境变量等,
因为可以给你一个很清晰的配置思路,
至于安装了什么,配置了什么,
这些都可以一步了然的排查出来。
当然,在Linux下deb还是tar.gz各有各的好处,毕竟这些都可以根据需要进行版本选择
mysql5.7.23安装包下载: 云盘免费下载(mysql-5.7.23-linux-glibc2.12-x86_64.tar.gz)
已经把本文用到的mysql安装版本上传到了云盘,希望能帮助到大家。

安装准备

cp -r /root/tools/mysql-5.7.23-linux-glibc2.12-x86_64.tar.gz   /usr/local/mysql
cd /usr/local/mysql
 tar -xvzf mysql-5.7.23-linux-glibc2.12-x86_64.tar.gz

groupadd mysql
useradd -r -g mysql mysql

安装libaio1

//Centos 安装libaio1   mysql安装依赖  必须先安装(前提条件)
yum install  libaio-devel.x86_64

配置mariadb

//建立mariadb目录和日志(前提条件)
mkdir /var/log/mariadb 
touch /var/log/mariadb/mariadb.log 
chown -R mysql:mysql  /var/log/mariadb/

配置环境变量

//编辑环境变量文件
vim  /etc/profile  
//  按  i  插入
// 按ESC   输入:wq保存文本并退出。如有不懂,自行百度查询vim命令

export PATH=$PATH:/usr/local/mysql/mysql3306/bin

//刷新环境变量
source /etc/profile

设置socket路径并赋权

mkdir  /run/mysqld
chmod 777 /run/mysqld

配置Mysql配置文件My.cnf

 vim  /etc/my.cnf


 [mysqld]
 sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
 # 一般配置选项
 basedir = /usr/local/mysql/mysql3306
 datadir = /usr/local/mysql/mysql3306/data
 port = 3306
 socket = /var/run/mysqld/mysql3306/mysqld.sock
 character-set-server=utf8

 [mysql]
 no-auto-rehash
 default-character-set=utf8
 safe-updates
 socket = /var/run/mysqld/mysql3306/mysqld.sock

初始化

//这条命令会产生临时密码
bin/mysqld --initialize --user=mysql

安全启动

//生成证书
mysql_ssl_rsa_setup
// 安全模式启动mysql
mysqld_safe --user=mysql &

root身份临时密码登录并修改临时密码

//登录mysql之后,更改root密码
mysql -uroot -p  登录root,第一次需要临时密码

SET PASSWORD = PASSWORD('123456');

ALTER USER 'root'@'localhost'
PASSWORD EXPIRE NEVER;

flush privileges;

赋予指定用户远程连接操作权限

//添加具体的用户名可以进行远程数据库连接
GRANT ALL PRIVILEGES ON *.* TO '远程连接用户名'@'%' IDENTIFIED BY '远程连接密码' WITH GRANT OPTION;

//mysql查询远程连接地址信息
SELECT DISTINCT CONCAT('User: ''',user,'''@''',host,''';') AS query FROM mysql.user;

操作步骤汇总:

//安装前准备工作
[root@fyly bin]# cp -r /root/tools/mysql-5.7.23-linux-glibc2.12-x86_64.tar.gz   /usr/local/mysql
[root@fyly bin]# cd /usr/local/mysql
[root@fyly mysql]# tar -xvzf mysql-5.7.23-linux-glibc2.12-x86_64.tar.gz

[root@fyly mysql]# groupadd mysql
[root@fyly mysql]# useradd -r -g mysql mysql
//安装MySQL

//Centos 安装libaio1   mysql安装依赖  必须先安装(前提条件)
yum install  libaio-devel.x86_64

//建立mariadb目录和日志(前提条件)
mkdir /var/log/mariadb 
touch /var/log/mariadb/mariadb.log 
chown -R mysql:mysql  /var/log/mariadb/

//配置环境变量(非常重要)(注意不要加入分割线)
//  vim  /etc/profile  
//  配置mysql开发环境。你的目录不对,可以自行更改下面的bin目录路径
------------------------------------------------------------------------------
export PATH=$PATH:/usr/local/mysql/mysql3306/bin
------------------------------------------------------------------------------
// 配置mysql 配置文件 (注意不要加入分割线)
//  vim  /etc/my.cnf
------------------------------------------------------------------------------
 [mysqld]
 sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
 # 一般配置选项
 basedir = /usr/local/mysql/mysql3306
 datadir = /usr/local/mysql/mysql3306/data
 port = 3306
 socket = /var/run/mysqld/mysql3306/mysqld.sock
 character-set-server=utf8

 [mysql]
 no-auto-rehash
 default-character-set=utf8
 safe-updates
 socket = /var/run/mysqld/mysql3306/mysqld.sock
------------------------------------------------------------------------------



//执行这一步的时候,确保配置文件设置好data目录,设置好socket路径
//这条命令会产生临时密码
bin/mysqld --initialize --user=mysql
//配置文件中的data文件目录,会被初始化数据,如果初始化失败,请查看data目录下面的错误日志文件。
//里面的日志信息会详细告诉你,初始化数据库的时候,发生的错误信息。一般出错误比较多的是socket路径问题
//临时密码
pxHzcv<i+1ws


bin目录下
//生成证书
mysql_ssl_rsa_setup
// 安全模式启动mysql
mysqld_safe --user=mysql &

mysql目录下
bin/mysql_ssl_rsa_setup
bin/mysqld_safe --user=mysql &

MySQL安全模式启动之后

//登录mysql之后,更改root密码
mysql -uroot -p  登录root,第一次需要临时密码

SET PASSWORD = PASSWORD('123456');

ALTER USER 'root'@'localhost'
PASSWORD EXPIRE NEVER;

flush privileges;


//添加具体的用户名可以进行远程数据库连接
GRANT ALL PRIVILEGES ON *.* TO '远程连接用户名'@'%' IDENTIFIED BY '远程连接密码' WITH GRANT OPTION;

//mysql查询远程连接地址信息
SELECT DISTINCT CONCAT('User: ''',user,'''@''',host,''';') AS query FROM mysql.user;

重要截图界面:

获取到临时密码:

配置mysql环境变量之后执行命令:

配置mysql配置文件。性能调优参数请自行查百度,这里写了最基本的,包括中文乱码问题

root身份远程连接成功!

遇到问题

  • Linux安装MySQL时候出现log-error set to '/var/log/mariadb/mariadb.log', however file don't exists.
  • Can't connect to local MySQL server through socket '/tmp/mysql.sock'
    出现这个错误的原因:mysql服务未启动;mysql socket路径和权限可能错误
    mysql服务启动失败,请排查data目录下的错误日志文件信息;
    socket路径和权限错误:请排查my.cnf配置文件和对应socket目录正确与否,并赋予 socket目录权限。
  • root身份远程连接mysql。完成可以。但是要分配端口远程连接权限。允许root身份在任何ip客户端都能登录。

原文地址:【猿视野】https://www.yundashi168.com/184.html

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
15天前
|
关系型数据库 MySQL 数据库连接
数据库连接工具连接mysql提示:“Host ‘172.23.0.1‘ is not allowed to connect to this MySQL server“
docker-compose部署mysql8服务后,连接时提示不允许连接问题解决
|
1天前
|
关系型数据库 MySQL 数据库
Docker Compose V2 安装常用数据库MySQL+Mongo
以上内容涵盖了使用 Docker Compose 安装和管理 MySQL 和 MongoDB 的详细步骤,希望对您有所帮助。
61 42
|
29天前
|
安全 关系型数据库 MySQL
CentOS7仅安装部署MySQL80客户端
通过上述步骤,你可以在CentOS 7上成功安装并配置MySQL 8.0客户端。这个过程确保你能够使用MySQL客户端工具连接和管理远程的MySQL数据库,而不需要在本地安装MySQL服务器。定期更新MySQL客户端可以确保你使用的是最新的功能和安全修复。
120 16
|
19天前
|
缓存 关系型数据库 MySQL
【深入了解MySQL】优化查询性能与数据库设计的深度总结
本文详细介绍了MySQL查询优化和数据库设计技巧,涵盖基础优化、高级技巧及性能监控。
152 0
|
2月前
|
存储 Oracle 关系型数据库
数据库传奇:MySQL创世之父的两千金My、Maria
《数据库传奇:MySQL创世之父的两千金My、Maria》介绍了MySQL的发展历程及其分支MariaDB。MySQL由Michael Widenius等人于1994年创建,现归Oracle所有,广泛应用于阿里巴巴、腾讯等企业。2009年,Widenius因担心Oracle收购影响MySQL的开源性,创建了MariaDB,提供额外功能和改进。维基百科、Google等已逐步替换为MariaDB,以确保更好的性能和社区支持。掌握MariaDB作为备用方案,对未来发展至关重要。
66 3
|
2月前
|
安全 关系型数据库 MySQL
MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!
《MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!》介绍了MySQL中的三种关键日志:二进制日志(Binary Log)、重做日志(Redo Log)和撤销日志(Undo Log)。这些日志确保了数据库的ACID特性,即原子性、一致性、隔离性和持久性。Redo Log记录数据页的物理修改,保证事务持久性;Undo Log记录事务的逆操作,支持回滚和多版本并发控制(MVCC)。文章还详细对比了InnoDB和MyISAM存储引擎在事务支持、锁定机制、并发性等方面的差异,强调了InnoDB在高并发和事务处理中的优势。通过这些机制,MySQL能够在事务执行、崩溃和恢复过程中保持
104 3
|
2月前
|
SQL 关系型数据库 MySQL
数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog
《数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog》介绍了如何利用MySQL的二进制日志(Binlog)恢复误删除的数据。主要内容包括: 1. **启用二进制日志**:在`my.cnf`中配置`log-bin`并重启MySQL服务。 2. **查看二进制日志文件**:使用`SHOW VARIABLES LIKE &#39;log_%&#39;;`和`SHOW MASTER STATUS;`命令获取当前日志文件及位置。 3. **创建数据备份**:确保在恢复前已有备份,以防意外。 4. **导出二进制日志为SQL语句**:使用`mysqlbinlog`
104 2
|
2月前
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
327 15
|
2月前
|
SQL 关系型数据库 MySQL
数据库数据恢复—Mysql数据库表记录丢失的数据恢复方案
Mysql数据库故障: Mysql数据库表记录丢失。 Mysql数据库故障表现: 1、Mysql数据库表中无任何数据或只有部分数据。 2、客户端无法查询到完整的信息。
|
2月前
|
关系型数据库 MySQL 数据库
数据库数据恢复—MYSQL数据库文件损坏的数据恢复案例
mysql数据库文件ibdata1、MYI、MYD损坏。 故障表现:1、数据库无法进行查询等操作;2、使用mysqlcheck和myisamchk无法修复数据库。