Centos7安装配置mysql8

基于Linux Centos7安装配置Mysql8.+的步骤:

  1. 安装工作: 检查centos自带MariaDB,下载资源包,检查旧版本MySQL,解压安装
  2. 配置环境: 基本设置,创建用户和组,数据目录
  3. 初始化MySQL:配置文件,初始化
  4. 启动MySQL:启动服务,登录,修改密码,创建远程连接用户,退出

安装工作

检查卸载MariaDB

MariaDB

MySQL的一个分支,主要由开源社区维护。

  1. Centos7+不在默认使用MySQL数据库,而是MariaDB数据库。
  2. 直接安装MySQL会与MariaDB的文件冲突,需要先卸载。

卸载

  1. 检查版本:有则需要卸载
rpm -qa|grep mariadb
  1. 卸载:复制文件名,执行命令
rpm -e --nodeps 文件名
  1. 确认是否已卸载
rpm -qa|grep mariadb

不打印内容则卸载成功

下载资源包

官网下载(方式一)

  1. 官网地址:https://dev.mysql.com/downloads/mysql/
  2. 下载完成上传到服务器:/usr/local目录下

wget下载(方式二)

  1. 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

检查旧版MySQL

# 检查已安装的版本
rpm -qa|grep mysql
  • 没有输出:说明当前系统没有安装MySQL,开始安装。
  • 有输出:卸载后开始安装。
# 停止服务
systemctl stop mysqld

# 卸载
rpm -e --nodeps mysql文件名

解压安装

解压

tar命令

# .tar.gz 后缀
tar -zxvf 文件名

# .tar.xz 后缀
tar -Jxvf 文件名

安装目录

将MySQL安装在/usr/local/

配置工作

基本设置

设置安装目录

重命名MySQL文件夹(或创建软连接)
通常命名为mysql版本号

# 重命名(也可通过Xftp修改)
mv 原文件夹名 mysql8

# 或 软链接
ln -s 文件夹名 mysql8

PATH变量

添加方式

  1. 临时方式:export 命令(连接会话关闭后失效)
export PATH=$PATH:/usr/local/mysql8/bin
  1. 永久方式 (建议):修改配置文件
## 家目录~下 打开vim编辑配置文件
vim .bash_profile
## 或者编辑 /etc/profile
vim /etc/profile

确认安装

  1. 查看版本

mysql --version

  1. 确认MySQL安装成功,可删除压缩包

rm -rf 压缩包

创建用户/组(!)

注:目录需要切入 /usr/local

  1. 创建用户组:groupadd
  2. 创建用户:useradd (-r 创建系统用户 -g 指定用户组)
# 创建组 
groupadd mysql

# 创建用户 -r 创建系统用户 -g 指定用户组
useradd -r -g mysql mysql

数据目录

  1. 创建目录
mkdir -p /data/mysql
  1. 赋予权限
# 更改属主
chown -R mysql:mysql /data/mysql

# 更改模式 
chmod -R 750 /data/mysql8_data   # 或755

初始化 & 启动

配置文件

/usr/local/etc 下创建 my.cnf 配置文件,用于初始化 MySQL 数据库

配置方式:

  1. 可在本地创建好文件后,通过xftp上传
  2. 也可直接使用Vim编辑器编辑保存
# 进入vim编辑器
vim /usr/local/etc/my.cnf

# 编辑后:wq保存退出

配置内容

