史上Mysql5.7.23最详细教程(CentOS7)
Posted androidstarjack
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了史上Mysql5.7.23最详细教程(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各有各的好处,毕竟这些都可以根据需要进行版本选择
安装准备
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配置文件。性能调优参数请自行查百度,这里写了最基本的,包括中文乱码问题
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客户端都能登录。
end
BAT等大厂Java面试经验总结 想获取 Java大厂面试题学习资料扫下方二维码回复「BAT」就好了回复 【加群】获取github掘金交流群回复 【电子书】获取2020电子书教程回复 【C】获取全套C语言学习知识手册回复 【Java】获取java相关的视频教程和资料回复 【爬虫】获取SpringCloud相关多的学习资料回复 【Python】即可获得Python基础到进阶的学习教程回复 【idea破解】即可获得intellij idea相关的破解教程关注我gitHub掘金,每天发掘一篇好项目,学习技术不迷路!
回复 【idea激活】即可获得idea的激活方式
回复 【Java】获取java相关的视频教程和资料
回复 【SpringCloud】获取SpringCloud相关多的学习资料
回复 【python】获取全套0基础Python知识手册
回复 【2020】获取2020java相关面试题教程
回复 【加群】即可加入终端研发部相关的技术交流群
阅读更多
为什么HTTPS是安全的
因为BitMap,白白搭进去8台服务器...
《某厂内部SQL大全 》.PDF
字节跳动一面:i++ 是线程安全的吗?
大家好,欢迎加我微信,很高兴认识你!
在华为鸿蒙 OS 上尝鲜,我的第一个“hello world”,起飞!
相信自己,没有做不到的,只有想不到的在这里获得的不仅仅是技术!
如果喜欢就给个“在看”
以上是关于史上Mysql5.7.23最详细教程(CentOS7)的主要内容,如果未能解决你的问题,请参考以下文章
Linux CentOS7.5上二进制安装MySQL5.7.23