启动方式及故障排查

一、几个问题

1.1 /etc/init.d/mysql 从哪来

cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql

1.2 mysql能否设置成开机启动

可以,但是没必要

# 方法1:
chkconfig mysql on
# 方法2:
echo "/etc/init.d/mysql start" >> /etc/rc.local

1.3 开机启动?

有没有必要把MySQL设置为开机启动

如果线上库,建议关闭自动启动,线上库本着一个原则,出错了就停下来,用脚本批量启动

1.4 配置文件位置及加载顺序

mysqld可以加载哪些位置的配置文件

mysql global status | grep my.cnf
mysql --help | grep my.cnf
mysqld --verbose --help | grep my.cnf man mysqld
mysqld --verbose --help | grep defaults-file
--defaults-file=# Only read default options from the given file #. # my.cnf加载顺序:
# /etc/my.cnf /etc/mysql/my.cnf /usr/local/mysql/etc/my.cnf ~/.my.cnf

1.5 mysql的启动方式

# 1
/etc/init.d/mysql start
# 2(1与2都是调用的mysql.server)
service mysql start
# 3
/usr/local/mysql/bin/mysqld_safe --defaults-file=/etc/my.cnf &
# 4
/usr/local/mysql/bin/mysqld --defaults-file=/etc/my.cnf & # mysql.server调用的mysqld_safe
# mysqld_safe调用的mysqld (mysqld_safe是mysqld的守护进程,会自动重启) # 建议用如下启动方式,一机多实例启动也就简单了
# mysqld_safe启动,mysqld进程挂掉,会自动重启,不便于定位问题
/usr/local/mysql/bin/mysqld --defaults-file=/etc/my.cnf &
/usr/local/mysql/bin/mysqld --defaults-file=/data/mysql/mysql3376/my3376.cnf &
/usr/local/mysql/bin/mysqld --defaults-file=/data/mysql/mysql3377/my3377.cnf & # 关闭
/usr/local/mysql/bin/mysqladimn -S /tmp/mysql3376.sock shutdown

二、为什么推荐用mysqld启动

  1. mysqld_safe是mysqld的守护进程
  2. 一机多实例启动也就简单了
  3. mysqld_safe启动,mysqld进程挂掉,会自动重启,不便于定位问题

三、一机多实例

3.1 场景

  1. 防止两个业务之间影响,每个业务需要的资源不大,2、3G内存就够了

  2. MySQL随着连接数的上升性能会下降,通过拆分实例降低连接数

  3. 不同端口号跑不同的业务

    3376->userdb

    3377->cmsdb

3.2 技巧,减少误操作

一组MySQL用一个唯一端口号,所有的组之间不要重复

如:一组对应的一主两从

3.3 实现

1. 创建目录
mkdir -p /data/mysql/mysql3377/{data,tmp,logs} 2. 修改配置文件,端口
# cp /data/mysql/mysql3376/mysql3376.cnf /data/mysql/mysql3377/mysql3377.cnf
# cp /etc/my.cnf /data/mysql/mysql3377/mysql3377.cnf
# sed -i 's/3376/3377/g' /data/mysql/mysql3377/mysql3377.cnf
cp /etc/my.cnf /etc/mysql3377.cnf
sed -i 's/3376/3377/g' /etc/mysql3377.cnf 3. 修改权限
sudo chown -R mysql:mysql /data/mysql/mysql3377 4. 初始化,指定配置文件
cd /usr/local/mysql
# ./scripts/mysql_install_db --defaults-file=/data/mysql/mysql3377/mysql3377.cnf
sudo ./scripts/mysql_install_db --defaults-file=/etc/mysql3377.cnf 5. 通过mysqld启动
# mysqld --defaults-file=/data/mysql/mysql3377/mysql3377.cnf &
mysqld --defaults-file=/etc/mysql3377.cnf & 6. 安全加固
mysql -S /tmp/mysql3377.sock 7. 关闭
mysqladimn -S /tmp/mysql3377.sock shutdown # 可以写成脚本,只需要如下3个参数
port, bp size, appname
$appname$port

四、mysqld_multi

  1. mysqld_multi是用一个配置文件实现一机多实例
  2. mysqld_multi可以调用mysqld_safe,也可以调用mysqld
  3. 如果mysqld_multi,建议调用mysqld_safe
  4. my.cnf必须在/etc/my.cnf这个位置
  5. http://www.cnblogs.com/LCX/archive/2010/04/02/1703215.html

4.1 向my.cnf追加如下内容

必须是/etc/my.cnf这默认位置的配置文件

[mysqld_safe]的参数仅供mysqld_safe程序使用

[mysqldN]会覆盖[mysqld]的部分,前缀必须是mysqld

port/datadir/socket必须不能一样