[mysql]
# 默认字符集
default-character-set=utf8mb4
[client]
port       = 3306
socket     = /tmp/mysql.sock
[mysqld]
port       = 3306
server-id  = 3306
user       = mysql
socket     = /tmp/mysql.sock
# 安装目录
basedir    = /usr/local/mysql
# 数据存放目录
datadir    = /data/mysql
log-bin    = /data/mysql/mysql-bin
innodb_data_home_dir      =/data/mysql
innodb_log_group_home_dir =/data/mysql
# 日志及进程数据的存放目录
log-error =/data/mysql/mysql.log
pid-file  =/data/mysql/mysql.pid
# 服务端字符集
character-set-server=utf8mb4
lower_case_table_names=1
autocommit =1
##### 以上涉及文件夹明,注意修改
skip-external-locking
key_buffer_size = 256M
max_allowed_packet = 1M
table_open_cache = 1024
sort_buffer_size = 4M
net_buffer_length = 8K
read_buffer_size = 4M
read_rnd_buffer_size = 512K
myisam_sort_buffer_size = 64M
thread_cache_size = 128
#query_cache_size = 128M
tmp_table_size = 128M
explicit_defaults_for_timestamp = true
max_connections = 500
max_connect_errors = 100
open_files_limit = 65535
binlog_format=mixed
binlog_expire_logs_seconds =864000
# 创建表时使用的默认存储引擎
default_storage_engine = InnoDB
innodb_data_file_path = ibdata1:10M:autoextend
innodb_buffer_pool_size = 1024M
innodb_log_file_size = 256M
innodb_log_buffer_size = 8M
innodb_flush_log_at_trx_commit = 1
innodb_lock_wait_timeout = 50
transaction-isolation=READ-COMMITTED
[mysqldump]
quick
max_allowed_packet = 16M
[myisamchk]
key_buffer_size = 256M
sort_buffer_size = 4M
read_buffer = 2M
write_buffer = 2M
[mysqlhotcopy]
interactive-timeout

初始化

需要进入 /usr/local/mysql/bin 目录下,若配置了PATH变量可忽略

初始化命令: 注意文件夹名称

  • –default-fiile :指定配置文件(–initialize前面)
  • –user :指定用户
  • –basedir :指定安装目录
  • –datadir :指定初始化数据目录
  • –intialize-insecure :初始化无密码 (否则会生成随机密码)
# 初始化代码
mysqld --defaults-file=/usr/local/etc/my.cnf --basedir=/usr/local/mysql8 --datadir=/data/mysql --user=mysql --initialize-insecure

启动MySQL

查看 MySQL 的/bin下是否包含 mysqld_safe
它用于后台安全启动 MySQL

启动服务

  1. 安全后台启动MySQL
# 完整命令
/usr/local/mysql8/bin/mysqld_safe --defaults-file=/usr/local/etc/my.cnf &

# 若添加了PATH变量,可省略成如下命令
mysqld_safe --defaults-file=/usr/local/etc/my.cnf &
  1. 确认启动
ps -ef|grep mysql

登录

  1. 无密码登录: 若在步骤 _3.2.初始化 _时以 --initialize-insecure初始化,首次登录时可跳过密码
mysql -u root --skip-password
  1. 有密码:若初始化时设置了随机密码,在 /data/mysql8_data/mysql/mysql.log 查看

修改密码

首次修改

# 修改密码
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '新密码';

# 刷新权限
FLUSH PRIVILEGES;

平时修改

  1. Linux命令行
mysqladmin -u用户名 -p旧密码 password 新密码
  1. MySQL命令行
# 设置密码
SET PASSWORD FOR '用户名'@'主机' = PASSWORD(‘密码');

# 刷新权限
FLUSH PRIVILEGES;

远程连接MySQL

远程连接用户

  1. 选择mysql数据库,查看当前用户
use mysql;

SELECT user,host,plugin,authentication_string FROM user;
  1. host字段表示可访问当前数据库的主机
# localhost代表仅可本地访问
  1. 创建用户,任意远程访问
# 创建用户
CREATE user 'root'@'%';

# 设置首次密码
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '密码';

# 授权用户所有权限,刷新权限
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%';
FLUSH PRIVILEGES;

远程连接MySQL

启动MySQL服务

# 配置好PATH
mysqld_safe --defaults-file=/usr/local/etc/my.cnf &

image.png

开放端口

  1. 查看端口状态: no 表示未开启
firewall-cmd --query-port=3306/tcp
  1. 永久开放端口:
firewall-cmd --add-port=3306/tcp --permanent
  1. 重启防火墙
systemctl restart firewalld

转载自:https://www.cnblogs.com/secretmrj/p/15600144.html

  • 22
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值