MySQL> SHOW VARIABLES LIKE 'validate_password%'; ## 查看密码要求
MySQL> GRANT ALL PRIVILEGES ON *.* TO 'root'@'192.168.%' IDENTIFIED BY 'MySQL5.7' WITH GRANT OPTION;
MySQL> SHOW GRANTS FOR 'root'@'192.168.%'; ## 查看授权结果1234567812345678 1.4.2 忘记密码时
首先,修改 MySQL 配置,跳过授权验证,安全起见同时关闭网络防止外部主机连接:
## sudo vim /etc/my.cnf[mysqld]skip-networkingskip-grant-tables12341234 重启 MySQL 服务:
sudo systemctl restart mysqld11 重新设置 root 密码:
mysql -uroot # 此时可无密码登录
MySQL> UPDATE mysql.user SET authentication_string=password('MySQL5.7') WHERE user='root';
MySQL> FLUSH PRIVILEGES; EXIT;123123
恢复之前的 MySQL 配置,并重启服务,操作完毕:
sudo vim /etc/my.cnf # 撤消刚刚的修改sudo systemctl restart mysqld
mysql -uroot -p # 此时指定新设密码登录123123 1.5 防火墙放行
### sudo vim /etc/sysconfig/iptables-A INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT### 重启生效: sudo systemctl restart iptables1231231.6 验证连接
在 Windows 上连接 MySQL 来验证:
DOS> mysql -uroot -hcentos -pMySQL5.7 -P3306 -e “SELECT user(), @@port”
输出 root@192.168.214.1 | 3306, 验证通过。 1.7 卸载 MySQL
若要重新安装 MySQL 服务,需要先卸载:
# 注意:如果重装版本号不变,则可以不卸载 mysql57-community-releasesudo systemctl stop mysqldsudo systemctl disable mysqldsudo yum -y remove mysql-server mysql-client mysql-common mysql-libssudo rm -rf /var/lib/mysql /usr/share/mysql /etc/my.cnf /var/log/mysqld.log1234512345 执行完毕后,检查卸载是否彻底:
rpm -qa | grep -i mysql
sudo find / -name "mysql*"1212 2. Linux 单机启动多个 MySQL 实例
单机多实例是指,单个 Linux 的单个 MySQL 安装,启动多个 MySQL 服务进程,监听多个端口提供多个数据库服务。
早期版本只能使用 mysqld_multi 实现多实例,从 MySQL 5.7.13 开始,只能使用 systemd 实现。
下面的多实例实现单机主从库,把原实例作为 master 库,新增实例作为 slave 库。 2.1 关于 mysqld_multi 命令
mysqld_multi 用来管理多个 mysqld 进程,各个进程以 GNR(Group Number) 标识。
命令格式为:mysqld_multi [options] {start|stop|reload|report} [GNR[,GNR] ...]
[options]: 对应于 my.cnf 中的 [mysqld_multi] 段;
可以执行的命令包括 start(启动), stop(停止),> GNR 必须为正整数,对应于 /etc/my.cnf 中 [mysqld{GNR}] 的 {GNR}
可以指定单个或多个 GNR(逗号分隔),不指定 GNR 时,表示所有 GNR;
下面是使用 systemd 实例单机多实例,关于 mysqld_multi 的实现请参考官方资料:
http://dev.mysql.com/doc/refman/5.7/en/mysqld-multi.html 2.2 关闭 SELinux 模式
# sudo vim /etc/selinux/config# mode of SELinux: enforcing=enable, permissive=disable# SELINUX=enforcingSELINUX=permissive12341234 Linux sudo reboot 之后生效。
如果漏掉此操作,启动实例时会报错:
[ERROR] InnoDB: Operating system error number 13 in a file operation.
[ERROR] InnoDB: The error means mysqld does not have the access right s to the directory.
[ERROR] InnoDB: os_file_get_status() failed on './ibdata1'. Can~t determine file permissions
[ERROR] InnoDB: Plugin initialization aborted with error Generic error12341234
参考资料: http://stackoverflow.com/questions/26474222/mariadb-10-centos-7-moving-datadir-woes 2.3 MySQL 配置文件中增加实例配置
## sudo vim /etc/my.cnf[mysqld@slave]
port=33061datadir=/var/lib/mysql-slave