[mysqld_multi]
mysqld = /usr/local/mysql/bin/mysqld_safe
mysqladmin = /usr/local/mysql/bin/mysqladmin
# 用来做关闭mysql使用
user = root
# password = 123456
log = /data/mysql/mysqld_multi.log [mysqld3378]
socket = /tmp/mysql3378.sock
port = 3378
datadir = /data/mysql/mysql3378/data
user = mysql
pid-file = /data/mysql/mysql3378/data/mysql3378.pid
log-error = /data/mysql/mysql3378/logs/error.log
log-bin = /data/mysql/mysql3378/logs/mysql-bin
innodb_data_home_dir = /data/mysql/mysql3378/data
innodb_log_group_home_dir = /data/mysql/mysql3378/logs [mysqld3379]
socket = /tmp/mysql3379.sock
port = 3379
datadir = /data/mysql/mysql3379/data
user = mysql
pid-file = /data/mysql/mysql3379/data/mysql3379.pid
log-error = /data/mysql/mysql3379/logs/error.log
log-bin = /data/mysql/mysql3379/logs/mysql-bin
innodb_data_home_dir = /data/mysql/mysql3379/data
innodb_log_group_home_dir = /data/mysql/mysql3379/logs

4.2 启动

# 查看MySQL状态
/usr/local/mysql/bin/mysqld_multi report # 前提是3378和3379的数据库文件已经初始化完了
cd /usr/local/mysql
./scripts/mysql_install_db --defaults-file=/etc/mysql3378.cnf
./scripts/mysql_install_db --defaults-file=/etc/mysql3379.cnf # 启动,不加参数是启动所有实例
/usr/local/mysql/bin/mysqld_multi start
# 只启动3376,通过端口号指定
/usr/local/mysql/bin/mysqld_multi start 3376 # 关闭,不加参数是关闭所有实例
mysqld_multi stop
mysqld_multi stop 3376
mysqladmin shutdown -S /tmp/mysql3376.sock

4.3 单机跑多实例

# 以下三个绝对不能一样
port
datadir
socket

server-id

五、打包初始化

/data/mysql/mysql3376
# 打包前,删除auto.cnf
rm -rf /data/mysql/mysql3376/auto.cnf
tar -czvf mysqldata.tar.gz /data/mysql/mysql3376

六、故障排查

6.1 看错误日志

# my.cnf定义错误日志的输出
log-error = /data/mysql/mysql3376/logs/error.log cat /data/mysql/mysql3376/logs/error.log

6.2 字典数据过大

# 数据字典文件
innodb_data_file_path=ibdata1:100M:autoextend # 不能改大,改小了可以

6.3 ibdata1非常大

ibdata1非常大怎么办?

很有可能是启用了共享表空间,改成独立表空间

共享表空间,就是把数据清理掉后,也不会回收空间

解决:

  1. dump出来
  2. 启用独立表空间导入

6.4 优化错误

[mysqld_safe]
malloc-lib = /usr/local/mysql/lib/mysql/libjemalloc.so

用/etc/init.d/mysql和mysqld_safe启,连错误日志都没有写

错误日志是由mysqld来写的,所以连mysqld都没有调用到

解决:

  1. 把缺少的文件找来编译放进去
  2. 把这句优化注释掉

6.5 启动mysql的用户

2017-11-18 12:52:04 4766 [ERROR] Fatal error: Please read "Security" section of the manual to find out how to run mysqld as root!

以mysql身份来启动mysql ------不是这个原因

# su - root -c "command"
mysqld --defaults-file=/data/mysql/mysql3377/mysql3377.cnf &
su - mysql -c "mysqld --defaults-file=/data/mysql/mysql3377/mysql3377.cnf &"

my.cnf不要让其他用户有w权限

6.6 设置error_log

error_log必须提前创建好

https://bugs.mysql.com/bug.php?id=84427

6.7 权限错误

/tmp目录权限不对

/tmp是个特殊目录,在日常操作中,该目录会被误操作

iptables

firewalld

selinux

getenforce

七、总结

7.1 问题来源:

目录权限问题

优化问题

7.2 解决思路:

看调用关系

看日志

7.3 要求

  1. 能按着要求布署一个数据库3378
  2. 了解几种启动方式的调用关系
  3. 了解配置文件加载的顺序
  4. 掌握启动故障的排查思路
  5. 多实例的布署

