Linux下安装mysql-5.7.23
发布日期:2021-06-29 01:55:24
浏览次数:2
分类:技术文章
本文共 4076 字,大约阅读时间需要 13 分钟。
Linux Centos安装Mysql5.7.23
阿里云服务器安装Mysql数据官方帮助文档
我写的教程参考了上面的帮助文档。
需要一台服务器或者。选服务器的时候选择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/mysqlcd /usr/local/mysql tar -xvzf mysql-5.7.23-linux-glibc2.12-x86_64.tar.gzgroupadd mysqluseradd -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/mysqldchmod 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// 安全模式启动mysqlmysqld_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
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身份远程连接成功!
遇到问题
- 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://blog.csdn.net/yundashi168/article/details/112391579 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
很好
[***.229.124.182]2024年04月15日 01时19分16秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
秒开 100GB 数据!甩了 Pandas 几条街啊
2019-04-29
Python 内存分配时的小秘密
2019-04-29
Oh My God!Python 还能帮你理财?!
2019-04-29
C++多继承
2019-04-29
编程模式·观察者模式、事件通知、消息队列三者区别
2019-04-29
Android Activity启动流程(基于Android8.0系统)
2019-04-29
为什么要用HandlerThread,怎么用?
2019-04-29
Android IntentService的使用和源码分析
2019-04-29
Android线程管理(二)——ActivityThread
2019-04-29
Android使用Handler造成内存泄露的分析及解决方法
2019-04-29
android的handler、looper、Message之间的关系
2019-04-29
Android多线程的四种方式
2019-04-29
com.android.internal.R的位置
2019-04-29
Input dispatching timed out 导致anr问题分析
2019-04-29
主线程中Thread.Sleep()是否会导致ANR
2019-04-29
Android 为什么主线程的looper 一直循环不会ANR
2019-04-29
Android View 的绘制流程
2019-04-29
ContentProvider和数据库的区别
2019-04-29