设为首页 收藏本站
查看: 901|回复: 0

[经验分享] MySQL 安装及其单机多实例部署

[复制链接]

尚未签到

发表于 2018-10-10 10:24:03 | 显示全部楼层 |阅读模式
1. CentOS 下安装 MySQL
  Oracle 收购 MySQL 后,CentOS 为避免 MySQL 闭源的风险,改用 MySQL 的分支 MariaDB;
  MariaDB 完全兼容 MySQL,包括API和命令行,但还是有些地方不一样(比如命令行提示符);
  要想使用传统的官方版本 MySQL Community,需要手工下载并安装。
1.1 安装与启动
1.1.1 自动方法,国内下载慢(90min)
## https://dev.mysql.com/downloads/repo/yum/wget --tries=0 --retry-connrefused http://repo.mysql.com//mysql57-community-release-el7-9.noarch.rpmsudo yum -y install mysql57-community-release-el7-9.noarch.rpmsudo yum -y install mysql-server123412341.1.2 手动方法,下载速度快
  使用迅雷等多线程下载工具,下载各安装包至 PC,再上传至 Linux 主机:
  - mysql-community-server, 162M
  - mysql-community-client, 24M
  - mysql-community-common, 1M
  - mysql-community-libs, 2M
  然后按下面顺序安装(有依赖关系):
sudo yum -y remove mariadb-libssudo 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.rpm1234512345
1.2 启动 MySQL 服务进程
sudo systemctl enable mysqld # 加入开机启动sudo systemctl start mysqld # 立即启动sudo netstat -natp | grep mysql ## 检测监听端口1231231.3 日志文件时间格式
  查看日志文件 /var/log/mysqld.log,发现时间格式为 2016-12-21T13:15:11.097632Z,为 UTC 格式,与北京时间相差 8 小时;
### sudo vim /etc/my.cnflog_timestamps=SYSTEM # log time zoneexplicit_defaults_for_timestamp=true123123  调整后重启 mysqld,日志中变为北京时间,形如“2016-12-22T11:52:12.499593+08:00”,但格式非预期,没能找到解决办法,但尚能授受。
1.4 修改密码
1.4.1 已知 root 密码时
## 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.%'; ## 查看授权结果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
  
socket=/var/lib/mysql-slave/mysql.sock
  
log-error=/var/log/mysqld-slave.log
  
explicit_defaults_for_timestamp=truelog_timestamps=SYSTEM1234567812345678
  参考资料: http://dev.mysql.com/doc/refman/5.7/en/using-systemd.html#systemd-multiple-mysql-instances
2.4 启动新实例
sudo systemctl enable mysqld@slave # 加入开机启动sudo systemctl start mysqld@slave # 立即启动12122.5 强制本机客户端以 TCP 连接
  这里有个大坑,Linux 上使用 mysql -uroot -P33061 -p 连接时,即使指定了 slave 端口号,仍然连接到 master 库,百思不得其解;
  原来有个隐规则:当以 localhost 连接时(不指定-h时默认为localhost),MySQL 是通过 Unix Socket(而不是 TCP) 连接。此时指定的端口被忽略。
  解决办法(mysqld 无需重启,立即生效):
## sudo vim /etc/my.cnf[client]  
protocol = TCP123123
  相关资料: http://dev.mysql.com/doc/refman/5.7/en/connecting.html#option_general_protocol
2.6 修改密码
sudo grep "temporary password" /var/log/mysqld-slave.log | awk -F'root@localhost: ' '{print $2}' # 查询初始密码  
mysql -uroot -P33061 -p # tBXQh60y 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.%'; ## 查看授权结果1234512345
2.7 防火墙放行
### sudo vim /etc/sysconfig/iptables-A INPUT -m state --state NEW -m tcp -p tcp --dport 33061 -j ACCEPT### 重启生效: sudo systemctl restart iptables1231232.8 验证连接
  在 Windows 上连接 MySQL 来验证:
  DOS> mysql -uroot -hcentos -pMySQL5.7 -P33061 -e “SELECT user(), @@port”
  输出 root@192.168.214.1 | 33061, 验证通过。
  本文出自http://blog.csdn.net/kefengwang/article/details/54233315



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-619853-1-1.html 上篇帖子: MySQL 监控(MySQL Monitoring)安装方法 下篇帖子: Mysql占用大量写I/O
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表