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 主机:

然后按下面顺序安装(有依赖关系):

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;

2.2 关闭 SELinux 模式

1

2

3

4

# sudo vim /etc/selinux/config

# mode of SELinux: enforcing=enable, permissive=disable

# SELINUX=enforcing

SELINUX=permissive

Linuxsudo 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

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

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

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

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, 验证通过

rpm安装两个mysql_MySQL通过rpm安装及其单机多实例部署相关推荐

  1. 服务器如何安装两个系统,服务器如何安装双操作系统

    服务器如何安装双操作系统 内容精选 换一换 PostgreSQL官网提供了针对不同操作系统的客户端安装包,以及包含动态依赖库的软件包.RDS for PostgreSQL提供了PostgreSQL增强 ...

  2. linux rpm mysql 路径_linux基础-linux 下 安装 rpm 格式 的 mysql

    在Linux操作系统下,安装MYSQL有两种方式: 一种tar安装方式, 另外一种是rpm安装方式. 这两种安装方式有什么区别呢?尽管我们在Linux下常用tar来压缩/解压缩文件,但MYSQL的ta ...

  3. suse 安装mysql5.6_SuSE11安装MySQL5.6.40:RPM安装方式

    摘要:SuSE11sp3 64位操作系统. MySQL5.6.40rpm安装包 注:kingtry是我的主机名 一.环境准备 操作系统:SuSE版本11sp3,64位kingtry:~ # uname ...

  4. Linux学习笔记4-三种不同类型的软件的安装(绿色软件、rpm软件、源代码软件)...

    在Linux下软件分三种: 1.绿色软件:即不用安装直接就能用的软件 2.rpm安装包:以rpm结尾的可执行文件  3.源码文件:没有进行过编译和打包的文件,需要编译后再进行安装 一.绿色软件的安装 ...

  5. nessus rpm 安装_CentOS8.0下查看已安装的软件位置

    本文CentOS8.0环境为基础,以安装nginx说明. CentOS8发行版 / 存储库: CentOS 8 主要通过两个存储库分发:BaseOS.AppStream: BaseOS 存储库:主要包 ...

  6. RPM方式安装MySQL5.6和windows下安装mysql解压版

    下载地址: http://cdn.MySQL.com/archives/mysql-5.6/MySQL-server-5.6.13-1.el6.x86_64.rpm http://cdn.mysql. ...

  7. Linux 如何安装 SRPM 包(源代码 rpm 软件包,以 .src.rpm 为后缀名)/rpm 格式的源码软件包/源码包

    文章目录 一.SRPM 介绍 二.SRPM 命名格式 三.SRPM 的安装 (一)直接使用命令 rpmbuild (二)利用 *.spec 文件编译 (三)使用命令 make 编译和安装 四.写在最后 ...

  8. suse11 rpm 安装mysql_SuSE11安装MySQL5.7.22:RPM安装方式

    摘要:SuSE11sp3 64位操作系统. MySQL5.7.22 rpm安装包 5.7版本与先前版本安装有所区别,需要注意 注:kingtry是我的主机名 一.环境准备 操作系统:SuSE版本11s ...

  9. rpm安装mysql5.5_CentOS下以RPM方式安装MySQL5.5

    1.查找以前是否装有mysql 命令:rpm -qa|grep -i mysql 可以看到mysql的两个包: mysql-4.1.12-3.RHEL4.1 mysqlclient10-3.23.58 ...

最新文章

  1. 盘点深度学习中的各种数据增强技巧
  2. python迅雷远程下载页面_【教程】Chrome浏览器添加迅雷下载支持
  3. IDEA的GsonFormat插件--将json字符串直接实例化成类
  4. Chipscope使用
  5. 通过改善架构来提高 ASP.Net 应用程序的性能
  6. 贵州2021高考体考成绩查询,2021年贵州体育专业考试成绩查询网址:http://www.eaagz.org.cn/...
  7. 【算法设计与分析】03 算法及其时间复杂度
  8. vue2.x+springboot1.x+nginx服务器部署踩坑日记
  9. 详解HTML5中rel属性的prefetch预加载功能使用
  10. ElasticSearch 5.3源码学习 —— Segments_N 文件详解
  11. 计算机网络监控,计算机网络连接监控系统.doc
  12. java虚拟机安装_java虚拟机官方下载|Java Virtual Machine(java虚拟机)下载v5.0官方版 附安装教程 - 欧普软件下载...
  13. Glide圆角和centerCrop()的那些坑
  14. Linux 在线扫描热添加的SCSI设备
  15. 数据中心Overlay技术简介
  16. 淘宝广告数据分析实战!(附代码和100W数据源)
  17. 人工智能发展历程、机器学习分类、人工智能设计到的数学知识
  18. VLOOKUP函数的使用
  19. 基于C++的web服务器---总述篇
  20. python3爬虫有道翻译_【Python3爬虫】有道翻译

热门文章

  1. “make -n”和 “+command”的解释
  2. 几种添加系统环境变量方法和区别
  3. 数据脱敏的 6 种方案
  4. TCP/IP / UDP 头
  5. 启明云端WT32-CAM操作视频,让你快速上手ESP32camera应用
  6. android 自动补全方法,Android零基础入门|自动完成文本框AutoCompleteTextView
  7. centos7.2安装mysql5.7_Centos7.2下使用YUM快速安装MySQL5.7的方法
  8. 打开微型计算机的电源时,计算机操作与使用试题(有答案)
  9. mybatis-config.xml
  10. 数据库中DDL,DML,DCL