MySQL启动与多实例安装的更多相关文章

  1. MySQL多版本多实例安装启动

    多版本,大版本不同测试多实例,一个MySQL5.7.30一个MySQL8.0.20 解压8.0 tar -xvf mysql-8.0.20-linux-glibc2.12-x86_64.tar tar ...

  2. MySQL 5.7 多实例安装部署实例

    1. 背景  MySQL数据库的集中化运维,可以通过在一台服务器上,部署运行多个MySQL服务进程,通过不同的socket监听不同的服务端口来提供各自的服务.各个实例之间是相互独立的,每个实例的dat ...

  3. mysql一机多实例安装记录

    因为想研究mycat,所以需要安装多个mysql实例进行研究.限于没有多于计算机,只能在本机安装了.通过mysql文档,自己琢磨着安装成功! 目录结构如下: 其中one和two文件夹用来模拟数据库分库 ...

  4. MySQL单机上多实例安装

    首先安装mysql,不要启动MySQL,先配置vim /etc/my.cnf.[mysqld_multi]mysqld = /usr/bin/mysqld_safemysqladmin = /usr/ ...

  5. mysql5.7二进制包进行多实例安装

    一.需求 在一台服务器上安装mysql5.7,并且部署两个实例:3306用于本机主库,3307用于其他MYSQL服务器的从库 二.下载mysql二进制包 [root@push-- src]# -lin ...

  6. MySQL多实例安装、配置、启动(四)

    一.规划信息 系统信息: cat /etc/redhat-release CentOS Linux release (Core) # uname -r -.el7.x86_64 数据库规划 PORT: ...

  7. MySQL多实例安装

    1.安装MySQL需要的依赖的包和编译软件   (1)安装MySQL需要的依赖包 安装MySQL之前,最好先安装MySQL需要的依赖包,不然后面会出现报错,还得回来安装MySQL的依赖包. [root ...

  8. Mysql多实例 安装以及配置

    MySQL多实例 1.什么是MySQL多实例 简单地说,Mysql多实例就是在一台服务器上同时开启多个不同的服务端口(3306.3307),同时运行多个Mysql服务进程,这些服务进程通过不同的soc ...

  9. Windows下MySQL多实例安装/主从复制/重置密码

    Windows创建MySQL多实例 安装MYSQL和实例1 运行mysql-installer-community-5.7.16.0.msi 选择组件 MySQL Server 5.7.16 – X6 ...

随机推荐

  1. Ubuntu 18.04 磁盘根目录在线扩容 & 修改分区 inode 数量

    Ubuntu 18.04 磁盘根目录在线扩容 & 修改分区 inode 数量   Ubuntu 作为服务器系统使用的时候,系统盘的空间可能并不是很充裕,apt apt 着,根目录就满了.诚然, ...

  2. matlab中fmincon函数求解非线性规划问题

    Matlab求解非线性规划,fmincon函数的用法总结 1.简介 在matlab中,fmincon函数可以求解带约束的非线性多变量函数(Constrained nonlinear multivari ...

  3. C# Tutorial for Frontend Developer

    1.Basic Hello World Console output -> console.log Console.WriteLine("Hello World!"); Va ...

  4. 五分钟搭建博客系统 OK?

    前言: 请各大网友尊重本人原创知识分享,谨记本人博客:南国以南i 概要: 通过 Docker Compose 在使用Docker容器构建的隔离环境中轻松运行 WordPress.在开始之前,请确保已安 ...

  5. 【面试普通人VS高手系列】CPU飙高系统反应慢怎么排查?

    面试过程中,场景类的问题更容易检测出一个开发人员的基本能力. 这不,一个小伙伴去阿里面试,第一面就遇到了关于"CPU飙高系统反应慢怎么排查"的问题? 对于这个问题,我们来看看普通人 ...

  6. HCIE-SEC笔记-第四节-网络入侵和防火墙基础

    等级保护: 网络安全:防火墙.VPN.准入控制 渗透测试: 防火墙:区域隔离和访问控制 数字与研究公司:用数据说话 IDC:国际数据公司 Gartner:著名的数字与咨询公司 弗雷斯特: 数世咨询: ...

  7. Junit单元测试:

    * 测试分类: 1. 黑盒测试:不需要写代码,给输入值,看程序是否能够输出期望的值. 2. 白盒测试:需要写代码的.关注程序具体的执行流程. * Junit使用:白盒测试 * 步骤: 1. 定义一个测 ...

  8. 2021.08.09 P6225 抑或橙子(树状数组)

    2021.08.09 P6225 抑或橙子(树状数组) 重点: 1.异或用法 题意: Janez 喜欢橙子!他制造了一个橙子扫描仪,但是这个扫描仪对于扫描的每个橙子的图像只能输出一个 3232 位整数 ...

  9. 小米路由器3G R3G 刷入Breed和OpenWrt 20.02.2 的记录

    小米 R3G 参数 Architecture: MIPS Vendor: Mediatek Bootloader: U-Boot System-On-Chip: MT7621 family CPU/S ...

  10. nodejs mysql pool 只能插入10条记录或者较少记录

    BEGIN; 解决方案:从连接池获取到的Connection,执行完操作后,必须及时关闭! 即:connection.end(); 使用后发现console有打印出警告信息,大致意思为 end() 方 ...