yum源安装
# 下载yum源的rpm包
wget https://dev.mysql.com/get/mysql57-community-release-el7-11.noarch.rpm
# 安装源
rpm -Uvh mysql57-community-release-el7-11.noarch.rpm
# 安装mysql
yum -y install mysql-community-server
#mysql开机启动
systemctl enable mysqld.service
#检查mysql状态
systemctl status mysqld.service
#启动mysql
systemctl start mysqld.service
#停止mysql
systemctl stop mysqld.service
修改/etc/my.cnf 修改mysql的端口和字符集 修改前需要备份该文件 保存不了的话看下是否停止mysql
[mysqld]
# 数据库数据目录 如果不存在 mysql启动时会创建默认数据库
# 如果数据库发生过变化如修改密码或添加过数据库等 则需要把以前的数据库目录移动到新位置 否则会导致数据丢失
datadir=/data/mysql
# 修改该目录后 mysql链接数据库报错 所以没改 报错信息如下
# ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2) 这是找不到sock文件
# /var/lib/mysql目录需要存在 且所属用户为mysql 可以使用命令 chown -R mysql:mysql /var/lib/mysql
# 如果一定要修改 但是使用mysql链接报错的话 要么使用-h指定服务器地址 要么使用-S指定sock文件
# 要么创建个软连接 如ln -sf /data/mysql/mysql.sock /var/lib/mysql/mysql.sock
socket=/var/lib/mysql/mysql.sock
port=3316
character-set-server=utf8mb4
[mysql]
default-character-set=utf8mb4
[client]
default-character-set=utf8mb4
#重启mysql
systemctl restart mysqld.service
#查看mysql密码
cat /var/log/mysqld.log | grep 'A temporary password'
2018-05-25T06:55:29.033154Z 1 [Note] A temporary password is generated for root@localhost: eCBHGi%Cr4fh
#登录mysql 密码为eCBHGi%Cr4fh
mysql -uroot -P3316 -p
#下面操作为敏感操作 关闭日志记录
mysql>set sql_log_bin=0;
#修改密码为root 低版本不需要设置密码策略 因为没有这些建 好像从5.7.29开始用的
mysql>set global validate_password_policy=LOW; #设置低密码验证强度
mysql>set global validate_password_length=5; #设置密码长度为5
mysql>ALTER user 'root'@'localhost' identified by 'admin'; #修改密码为admin
mysql>use mysql;
mysql>update user set host='%' where user='root'; #让root用户可以在所有机器上登录
#敏感操作完成开启日志
mysql>set sql_log_bin=1;
如果磁盘可用空间不足也会启动mysql失败
#把远端mysql中的xxx库 导出为文件
mysqldump -uroot -h192.168.1.253 -P3316 -p xxx --skip-lock-tables >> xxx.sql
#创建数据库xxx 可以通过create database xxx character set utf8来设置编码
mysql>create database xxx;
#切换到xxx数据库
mysql>use xxx;
#根据xxx.sql恢复xxx数据库
mysql>source /data/xxx.sql
二进制安装mysql(不是源码编译安装 已经编译好的二进制)主从运行
tar xvf mysql-5.7.20-linux-glibc2.12-x86_64.t