MySQL通过rpm安装及其单机多实例部署
1. CentOS 下安装 MySQL
Oracle 收购 MySQL 后,CentOS 为避免 MySQL 闭源的风险,改用 MySQL 的分支 MariaDB;
MariaDB 完全兼容 MySQL,包括API和命令行,但还是有些地方不一样(比如命令行提示符);
要想使用传统的官方版本 MySQL Community,需要手工下载并安装。
1.1 安装与启动
1.1.1 自动方法,国内下载慢(90min)
|
1
2
3
4
5
|
## https://dev.mysql.com/downloads/repo/yum/
## cat /etc/redhat-release ## CentOS Linux release 7.3.1611
wget --tries=0 --retry-connrefused http://repo.mysql.com//mysql57-community-release-el7-9.noarch.rpm
sudo yum -y install mysql57-community-release-el7-9.noarch.rpm
sudo yum -y install mysql-server
|
1.1.2 手动方法,下载速度快
使用迅雷等多线程下载工具,下载各安装包至 PC,再上传至 Linux 主机:
- mysql-community-common, 1M
- mysql-community-libs, 2M
- mysql-community-client, 24M
- mysql-community-server, 162M
然后按下面顺序安装(有依赖关系):
|
1
2
3
4
5
|
sudo yum -y remove mariadb-libs
sudo yum -y install mysql-community-common-5.7.17-1.el7.x86_64.rpm
sudo yum -y install mysql-community-libs-5.7.17-1.el7.x86_64.rpm
sudo yum -y install mysql-community-client-5.7.17-1.el7.x86_64.rpm
sudo yum -y install mysql-community-server-5.7.17-1.el7.x86_64.rpm
|
1.2 启动 MySQL 服务进程
|
1
2
3
|
sudo systemctl enable mysqld # 加入开机启动
sudo systemctl start mysqld # 立即启动
sudo netstat -natp | grep mysqld ## 检测监听端口
|
1.3 日志文件时间格式
查看日志文件 /var/log/mysqld.log,发现时间格式为 2016-12-21T13:15:11.097632Z,为 UTC 格式,与北京时间相差 8 小时;
|
1
2
3
4
|
### sudo vim /etc/my.cnf
[mysqld]
log_timestamps=SYSTEM # log time zone
explicit_defaults_for_timestamp=true
|
调整后重启 mysqld,日志中变为北京时间,形如“2016-12-22T11:52:12.499593+08:00”,但格式非预期,没能找到解决办法,但尚能授受。
1.4 修改密码
1.4.1 已知 root 密码时
|
1
2
3
4
5
6
7
8
|
## MySQL 首次启动时随机生成 root 密码,要求修改后才能继续使用
## MySQL 5.7 密码要求: 8位以上、大小写、数字、字符
sudo grep "temporary password" /var/log/mysqld.log | awk -F'root@localhost: ' '{print $2}' # 查询初始密码
mysql -uroot -p
MySQL> SET PASSWORD = 'MySQL5.7';
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.%'; ## 查看授权结果
|
1.4.2 忘记密码时
首先,修改 MySQL 配置,跳过授权验证,安全起见同时关闭网络防止外部主机连接:
|
1
2
3
4
|
## sudo vim /etc/my.cnf
[mysqld]
skip-networking
skip-grant-tables
|
重启 MySQL 服务:
|
1
|
sudo systemctl restart mysqld
|
重新设置 root 密码:
|
1
2
3
|
mysql -uroot # 此时可无密码登录
MySQL> UPDATE mysql.user SET authentication_string=password('MySQL5.7') WHERE user='root';
MySQL> FLUSH PRIVILEGES; EXIT;
|
恢复之前的 MySQL 配置,并重启服务,操作完毕:
|
1
2
3
|
sudo vim /etc/my.cnf # 撤消刚刚的修改
sudo systemctl restart mysqld
mysql -uroot -p # 此时指定新设密码登录
|
1.5 防火墙放行
|
1
2
3
|
### sudo vim /etc/sysconfig/iptables
-A INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT
### 重启生效: sudo systemctl restart iptables
|
1.6 验证连接
在 Windows 上连接 MySQL 来验证:
DOS> mysql -uroot -hcentos -pMySQL5.7 -P3306 -e “SELECT user(), @@port”
输出 root@192.168.214.1 | 3306, 验证通过。
1.7 卸载 MySQL
若要重新安装 MySQL 服务,需要先卸载:
|
1
2
3
4
5
|
# 注意:如果重装版本号不变,则可以不卸载 mysql57-community-release
sudo systemctl stop mysqld
sudo systemctl disable mysqld
sudo yum -y remove mysql-server mysql-client mysql-common mysql-libs
sudo rm -rf /var/lib/mysql /usr/share/mysql /etc/my.cnf /var/log/mysqld.log
|
执行完毕后,检查卸载是否彻底:
|
1
2
|
rpm -qa | grep -i mysql
sudo find / -name "mysql*"
|
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(停止), reload(重启), report(报告)
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 模式
|
1
2
3
4
|
# sudo vim /etc/selinux/config
# mode of SELinux: enforcing=enable, permissive=disable
# SELINUX=enforcing
SELINUX=permissive
|
Linux sudo reboot 之后生效。
如果漏掉此操作,启动实例时会报错:
|
1
2
3
4
|
[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 error
|
参考资料: http://stackoverflow.com/questions/26474222/mariadb-10-centos-7-moving-datadir-woes
2.3 MySQL 配置文件中增加实例配置
|
1
2
3
4
5
6
7
8
|
## sudo vim /etc/my.cnf
[mysqld@slave]
port=33061
datadir=/var/lib/mysql-slave
socket=/var/lib/mysql-slave/mysql.sock
log-error=/var/log/mysqld-slave.log
explicit_defaults_for_timestamp=true
log_timestamps=SYSTEM
|
参考资料: http://dev.mysql.com/doc/refman/5.7/en/using-systemd.html#systemd-multiple-mysql-instances
2.4 启动新实例
|
1
2
|
sudo systemctl enable mysqld@slave # 加入开机启动
sudo systemctl start mysqld@slave # 立即启动
|
2.5 强制本机客户端以 TCP 连接
这里有个大坑,Linux 上使用 mysql -uroot -P33061 -p 连接时,即使指定了 slave 端口号,仍然连接到 master 库,百思不得其解;
原来有个隐规则:当以 localhost 连接时(不指定-h时默认为localhost),MySQL 是通过 Unix Socket(而不是 TCP) 连接。此时指定的端口被忽略。
解决办法(mysqld 无需重启,立即生效):
|
1
2
3
|
## sudo vim /etc/my.cnf
[client]
protocol = TCP
|
相关资料: http://dev.mysql.com/doc/refman/5.7/en/connecting.html#option_general_protocol
2.6 修改密码
|
1
2
3
4
5
|
sudo grep "temporary password" /var/log/mysqld-slave.log | awk -F'root@localhost: ' '{print $2}' # 查询初始密码
mysql -uroot -P33061 -p # tBXQh60y<Hen
MySQL> SET PASSWORD = 'MySQL5.7';
MySQL> GRANT ALL PRIVILEGES ON *.* TO 'root'@'192.168.%' IDENTIFIED BY 'MySQL5.7' WITH GRANT OPTION;
MySQL> SHOW GRANTS FOR 'root'@'192.168.%'; ## 查看授权结果
|
2.7 防火墙放行
|
1
2
3
|
### sudo vim /etc/sysconfig/iptables
-A INPUT -m state --state NEW -m tcp -p tcp --dport 33061 -j ACCEPT
### 重启生效: sudo systemctl restart iptables
|
2.8 验证连接
在 Windows 上连接 MySQL 来验证:
DOS> mysql -uroot -hcentos -pMySQL5.7 -P33061 -e “SELECT user(), @@port”
输出 root@192.168.214.1 | 33061, 验证通过
MySQL通过rpm安装及其单机多实例部署的更多相关文章
- MYSQL 5.5.32的单机多实例部署
Centos6.6安装并配置单机多实例的MYSQL数据库 本文介绍安装单机多实例的MYSQL数据库的环境如下: 系统平台环境:Centos6.6 Mysql软件包:Mysql-5.5.32.tar.g ...
- Mysql 数据库单机多实例部署手记
最近的研发机器需要部署多个环境,包括数据库.为了管理方便考虑将mysql数据库进行隔离,即采用单机多实例部署的方式.找了会资料发现用的人也不是太多,一般的生产环境为了充分发挥机器性能都是单机单 ...
- tomcat单机多实例部署
最近在面试的过程中,一家公司在面试时提到了有关tomcat单机多实例部署的提问, 正好, 之前使用IntelliJ IDEA 13.1.4这款IDE开发web项目,在开发的过程中,因为有多个web项目 ...
- MySQL通过RPM安装
以前写过一篇文章,RedHat Linux 6.1 安装MySQL,本文是从解决依赖的角度上再次描述如何在Linux下以RPM包方式安装MySQL. [root@serv01 ~]# ls /iso/ ...
- MySql的rpm安装
MySQL 5.5(rpm格式)在Linux 上安装 Linux系统上安装MySQL 5.5prm 1.准备工作 从MySQL官网上分别下载mysql服务器端于客户端包. 下载步骤:Downloads ...
- MySQL的rpm安装教程
Linux 上安装 MySQL Linux平台上推荐使用RPM包来安装Mysql,MySQL AB提供了以下RPM包的下载地址: MySQL - MySQL服务器.你需要该选项,除非你只想连接运行在另 ...
- MySQL之RPM安装说明及配置
1.查看当前系统是否安装过Linux rpm -qa | grep -i mysql 未安装无任何输出:安装会打印对应mysql的rpm安装包. 2.准备安装包: MySQL-client-5.5.4 ...
- Linux下安装Mysql(RPM安装)
一.去官网下载本次安装须要的mysql版本号.我们须要安装的是5.1版本号的且centos系统是64位的.所下面载的是MySQL-community-5.1.73-1.rhel5.x86_64.rpm ...
- Mysql之rpm安装5.7版本遇见的问题
前言:环境是centos7.5的系统,用rpm方式安装mysql5.7 1.由于是centos7.5 所以需要将默认的mariadb给卸载 rpm -qa | grep mariadb 查看下是否有m ...
随机推荐
- centos systemctl daemon-reload 提示 no such file or directory 的一个原因
service 的文件名写错了 比如 mongodb.service 写成了 mongodb.srvice 真的是坑,居然没有提示具体的路径,只是提示一个 no such file or direct ...
- Tomcat性能调优及JVM内存工作原理
Java性能优化方向:代码运算性能.内存回收.应用配置. 注:影响Java程序主要原因是垃圾回收,下面会重点介绍这方面 代码层优化:避免过多循环嵌套.调用和复杂逻辑.Tomcat调优主要内容如下:1. ...
- tp5.1 高级查询之 表里2字段比较大小
$map = [ 'status' => 1, 'is_show' => 1,]; $result = Db::name('coupon') ->where($map) ->w ...
- Rigidbody和Collider
Rigidbody: 常用属性: Mass:默认为1,单位并不是g或kg,而是相对的质量计量单位,只决定物体的惯性: Drag:空气阻力: Angular Drag:角阻力,旋转时受的阻力: Use ...
- Java poi读取,写入Excel2007
Java poi读取,写入Excel2007 相关阅读:poi读写Excel2003:http://www.cnblogs.com/gavinYang/p/3576739.htmljxl读写excel ...
- bzoj千题计划115:bzoj1024: [SCOI2009]生日快乐
http://www.lydsy.com/JudgeOnline/problem.php?id=1024 枚举横着切还是竖着切,一边儿分多少块 #include<cstdio> #incl ...
- 《A First Course in Abstract Algebra with Applications》-chaper1-数论-棣莫弗定理
定理1.24 (棣莫弗定理) 对每个实数x和每个正整数n有 基于棣莫弗定理的推论如下:
- android edittext 获取焦点并弹出软键盘
editText.setFocusable(true); editText.setFocusableInTouchMode(true); editText.requestFocus(); activi ...
- RulersGuides.js – 网站中实现 Photoshop 标尺效果
RulersGuides.js 是一个 JavaScript 库,在网页上添加类似 Photoshop 中的标尺和辅助网格线.要创建创建网格线线,请单击垂直或水平的标尺,然后推动就可以.还可以使用相应 ...
- 34、Collections工具类简介
Collections工具类简介 就像数组中的Arrays工具类一样,在集合里面也有跟Arrays类似的工具类Collections package com.sutaoyu.Collections; ...