1.安装前说明
本文档仅适用于 MySQL 8.0 glibc 版的安装使用,请使用官方的安装包进行安装
操作系统建议版本:
centos 6.x/7.x
redhat 6.x/7.x
oracle linux 6.x/7.x
数据库版本要求:
MySQL 5.7.14+
MySQL 8.0.12+
Mysql 安装路径(以下目录不需提前创建):
mysql 软件主目录:/usr/local/mysql
mysql 数据文件目录:/var/lib/mysql
96 / 184
mysql 其他日志,socket 文件存放目录:/var/lib/mysql
2.安装包下载
官网下载地址:https://dev.mysql.com/downloads/mysql/
根据 linux 系统位数下载最新的 Linux-Generic 安装包
3.上传安装包并使用 root 用户登入系统
通过 ftp 或者 ssh 等文件传输工具将下载得来的安装包上传至服务器
通过客户端工具使用 root 用户连接到服务器
4.安装依赖包创建 mysql 用户
libaio 属于建议安装的系统包,该功能可以提高数据库的 IO 性能
系统自带的有 yum 源可以使用 yum 安装或者使用系统自带的镜像进行 RPM 安装
[root@localhost ~]# yum install libaio -y
没有配置 yum 可使用 rpm 安装:rpm 安装命令:rpm -ivh libaio-0.3.107-10.el6.x86_64.rpm
创建 mysql 用户和用户组
[root@localhost ~]# groupadd mysql
[root@localhost ~]# useradd -r -g mysql -s /bin/false mysql
5.上传并解压安装包(上传路径没有要求)
[root@localhost ~]# cp mysql-8.0.12-linux-glibc2.12-x86_64.tar.xz /usr/local/
[root@localhost local]# cd /usr/local/
[root@localhost local]# xz -d mysql-8.0.12-linux-glibc2.12-x86_64.tar.xz
[root@localhost local]# tar xvf mysql-8.0.12-linux-glibc2.12-x86_64.tar
[root@localhost local]# mv /usr/local/mysql-8.0.12-linux-glibc2.12-x86_64
/usr/local/mysql
[root@localhost local]# cd mysql
[root@localhost mysql]# chown mysql:mysql -R /usr/local/mysql/*
6.初始化数据库
[root@localhost ~]# vi /etc/my.cnf
[mysqld]
user=mysql
port = 3306
socket = /var/lib/mysql/mysql.sock
datadir = /var/lib/mysql
character-set-server=utf8
server-id = 1
max_connections = 1000
group_concat_max_len = 102400
max_connect_errors = 10
table_open_cache = 4096
event_scheduler = ON
skip-name-resolve
lower_case_table_names = 1
max_allowed_packet = 64M
binlog_cache_size = 32M
max_heap_table_size = 256M
read_rnd_buffer_size = 64M
sort_buffer_size = 256M
join_buffer_size = 512M
thread_cache_size = 300
log_bin_trust_function_creators=1
key_buffer_size = 256M
read_buffer_size = 32M
read_rnd_buffer_size = 128M
bulk_insert_buffer_size = 512M
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
######READ-UNCOMMITTED, READ-COMMITTED, REPEATABLE-READ, SERIALIZABLE
transaction_isolation = READ-COMMITTED
tmp_table_size = 512M
log-bin=mysql-bin
binlog_format=mixed
expire_logs_days = 15
slow_query_log = 1
slow_query_log_file = /var/lib/mysql/slow.log
long_query_time = 5
####### InnoDB
innodb_buffer_pool_size = 512M
innodb_thread_concurrency = 16
innodb_flush_log_at_trx_commit = 2
innodb_log_buffer_size = 32M
innodb_log_file_size = 1024M
innodb_log_files_in_group = 4
innodb_max_dirty_pages_pct = 90
innodb_lock_wait_timeout = 120
#innodb_force_recovery=1
[mysqldump]
quick
max_allowed_packet = 64M
[mysql]
no-auto-rehash
[myisamchk]
key_buffer = 16M
sort_buffer_size = 16M
read_buffer = 8M
write_buffer = 8M
[mysqlhotcopy]
interactive-timeout
[mysqld_safe]
open-files-limit = 65535
log-error=/var/lib/mysql/mysqld.log
pid-file=/var/lib/mysql/mysqld.pid
初始化数据库,安装加密算法,并启动数据库(初始化过程有随机的 root 密码,注意输出信息)
[root@localhost mysql]# cd /usr/local/mysql
[root@localhost mysql]# bin/mysqld --initialize --user=mysql
注意此处的系统输出信息中包含系统默认的 root 用户密码,请记录下来。
安装加密算法
[root@localhost mysql]# bin/mysql_ssl_rsa_setup
7.注册数据库服务
[root@localhost mysql]# cd /usr/local/mysql
[root@localhost mysql]# cp support-files/mysql.server /etc/init.d/mysqld
[root@localhost mysql]# chmod +x /etc/init.d/mysqld
[root@localhost mysql]# chkconfig --add mysqld
[root@localhost mysql]# chkconfig mysqld on
8.启动 mysql 服务
[root@localhost mysql]#service mysqld start
9.配置数据库的 sock 文件,并修改 root 用户的初始密码
[root@localhost mysql]# ln -s /var/lib/mysql/mysql.sock /tmp/mysql.sock
[root@localhost mysql]# /usr/local/mysql/bin/mysql -uroot -p
Enter password: 输入随机生成的密码(即步骤 6 记录下来的密码)
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 8
Server version: 8.0.12
103 / 184
Copyright (c) 2000, 2018, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql> set password = 'mysqltest123';
Query OK, 0 rows affected (0.01 sec)
10.创建 XXX 数据库,并创建账号,赋权
mysql>create database XXX;
mysql> create user XXX identified with mysql_native_password by 'XXX123';
mysql> grant all privileges on *.* to ' XXX '@'%';
mysql> flush privileges;
11.停止 mysql 服务
[root@localhost mysql]#service mysqld stop