Linux(CentOS7)安装 MySQL8

目录

下载

上传

解压

创建配置文件

[初始化 MySQL 服务](#初始化 MySQL 服务)

[启动 MySQL 服务](#启动 MySQL 服务)

[连接 MySQL](#连接 MySQL)

创建软链接


下载

官方地址:

MySQL :: Download MySQL Community Serverhttps://dev.mysql.com/downloads/mysql/选择版本前需先看一下服务器的 glibc 版本

bash 复制代码
ldd --version

上传

将下载好的 tar 包上传到服务器上,这里演示上传到了 /usr/local/ 文件夹下

解压

bash 复制代码
tar -Jxvf mysql-8.0.36-linux-glibc2.17-x86_64.tar.xz

解压后修改文件夹名(让文件夹名简短一点)

bash 复制代码
mv mysql-8.0.36-linux-glibc2.17-x86_64 mysql

进入 mysql 文件夹

创建配置文件

MySQL 服务启动项很多,一般不通过命令行输入,而是写在配置文件中,启动时指定配置文件即可。如果没有指定配置文件,则会去 /etc/my.cnf 等默认路径下找配置文件。

这里直接指定自己创建的配置文件,把一切都掌握在自己手里。

bash 复制代码
vim my.cnf

写入以下配置

mysqld

basedir=/usr/local/mysql/

datadir=/usr/local/mysql/data/

socket=/tmp/mysql.sock

character-set-server=UTF8MB4

创建 data 文件夹

bash 复制代码
mkdir data

初始化 MySQL 服务

进入 bin 文件夹

bash 复制代码
cd bin

指定自己创建的配置文件初始话 MySQL 服务

bash 复制代码
./mysqld --defaults-file=/usr/local/mysql/my.cnf --initialize

生成一个临时的 root 用户密码,以便首次登入 MySQL

启动 MySQL 服务

必须为 MySQL 创建 mysql 用户才能启动服务,否则会报错

创建用户和组

bash 复制代码
#创建用户组
groupadd mysql
#创建mysql用户并添加到mysql用户组
useradd -g mysql mysql
#授权
chown -R mysql.mysql /usr/local/mysql

启动服务,指定配置文件和使用 mysql 用户启动

bash 复制代码
./mysqld --defaults-file=/usr/local/mysql/my.cnf --user=mysql

连接 MySQL

输入刚刚初始化生成的随机密码

bash 复制代码
mysql -u root -p

修改 root 用户登录密码

bash 复制代码
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '123456';

flush privileges;

允许 root 用户远程连接

bash 复制代码
use mysql;

update user set host='%' where user='root';
 
flush privileges;

创建软链接

bash 复制代码
ln -s /usr/local/mysql/bin/mysql /usr/local/bin/mysql

这样就能够在任意路径下直接通过 mysql 命令来连接 MySQL 服务了

相关推荐
笨蛋不要掉眼泪2 小时前
Mysql架构揭秘:update语句的执行流程
数据库·mysql·架构
疯狂成瘾者2 小时前
服务器的单体和集群
运维·服务器
liuhuizuikeai2 小时前
可视化门禁---Linux/Qt+SqLite篇
linux·运维·qt
Andya_net3 小时前
MySQL | MySQL 8.0 权限管理实践-精确赋予库、表只读等权限
android·数据库·mysql
初願致夕霞3 小时前
基于系统调用的Linux网络编程——UDP与TCP
linux·网络·c++·tcp/ip·udp
czlczl200209254 小时前
理解 MySQL 行锁:两阶段锁协议与热点更新优化
数据库·mysql
charlie1145141915 小时前
嵌入式Linux驱动开发——新 API 字符设备驱动完整教程 - 从设备结构体到应用测试
linux·运维·驱动开发
渣渣盟6 小时前
Mysql入门到精通全集(SQL99)包含关系运算,软考数据库工程师复习首选
数据库·mysql·oracle
飞Link6 小时前
2000 亿砸向算力:字节跳动 AI 基建跨越,后端与运维的“万亿 Token”生死战
运维·人工智能
消失的旧时光-19436 小时前
C语言对象模型系列(四)《Linux 内核里的 container_of 到底是什么黑魔法?》—— 一篇讲透 Linux 内核的“对象模型”核心技巧
linux·c语言·算法