基于 linux 的 Centos 7 安装 Mysql 8,包含以下步骤 安装工作:卸载 MariaDB,下载资源包,检查旧版本 mysql,解压安装。配置工作:基本设置,创建用户组和用户,数据目录。初始化 MySQL:配置文件,初
👉 安装 MySQL 之前,先卸载自带的 MariaDB。
步骤
查看版本:有则需要卸载。
rpm -qa|grep mariadb
卸载:复制文件名,执行以下指令。
rpm -e --nodeps 文件名
确认卸载:
rpm -qa|grep mariadb
图示
Hint:将 MySQL 资源包放在
/usr/local/
下
2 种下载方式:
官网下载:Linux - Generic (glibc 2.12) (x86, 64-bit)
上传到服务器:/usr/local/
目录下。
wget 指令:在 /usr/local/
下执行,下载资源包。
# 格式:wget 资源地址wget https://dev.mysql.com/get/Downloads/MySQL-8.0/mysql-8.0.20-linux-glibc2.12-x86_64.tar.xz
指令:
rpm -qa|grep mysql
没有输出:说明当前系统没有安装 MySQL,开始安装。
有输出:显示的 MySQL 不是想要的版本,则卸载。
# 停止服务systemctl stop mysqld# 卸载rpm -e --nodeps mysql文件名
解压:tar 指令。
# .tar.gz 后缀tar -zxvf 文件名# .tar.xz 后缀tar -Jxvf 文件名
解压完成:/usr/local/
下会生成 MySQL 文件夹。
Hint:将 MySQL 安装在
/usr/local/
下若没有安装在该目录下,通过
mv
指令移动到该目录。
安装完成后的基本设置。
重命名 MySQL 文件夹(或创建软链接 👉文件管理 2.5)
通常命名为 mysql版本号
# 重命名(也可通过Xftp修改)mv 原文件夹名 mysql8# 软链接ln -s 文件夹名 mysql8
添加 PATH 变量后,可在全局使用 MySQL
添加方式:
临时生效:export 命令(连接会话关闭后失效,通常用于测试环境)
export PATH=$PATH:/usr/local/mysql8/bin
永久生效:修改配置文件。
查看版本
mysql --version
确定 MySQL 安装成功后,可删除压缩包。
rm -rf 压缩包名
注:需要进入
/usr/local
创建用户组:groupadd
创建用户:useradd
(-r
创建系统用户,-g
指定用户组)
groupadd mysqluseradd -r -g mysql mysql
创建目录:
mkdir -p /data/mysql8_data
赋予权限:
# 更改属主和数组chown -R mysql:mysql /data/mysql8_data# 更改模式chmod -R 750 /data/mysql8_data
在
/usr/local/etc/
下创建my.cnf
配置文件用于初始化 MySQL 数据库
注:部分配置涉及 MySQL 文件夹名称,若文件夹名不是
mysql8
则需修改。
在本地创建后,通过 Xftp 上传
使用 Vim 编辑器 进行编辑
进入 Vim 编辑器
vim /usr/local/etc/my.cnf
按 i
进入输入模式,粘贴以下配置。
按 ESC
退出编辑模式,按 :wq
保存并退出。
[mysql]# 默认字符集default-character-set=utf8mb4[client]port = 3306Socket = /tmp/mysql.sock[mysqld]port = 3306server-id = 3306user = mysqlsocket = /tmp/mysql.sock# 安装目录basedir = /usr/local/mysql8# 数据存放目录datadir = /data/mysql8_data/mysqllog-bin = /data/mysql8_data/mysql/mysql-bininnodb_data_home_dir =/data/mysql8_data/mysqlinnodb_log_group_home_dir =/data/mysql8_data/mysql# 日志及进程数据的存放目录log-error =/data/mysql8_data/mysql/mysql.logpid-file =/data/mysql8_data/mysql/mysql.pid# 服务端字符集character-set-server=utf8mb4lower_case_table_names=1autocommit =1##### 以上涉及文件夹明,注意修改skip-external-lockingkey_buffer_size = 256Mmax_allowed_packet = 1Mtable_open_cache = 1024sort_buffer_size = 4Mnet_buffer_length = 8Kread_buffer_size = 4Mread_rnd_buffer_size = 512Kmyisam_sort_buffer_size = 64Mthread_cache_size = 128#query_cache_size = 128Mtmp_table_size = 128Mexplicit_defaults_for_timestamp = truemax_connections = 500max_connect_errors = 100open_files_limit = 65535binlog_fORMat=mixedbinlog_expire_logs_seconds =864000# 创建表时使用的默认存储引擎default_storage_engine = InnoDBinnodb_data_file_path = ibdata1:10M:autoextendinnodb_buffer_pool_size = 1024Minnodb_log_file_size = 256Minnodb_log_buffer_size = 8Minnodb_flush_log_at_trx_commit = 1innodb_lock_wait_timeout = 50transaction-isolation=READ-COMMITTED[mysqldump]quickmax_allowed_packet = 16M[myisamchk]key_buffer_size = 256Msort_buffer_size = 4Mread_buffer = 2Mwrite_buffer = 2M[mysqlhotcopy]interactive-timeout
Hint:需要进入
/usr/local/mysql/bin
,若添加了 PATH 变量可忽略。
初始化命令:注意文件夹名称。
--defaults-file
:指定配置文件(要放在--initialize 前面)
--user
: 指定用户
--basedir
:指定安装目录
--datadir
:指定初始化数据目录
--intialize-insecure
:初始化无密码(否则生成随机密码)
mysqld --defaults-file=/usr/local/etc/my.cnf --basedir=/usr/local/mysql8 --datadir=/data/mysql8_data/mysql --user=mysql --initialize-insecure
查看 MySQL 的
/bin
下是否包含mysqld_safe
用于后台安全启动 MySQL
安全后台启动 MySQL
# 完整命令/usr/local/mysql8/bin/mysqld_safe --defaults-file=/usr/local/etc/my.cnf 若添加了PATH变量,可省略如下mysqld_safe --defaults-file=/usr/local/etc/my.cnf &
确认启动:第二条即 MySQL 服务。
ps -ef|grep mysql
无密码:若以 --initialize-insecure
初始化,首次登录时跳过密码。
mysql -u root --skip-passWord
有密码:若初始化时设置了随机密码,在 /data/mysql8_data/mysql/mysql.log
查看
mysql -u root -p
说明
登录后进入 MySQL 命令行
以下报错,说明 MySQL 服务没开启
ERROR 2002 (HY000): Can't connect to local MySQL Server through socket '/tmp/mysql.sock' (2)
MySQL 初始化的 root 用户、新创建的用户,都需要设置首次密码。
建议使用本地密码插件
mysql_native_password
。
# 修改密码ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '新密码';# 刷新权限FLUSH PRIVILEGES;
可在 Linux 或 MySQL 中修改。
Linux 命令行
mysqladmin -u用户名 -p旧密码 password 新密码
MySQL 命令行
# 设置密码SET PASSWORD FOR '用户名'@'主机' = PASSWORD(‘密码');# 刷新权限FLUSH PRIVILEGES;
在 MySQL 命令行中执行
若在 Linux 命令行中,会退出/关闭 Linux 服务器。
退出 MySQL(命令行):
quit;exit;
关闭 MySQL 服务:
shutdown;
选择 mysql 数据库,查看当前用户
USE mysql;SELECT user,host,plugin,authentication_string FROM user;
host 字段
表示可访问当前数据库的主机,目前仅本地可访问。
创建用户,任意远程访问
# 创建用户CREATE user 'root'@'%';# 设置首次密码ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '密码';# 授权用户所有权限,刷新权限GRANT ALL PRIVILEGES ON *.* TO 'root'@'%';FLUSH PRIVILEGES;
查看用户:已创建一个可被任意远程主机访问的 root 用户。
启动 MySQL 服务(本文 4.1.1)
开放端口:默认端口号 3306
查看端口状态:no 表示未开启
firewall-cmd --query-port=3306/tcp
永久开放端口:
firewall-cmd --add-port=3306/tcp --permanent
重启防火墙:
systemctl restart firewalld
远程连接:
TODO:远程连接报错 1045 分析。
完结撒花 🌹
Linux 中还可以设置 MySQL 开机自启,本文不做介绍。
来源地址:https://blog.csdn.net/qq_51835226/article/details/131575378
--结束END--
本文标题: 基于 Linux 的 CentOS 7 安装 MySQL 8,包含以下步骤
本文链接: https://www.lsjlt.com/news/402555.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2024-05-13
2024-05-13
2024-05-13
2024-05-13
2024-05-12
2024-05-12
2024-05-12
2024-05-12
2024-05-12
2024-05-12
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0