linux系统(ubuntu)安装mysql8详细教程

作者:ChenZhen

博客地址:https://www.chenzhen.space/

版权:本文为博主 ChenZhen 的原创文章,本文版权归作者所有,转载请附上原文出处链接及本声明。

如果对你有帮助,请给一个小小的star⭐


总所周知,linux在服务器领域的应用是最强的,百度、谷歌、淘宝等应用和网站后台都是成千上万的Linux服务器组成的,世界上大部分软件和服务都是运行在Linux上的。

Linux系统是一个真正的多用户多任务的操作系统

Linux系统与Windows相比是更加安全的操作系统。

因此你的服务器会部署在linux系统上,这就是为什么我们要把mysql数据库安装在linux上的原因

进入正题,这里我用的发行版是ubuntu 不同版本用的指令可能会有些不同

请根据自己的版本选择合适的教程

1.下载mysql8

直接到官网下载最新版即可

MySQL :: Download MySQL Community Server

选择linux通用版本

选择glibc 64位压缩包

下个页面直接选择开始下载即可

然后将下载好的压缩包放到Linux的 /usr/local 目录下

2.输入指令解压到当前目录
bash 复制代码
tar -xvf mysql-8.0.30-linux-glibc2.12-x86_64.tar.xz
  • tar -xvf 可以解压tar.xz后缀的压缩文件
  • tar -zxvf 可以解压tar.gz后缀的压缩文件
3.重命名文件为mysql-8.0

(这里也可以选择创建一个名为mysql-8.0软连接指向文件)

bash 复制代码
mv mysql-8.0.30-linux-glibc2.12-x86_64 mysql-8.0
4.创建data文件夹 储存文件

在mysql目录下创建data文件夹

bash 复制代码
cd mysql-8.0

mkdir data
5.创建用户组以及用户

创建mysql组,再创建mysql用户并将mysql用户添加到组中

bash 复制代码
groupadd mysql

useradd -g mysql mysql
6.授权用户

将mysql文件夹的所有者和所有组都改为mysql

bash 复制代码
chown -R mysql.mysql /usr/local/mysql-8.0
7.mysql初始化

进入bin目录执行mysqld文件进行初始化

bash 复制代码
cd bin

./mysqld --user=mysql --basedir=/usr/local/mysql-8.0 --datadir=/usr/local/mysql-8.0/data/ --initialize
8.编辑my.cnf
bash 复制代码
vim /etc/my.cnf

注释掉mysqld_safe和下面2条内容 修改basedir datadir socket信息

xml 复制代码
[mysqld]
basedir=/usr/local/mysql-8.0
datadir=/usr/local/mysql-8.0/data
port=3306
socket=/tmp/mysql.sock
user=mysql

####9.添加mysqld服务

创建 systemd 服务文件 /etc/systemd/system/mysql.service

bash 复制代码
[Unit]
Description=MySQL Server
After=network.target

[Service]
Type=forking
User=mysql
Group=mysql
ExecStart=/usr/local/mysql/bin/mysqld_safe --datadir=/usr/local/mysql/data
ExecStop=/usr/local/mysql/bin/mysqladmin shutdown
Restart=always

[Install]
WantedBy=multi-user.target

启动并开机自启:

bash 复制代码
sudo systemctl daemon-reload
sudo systemctl start mysql
sudo systemctl enable mysql
sudo systemctl status mysql
11.启动mysql
bash 复制代码
systemctl start mysql
12.查看启动状态

可以用service mysql status 再次查看mysql启动状态

bash 复制代码
systemctl status mysql
13.(可选)加入环境变量
bash 复制代码
echo 'export PATH=/usr/local/mysql-8.0/bin:$PATH' >> ~/.bashrc
source ~/.bashrc
14.登录
bash 复制代码
mysql -uroot -p

在下方填入之前生成的随机密码

登录成功提示

15.修改root密码

接下来修改root密码,将123456换成你的新密码

别忘了结尾有个分号";"

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

然后刷新权限 使密码生效

bash 复制代码
flush privileges;
16.修改远程连接并生效

选中mysql数据库

bash 复制代码
use mysql;

设置允许远程连接并生效

bash 复制代码
update user set host='%' where user='root';
 
flush privileges;

root表示想要被连接的数据库的用户名

其中"%"表示允许所有机器能访问root用户

相关推荐
LoneEon3 小时前
Ubuntu 部署 Harbor 构建企业级私有镜像仓库
linux·运维·ubuntu·docker·harbor
用户31187945592183 小时前
如何在CentOS 7上安装bzip2-1.0.6-13.el7.x86_64.rpm RPM包(详细步骤)
linux
泡沫冰@3 小时前
shell编程:sed - 流编辑器(2)
linux
Kusunoki_D3 小时前
Linux to go Ubuntu 22.04 不匹配无线网卡 MT7925 的解决方法
linux·ubuntu
oLingXi123 小时前
Unity开发CI/CD工具Jenkins的安装(Windows10)
运维·unity·ci/cd·jenkins
egoist20234 小时前
[linux仓库]解剖ELF:从文件头到进程地址空间的完美映射
linux·elf·虚拟地址空间·静态链接
忘梓.4 小时前
Linux的写作日记:Linux基础开发工具(二):vim编辑器
linux·编辑器·vim
X1A0RAN4 小时前
在Unix/Linux中bash/sh/source以及./执行脚本的区别
linux·bash·unix
努力学习的小廉4 小时前
深入了解linux网络—— UDP网络通信
linux·网络·udp