43. Systemd的Unit配置详解,unit文件位置,优先级,unit类型,unit文件字段详解,Unit/Service/Install字段,添加mysql服务等例子

Systemd的Unit配置详解,unit文件位置和优先级,unit文件类型,unit文件字段详解,[Unit]字段,[Service]字段,[Install]字段,添加服务,创建.service 文件,配置文件,加载启动服务。

文章目录

  • unit
    • 概念
    • unit文件位置和优先级
    • unit文件类型
  • unit文件字段详解
    • [Unit]字段详解
    • [Service]字段详解
    • [Install]字段详解
  • 例:添加ohas服务
    • 创建.service 文件
    • 配置文件
    • 加载,启动服务
  • 例:添加mysql服务
    • 创建service文件
    • 启动加载服务
    • 查看服务状态
  • 总结
  • 友情链接


unit

概念

  • unit(单元|服务等)
    Systemd 可以管理所有系统资源,将每个系统资源称为一个 Unit。Unit 是 Systemd 管理系统资源的基本单位,使用一个 Unit File 作为 Unit 的单元文件,Systemd 通过单元文件控制 Unit 的启动.
    例如,Httpd服务被 Systemd 视为一个 Unit,使用一个 httpd.service 作为启动配置文件

  • Unit File(单元文件|配置文件)
    单元文件中包含该单元的描述、属性、启动命令等

unit文件位置和优先级

路径 说明 优先级
/etc/systemd/system 系统或用户提供的配置文件
/run/systemd/system 软件运行时生成的配置文件
/usr/lib/systemd/system 系统或第三方软件安装时添加的配置文件
注意: 当这几个目录中有同名文件时,会使用优先级最高目录的文件。

通常我们是在/etc/systemd/system/ 目录下进行新增文件。

[root@shuge ~]# ls /etc/systemd/system/
basic.target.wants/                         default.target.wants/                       network-online.target.wants/
dbus-org.fedoraproject.FirewallD1.service   getty.target.wants/                         sysinit.target.wants/
dbus-org.freedesktop.nm-dispatcher.service  local-fs.target.wants/                      system-update.target.wants/
default.target                              multi-user.target.wants/                    vmtoolsd.service.requires/

unit文件类型

Systemd 将系统资源划分为12类,对应12种类型的单元文件

系统资源类型 单元文件扩展名 单元文件描述
Service .service 最常见Unit 文件类型,封装守护进程的启动、停止、重启和重载操作,也就是一直讲的服务
Target .target 定义 target 信息及依赖关系,一般仅包含 Unit 段
Device .device 对于 /dev 目录下的硬件设备,主要用于定义设备之间的依赖关系
Mount .mount 定义文件系统的挂载点,可以替代过去的 /etc/fstab 配置文件
Automount .automount 用于控制自动挂载文件系统,相当于 SysV-init 的 autofs 服务
Path .path 用于监控指定目录或文件的变化,并触发其它 Unit 运行
Scope .scope 这种 Unit 文件不是用户创建的,而是 Systemd 运行时产生的,描述一些系统服务的分组信息
Slice .slice 用于表示一个 CGroup 的树
Snapshot .snapshot 用于表示一个由 systemctl snapshot 命令创建的 Systemd Units 运行状态快照,可以切回某个快照
Socket .socket 监控来自于系统或网络的数据消息
Swap .swap 定义一个用户做虚拟内存的交换分区
Timer .timer 用于配置在特定时间触发的任务,替代了 Crontab 的功能
注意:
  • 如果缺省扩展名,则默认.service扩展名
  • 执行target相关命令,则默认生成.target扩展名

unit文件字段详解

sshd.service文件的输出内容输出如下,可以看到分为三个部分[Unit],[Service],[Install]。

[root@shuge system]# cat sshd.service
[Unit]
Description=OpenSSH server daemon
Documentation=man:sshd(8) man:sshd_config(5)
After=network.target sshd-keygen.service
Wants=sshd-keygen.service

[Service]
Type=notify
EnvironmentFile=/etc/sysconfig/sshd
ExecStart=/usr/sbin/sshd -D $OPTIONS
ExecReload=/bin/kill -HUP $MAINPID
KillMode=process
Restart=on-failure
RestartSec=42s

[Install]
WantedBy=multi-user.target

[Unit]字段详解

该部分主要对服务进行说明。

  • Description
    描述信息,自定义即可。

  • Documentation
    介绍这个服务的文档的地址,可以是url,也可以是其他地址。

  • Requires
    依赖的其他 Unit 列表,列在其中的 Unit 模块会在这个服务启动的同时被启动,并且如果其中有任意一个服务启动失败,这个服务也会被终止。

  • Wants
    与 Requires 相似,但只是在被配置的这个 Unit 启动时,触发启动列出的每个 Unit 模块,而不去考虑这些模块启动是否成功。

  • After
    与 Requires 相似,但会在后面列出的所有模块全部启动完成以后,才会启动当前的服务。

  • Before
    与 After 相反,在启动指定的任一个模块之前,都会首先确保当前服务已经运行。

  • BindsTo
    与 Requires 相似,但是一种更强的关联。启动这个服务时会同时启动列出的所有模块,当有模块启动失败时终止当前服务。反之,只要列出的模块全部启动以后,也会自动启动当前服务。并且这些模块中有任意一个出现意外结束或重启,这个服务会跟着终止或重启。

  • PartOf
    这是一个 BindTo 作用的子集,仅在列出的任何模块失败或重启时,终止或重启当前服务,而不会随列出模块的启动而启动。

  • OnFailure
    当这个模块启动失败时,就自动启动列出的每个模块。

  • Conflicts
    与这个模块有冲突的模块,如果列出模块中有已经在运行的,这个服务就不能启动,反之亦然。

[Service]字段详解

这部分内容是仅针对 “.service” 文件,在配置服务的时候,这部分内容是最重要的。

  • Type
    Type=simple:默认值,ExecStart字段启动的进程为主进程,服务进程不会 fork,如果该服务要启动其他服务,不要使用此类型启动。
    Type=forking:ExecStart字段将以fork()方式从父进程创建子进程启动,创建后父进程会立即退出,子进程成为主进程。通常需要指定PIDFile字段,以便 Systemd 能够跟踪服务的主进程
    对于常规的守护进程(daemon),除非你确定此启动方式无法满足需求,使用此类型启动即可
    Type=oneshot:只执行一次,Systemd 会等当前服务退出,再继续往下执行。适用于只执行一项任务、随后立即退出的服务。通常需要指定RemainAfterExit=yes字段,使得 Systemd 在服务进程退出之后仍然认为服务处于激活状态
    Type=dbus:当前服务通过 D-Bus 信号启动。当指定的 BusName 出现在 DBus 系统总线上时,Systemd认为服务就绪
    Type=notify:当前服务启动完毕会发出通知信号,通知 Systemd,然后 Systemd 再启动其他服务
    Type=idle:Systemd 会等到其他任务都执行完,才会启动该服务。

  • RemainAfterExit
    当前服务的所有进程都退出的时候,Systemd 仍认为该服务是激活状态。这个配置主要是提供给一些并非常驻内存,而是启动注册后立即退出,然后等待消息按需启动的特殊类型服务使用的

  • ExecStart
    启动当前服务的命令

ExecStart=/bin/echo execstart1
ExecStart=
ExecStart=/bin/echo execstart2
  • ExecStartPre
    启动当前服务之前执行的命令

  • ExecStartPost
    启动当前服务之后执行的命令。

  • TimeoutStartSec
    定义 Systemd 停止当前服务之前等待的秒数。

  • ExecStop
    停止当前服务时执行的命令

  • ExecStopPost
    停止当前服务之后执行的命令

  • KillMode:定义 Systemd 如何停止服务,可能的值包括:
    control-group(默认值):当前控制组里面的所有子进程,都会被杀掉
    process:只杀主进程(sshd 服务,推荐值)
    mixed:主进程将收到 SIGTERM 信号,子进程收到 SIGKILL 信号
    none:没有进程会被杀掉,只是执行服务的 stop 命令。

  • TimeoutStopSec
    停止服务时的等待的秒数,如果超过这个时间服务仍然没有停止,systemd 会使用 SIGKILL 信号强行杀死服务的进程。

  • Restart
    no(默认值):退出后不会重启
    on-success:只有正常退出时(退出状态码为0),才会重启
    on-failure:非正常退出时(退出状态码非0),包括被信号终止和超时,才会重启(守护进程,推荐值)
    on-abnormal:只有被信号终止和超时,才会重启(对于允许发生错误退出的服务,推荐值)
    on-abort:只有在收到没有捕捉到的信号终止时,才会重启
    on-watchdog:超时退出,才会重启
    always:不管是什么退出原因,总是重启

  • PIDFile:指向当前服务 PID file 的绝对路径。

  • RestartSec
    Systemd 重启当前服务间隔的秒数

  • ExecReload
    重启当前服务时执行的命令

  • Environment
    为服务添加环境变量,如前面的第一个例子中所示。

  • EnvironmentFile
    指定加载一个包含服务所需的环境变量列表的文件,文件中的每一行都是一个环境变量的定义。

  • Nice
    服务的进程优先级,值越小优先级越高,默认为0。-20为最高优先级,19为最低优先级。

  • WorkingDirectory
    指定服务的工作目录。

  • RootDirectory
    指定服务进程的根目录( / 目录),如果配置了这个参数后,服务将无法访问指定目录以外的任何文件。

  • User
    指定运行服务的用户

  • Group
    指定运行服务的用户组

  • EnvironmentFile:指定当前服务的环境参数文件。该文件内部的key=value键值对,可以用$key的形式,在当前配置文件中获取

  • LimitCPU / LimitSTACK / LimitNOFILE / LimitNPROC 等
    限制特定服务可用的系统资源量,例如 CPU,程序堆栈,文件句柄数量,子进程数量

[Install]字段详解

这个段中的配置与 Unit 有几分相似,但是这部分配置需要通过 systemctl enable 命令来激活,并且可以通过 systemctl disable 命令禁用。另外这部分配置的目标模块通常是特定启动级别的 .target 文件,用来使得服务在系统启动时自动运行。

  • WantedBy
    和[Unit]中的 Wants 作用相似,列出的是依赖当前服务的模块。它的值是一个或多个 target,执行enable命令时,符号链接会放入/etc/systemd/system目录下以 target 名 + .wants后缀构成的子目录中。
最常见的用法:WantedBy=multi-user.target,表明当系统以多用户方式(默认的运行级别)启动时,这个服务需要被自动运行。
  • RequiredBy
    和[Unit]的 Requires 作用相似,依赖当前服务的模块。它的值是一个或多个 target,执行enable命令时,符号链接会放入/etc/systemd/system目录下以 target 名 + .required后缀构成的子目录中

  • Alias:当前 Unit 可用于启动的别名

  • Also
    当这个服务被 enable/disable 时,将自动 enable/disable 后面列出的每个模块。

例:添加ohas服务

在centos/rhel 7当中在安装rac的时候,需要手工创建一个服务文件,我们就以这个案例进行讲解。

创建.service 文件

touch /usr/lib/systemd/system/ohasd.service  
chmod 777 /usr/lib/systemd/system/ohasd.service

配置文件

 vi /usr/lib/systemd/system/ohasd.service
[Unit]
Description=Oracle High Availability Services  //描述信息
After=syslog.target  //启动这个服务后,再启动当前配置的服务

[Service]
ExecStart=/etc/init.d/init.ohasd run >/dev/null 2>&1  // 执行的命令
Type=simple			//默认
Restart=always		// 无论何种原因退出,都重启这个服务

[Install]
WantedBy=multi-user.target   // 对应当前操作系统的启动级别,表明当系统以多用户方式(默认的运行级别)启动时,这个服务需要被自动运行。

加载,启动服务

  • 重新加载守护进程
systemctl daemon-reload
  • 设置守护进程自动启动
systemctl enable ohasd.service
  • 手工启动ohasd服务
systemctl start ohasd.service

例:添加mysql服务

创建service文件

[root@mdns ~]# touch /usr/lib/systemd/system/mysql.service
[root@mdns ~]# chmod 777 /usr/lib/systemd/system/mysql.service 
[root@mdns ~]# vi /usr/lib/systemd/system/mysql.service 
[root@mdns support-files]# cat /usr/lib/systemd/system/mysql.service 
[Unit]
Description=MySQL Server
After=network.target
SourcePath=/etc/init.d/mysqld
 
[Install]
WantedBy=multi-user.target
 
[Service]
Type=forking
TimeoutSec=0
PermissionsStartOnly=true
ExecStart=/etc/init.d/mysqld start
ExecStop=/etc/init.d/mysqld sop
LimitNOFILE = 65535
Restart=on-failure
RestartSec=3
RestartPreventExitStatus=1
PrivateTmp=false

启动加载服务

[root@mdns ~]# systemctl daemon-reload
[root@mdns ~]# systemctl enable mysql.service
[root@mdns support-files]# systemctl start mysql.service

查看服务状态

[root@mdns support-files]# systemctl status mysql.service
● mysql.service - MySQL Server
   Loaded: loaded (/etc/init.d/mysqld; enabled; vendor preset: disabled)
   Active: active (running) since Wed 2022-01-05 22:08:54 CST; 6s ago
  Process: 3095 ExecStart=/etc/init.d/mysqld start (code=exited, status=0/SUCCESS)
 Main PID: 3103 (mysqld_safe)
   CGroup: /system.slice/mysql.service
           ├─3103 /bin/sh /usr/local/mysql/bin/mysqld_safe --datadir=/data/mysql --pid-file=/data/my...
           └─3255 /usr/local/mysql/bin/mysqld --basedir=/usr/local/mysql --datadir=/data/mysql --plu...

Jan 05 22:08:53 mdns.zaishu.cn systemd[1]: Starting MySQL Server...
Jan 05 22:08:54 mdns.zaishu.cn mysqld[3095]: Starting MySQL. SUCCESS!
Jan 05 22:08:54 mdns.zaishu.cn systemd[1]: Started MySQL Server.

总结

Systemd的Unit配置详解,unit文件位置和优先级,unit文件类型,unit文件字段详解,[Unit]字段,[Service]字段,[Install]字段,添加服务,创建.service 文件,配置文件,加载启动服务。

友情链接

MySQL性能优化_原理_实战

1、MySQL在金融互联网行业的企业级安装部署

目录 章节
版本说明 版本说明
安装MySQL规范 1 安装方式
2 安装用户
3 目录规范
MySQL 5.7 安装部署 1 操作系统配置
2 创建用户
3 创建目录
4 安装
5 配置文件
6 安装依赖包
7 配置环境变量
8 初始化数据库
9 重置密码
MySQL8 安装 MySQL8 安装
源码安装 1 安装依赖包
2 生成源码包
3 创建用户
4 编译安装
5 配置数据库
6 连接mysql
多实例部署及注意事项 1 多实例概念
2 多实例安装
3 mysqld_multi(多实例第二种安装方式)

2、mysql启动关闭原理和实战_及常见错误排查

目录 章节
生产中MySQL启动方式 1、 启动原理
2、参数文件默认位置及优先级
3、 以server方式启动
4、 mysqld_safe方式
5、 mysqld 方式
6、 systemctl 方式
关库 1、相关参数innodb_fast_shutdown
2、相关参数innodb_force_recovery
3、关闭mysql多种方式
常见MySQL启动失败案例 1.、目录权限
2、参数问题
3、配置文件
4、端口占用
5、误删二进制文件
6、undo表空间异常
7、binlog缓冲异常
MySQL启动失败排查方法 MySQL启动失败排查方法
连接MySQL数据库的方式 连接MySQL数据库的方式
MySQL数据库用户安全策略 1、初始化数据库
2、修改密码
3、删除无用的用户
4、mysql_secure_installation
找回丢失的用户密码 找回丢失的用户密码

3、MySQL字符集和校对规则

目录 章节
MySQL字符集和校验规则 MySQL字符集和校验规则
查看字符集方法 1、查看mysql支持的字符集
2、查看字符集的校对规则
3、查看当前数据库的字符集
4、查看当前数据库的校对规则
MySQL字符集设置 1、字符集设置层级关系
2、设置MySQL服务器级别字符集
3、设置创建对象的字符集
字符集案例 1、常用字符集每个汉字占用字节多少
2、大小案例
插入中文乱码解决 插入中文乱码解决
数据库常见字符集及如何选择字符集 数据库常见字符集及如何选择字符集
生产中如何彻底避免出现乱码 生产中如何彻底避免出现乱码

4、史上最详细的Mysql用户权原理和实战_生产案例

目录 章节
访问控制 1、连接验证(阶段一)
2、允许的连接
3、连接优先级
4、请求验证(阶段二)
用户管理 1、新增用户
2、修改用户
3、删除用户
4、查看用户
密码管理 1、密码修改
2、密码过期设置
3、set password
4、密码过期策略
5、密码插件
MySQL用户权限管理 1、权限粒度
2、显示账户权限
3、显示账户非权限属性
4、库级权限
5、表级权限
6、列级权限
7、权限回收
资源限制 1、用户创建指定配额
2、修改配额
MySQL用户权限案例 1、断掉已清理的用户
2、忘记密码
3、如何禁止一个ip段的某个用户登录
4、创建开发账号
5、创建复制账号
6、创建管理员账号

5、InnoDB引擎原理和实战_通俗易懂

目录 章节
缓冲池 1、默认引擎
2、设置缓冲池大小
3、优化缓冲池
4、管理缓冲池
5、数据页类型
线程 1、IO线程
2、主线程
index page index page
insert buffer page insert buffer page
重做日志 重做日志
回滚日志 回滚日志
checkpoint,刷写脏页check point checkpoint
关键特性 1、插入缓冲
2、数据写入可靠性提升技术-doublewrite
3、自适应哈希索引-AHI
innodb预读预写技术 预读写

6、MySQL文件详解_物理结构_逻辑结构_原理和案例

目录 章节
参数和配置文件 1、文件位置
2、查找参数
3、参数类型
4、参数修改
5、示例一
6、示例二
7、注意事项
错误日志文件 错误日志
通用日志 通用日志
慢查询日志 慢日志
binlog 1、记录什么
2、用途
3、开启和参数配置
4、日志查看
5、日志刷新
6、删除日志
7、日志分析(mysqlbinlog)
8、利用二进制日志文件恢复误删的表
InnoDB存储引擎表空间文件 表空间文件
主从同步相关文件 主从同步文件
套接字文件 套接字文件
pid 文件 pid 文件
redo log 1、redo初识
2、日志组
3、与oracle redo的区别
4、相关参数
5、和binlog的区别
6、redo 缓冲区(innodb_flush_log_at_trx_commit)
InnoDB存储引擎逻辑结构 1、表空间
2、段
3、区
4、页
表碎片清理 1、判断是否有碎片
2、整理碎片
表空间文件迁移 1、需求
2、操作

7、SQL编程开发与优化事项

目录 章节
常用语句 1、导入数据
2、库操作
3、表操作
4、数据操作
5、use性能影响
6、delete、truncate、drop的区别
7、SQL语句分类
数据类型与性能 1、整型
2、浮点型
3、字符串类型
4、日期类型
MySQL约束 1、unsigned/signed
2、not null
3、count(*) 为什么慢
4、default
5、unique
6、 auto_increment
7、primary key
SQL编程高级 1、查询Syntax
2、查询列
3、where子句
4、group by … having子句
5、order by子句
6、limit子句(分页)
7、聚合函数
8、合并查询
9、多表查询
10、子查询
表的元数据库管理 1、统计应用库哪些表没有使用innodb存储引擎
2、如何查看表中是否有大对象
3、统计数据库大小
4、统计表的大小

8、MySQL索引原理和案例

目录 章节
MySQL索引与二分查找法 1、什么是索引
2、索引的优缺点
3、索引的最大长度
4、二分查找法:折半查找法
5、mysql一张表存多少数据后,索引性能就会下降?
剖析b+tree数据结构 1、B和B+树的区别
2、索引树高度
3、非叶子节点
4、指针
5、叶子节点
6、双向指针
7、b+tree插入操作
8、b+tree删除操作
相辅相成的聚集索引和辅助索引 1、聚集索引
2、聚集索引特点
3、聚集索引的优势
4、辅助索引
覆盖索引与回表查询 1、回表查询
2、覆盖索引
创建高性能的主键索引 1、主键索引创建的原则
2、主键索引的特点
3、为什么建议使用自增列作为主键
唯一索引与普通索引的性能差距 1、唯一索引特点
2、普通索引特点
3、唯一索引与普通索引的性能差距
前缀索引带来的性能影响 1、作用
2、坏处
如何使用联合索引 1、什么是联合索引
2、创建原则
3、排序
Online DDL影响数据库的性能和并发 1、5.6版本之前
2、新版本
3、online ddl语法
4、相关参数
5、示例
6、影响
pt-ocs原理与应用 1、安装pt-osc
2、pt-osc语法
3、案例
4、pt-osc原理
生产中索引的管理 1、建表时创建索引
2、建表后创建索引
3、查看索引
SQL语句无法使用索引的情况 1、where条件
2、联合索引
3、联表查询
4、其他情况

9、information_schema和sys中性能查看

目录 章节
最常用的STATISTICS和TABLES 1、STATISTICS:用于存放索引的信息
2、TABLES:用于存放库表的元数据信息
判断索引创建是否合理 1、选择性
2、索引创建的建议
检查联合索引创建是否合理 1、联合索引创建是否合理
2、有了联合索引(a,b),还需要单独创建a索引吗?
如何查找冗余索引 查找冗余索引
查找产生额外排序的sql语句 额外排序的sql语句
查找产生临时表的sql语句 临时表的sql语句
全表扫描的sql语句 全表扫描的sql语句
统计无用的索引 无用的索引
索引统计信息 1、存储索引统计信息
2、如何查看索引统计信息

10、MySQL优化器算法与执行计划

目录 章节
简单嵌套查询算法-simple nested-loop join simple nested-loop join
基于索引的嵌套查询算法-index nested-loop join index nested-loop join
基于块的嵌套查询算法- block nested-loop join block nested-loop join
Multi-Range Read MRR
bached key access join BKA
mysql三层体系结构 体系结构
Index Condition Pushdown 索引条件下推
一条查询SQL语句是怎样运行的 查询SQL语句
一条更新SQL语句是怎样运行的 更新SQL语句
MySQL长连接与短连接的选择 1、相关参数
2、断开连接
执行计划explain 1、语法
2、执行计划解析

11、MySQL查询优化

目录 章节
MySQL查询优化技术 概览
子查询优化 1、优化器自动优化
2、优化措施:子查询合并
3、优化措施:子查询上拉技术
外连接消除 外连接消除
生产环境不使用join联表查询 不使用join
group by分组优化 1、group by执行流程
2、为什么group by要创建临时表
order by排序优化 排序优化
MySQL性能抖动问题 性能抖动问题
count(*)优化 count(*)优化
磁盘性能基准测试 1、安装sysbench
2、生成文件
3、测试文件io
4、清除文件
MySQL基准测试 1、生成数据
2、测试(读)
3、测试(写)
4、清理数据

12、事务原理和实战

目录 章节
认识事务 认识事务
事务控制语句 1、开启事务
2、事务提交
3、事务回滚
事务的实现方式 1、原子性
2、一致性
3、隔离性
4、持久性
purge thread线程 purge thread线程
事务统计QPS与TPS 1、QPS
2、TPS
事务隔离级别 1、隔离级别
2、查看隔离级别
3、设置隔离级别
4、不同隔离级别下会产生什么隔离效果
事务组提交group commit 组提交
事务两阶段提交 两阶段提交
MVCC多版本并发控制 1、MVCC原理
2、MVCC案例

13、锁的原理和应用

目录 章节
认识锁 1、锁的作用
2、加锁的过程
3、锁对象:事务
innodb行锁 1、行锁类型
2、共享锁(S锁)
3、排他锁(X锁)
索引对行锁粒度的影响 1、行锁粒度有哪些
2、在RC隔离级别下不同索引产生的锁的范围
3、RR隔离级别下不同索引产生锁的范围
FTWRL全局读锁 FTWRL全局读锁
innodb表锁 innodb表锁
innodb意向锁与MDL锁 1、意向锁
2、意向锁作用
3、意向锁冲突情况
4、MDL锁
自增锁 自增锁
插入意向锁 插入意向锁
死锁 1、什么是死锁
2、相关参数
3、避免死锁
4、锁的状态
两阶段锁协议 两阶段锁协议

14、慢查询原理和实战_快速优化方法_优化工具

目录 章节
1. 系统状态 show status
2. 慢查询 2.1 慢查询开启
2.2 简单示例
2.3 数据准备
3. mysqldumpslow 3.1 语法
3.2 常见用法
4. pt-query-digest 4.1 安装
4.2 语法选项
4.3 报告解读
4.4 用法示例
5. 优化工具(soar) 5.1 安装配置
5.2 添加数据库
5.3 语句优化

15、备份恢复原理和实战_逻辑备份_物理备份_金融行业备份还原脚本

目录 章节
1.生产中备份方式 1.1 物理备份与逻辑备份
1.2 联机与脱机备份
1.3 完整备份与增量备份
1.4 常用命令
2.mysqldump备份 2.1 相关参数
2.2 备份所有数据库
2.3 备份指定数据库
2.4 备份指定表
2.6 只导出结构
2.7 只导出数据
2.8 --tab(生成文本,类似load)
2.8 mysqldump原理
2.9 binlog异步备份
2.10 利用mysqldump全备及binlog恢复数据
3.xtrabackup 3.1 Xtrabackup安装
3.2 原理
3.2 备份过程
3.4 恢复原理
3.3 相关参数
3.4 xtrabackup相关文件
3.5 备份示例
3.6 还原示例
4.binlog备份和恢复(数据库恢复) 4.1 找到恢复时间点
4.2 增量恢复
5. 生产环境的备份恢复实战 5.1 实施部署
5.1.1 环境清单
5.1.2 备份目的
5.1.3 备份说明
5.1.4 实施步骤
5.1.5 全备脚本
5.1.6 差异备份脚本
5.2 实施部署备份还原
5.2.1 Xtraback还原全量/差异备份
5.2.2 故障点数据恢复
5.2.3 增量恢复

16、主从复制,gtid,并行复制_半同步复制_实操案例_常用命令_故障处理

目录 章节
1.认识主从复制 1.1 主从复制原理深入讲解
1.2 主从复制相关参数
1.3.主从复制架构部署
1.4从库状态详解
1.5 .过滤复制
2 .gtid复制 2.1 什么是GTID?
2.2 GTID主从配置
2.5 gtid维护
2.4 GTID的特点
2.3 工作原理
2.4 gtid相关状态行和变量
3. 并行复制 3.1 延迟的原因
3.2 并行复制设置
3.3 查看并行复制
4. 增强半同步复制 4.1 异步复制
4.2 半同步复制
4.3 增强半同步复制
4.4 配置增强半同步
5. 案例 5.1 主库删除操作导致sql线程关闭案例
5.2 主从复制中断解决方案及案例
5.3 延迟复制
5.4 主库drop误操作利用延迟复制恢复案例
6 常用命令 6.1 启动线程
6.2 关闭线程
6.3 查看
6.4 重置
6.5 主从数据一致性校验

17、MySQL高可用和读写分离架构
MHA

目录 章节
MHA 介绍
架构和相关组件 架构和相关组件
工作流程 工作流程
MHA高可用架构部署 1、环境准备
2、软件安装
3、创建软链接
4、配置各节点互信
5、节点免密验证
6、mha管理用户
7、配置文件
8、状态检查
9、开启MHA
主库宕机故障模拟及处理 主库宕机故障模拟及处理
MHA VIP自动切换 VIP自动切换
MHA主从数据自动补足 MHA主从数据自动补足

Atlas

目录 章节
Atlas读写分离高性能架构 介绍
安装配置 安装配置
配置注解 配置注解
启动和关闭 启动和关闭
读写分离架构应用 读写分离架构应用
创建应用用户 创建应用用户
Atlas在线管理 Atlas在线管理
读写分离避坑指南 读写分离避坑指南

18、MySQL分库分表_原理实战

目录 章节
1.MyCAT分布式架构入门及双主架构 1.1 主从架构
1.2 MyCAT安装
1.3 启动和连接
1.4 配置文件介绍
2.MyCAT读写分离架构 2.1 架构说明
2.2 创建用户
2.3 schema.xml
2.4 连接说明
2.5 读写测试
2.6 当前是单节点
3.MyCAT高可用读写分离架构 3.1 架构说明
3.3 schema.xml(配置)
3.4 文件详解
3.4.1 schema标签
3.4.2 table标签
3.4.3 dataNode标签
3.4.4 dataHost
3.4 读写测试
3.5 故障转移
4.MyCAT垂直分表 4.1 架构
4.2 新建表
4.3 配置mycat
4.4 验证
5 MyCAT水平分表-范围分片 5.1 新建表
5.2 schema.xml
5.2 rule.xml
5.3 autopartition-long.txt
5.4 验证
6. MyCAT水平分表-取模分片 取模分片
7. MyCAT水平分表-枚举分片 枚举分片
8. MyCAT全局表与ER表 全局与ER表
8.1 全局表 8.1.1 特性
8.1.2 建表
8.1.3 配置
8.1.4 验证
8.1.5 分析总结(执行计划)
8.2 ER表 8.2.1 特性
8.2.2 建表
8.2.3 配置
8.2.4 测试验证,子表是否跟随父表记录分片
8.2.5 分析总结(执行计划)

19、基准性能测试_sysbench

目录 章节
1. sysbench 1.1 用途
1.2 安装
1.3 版本
1.4 查看帮助
1.5 测试过程阶段
2 CPU 性能测试 2.1 测试原理
2.2 查看帮助
2.3 测试
3. 内存性能测试 3.1 查看帮助信息
3.2 测试过程
4.磁盘性能基准测试 4.1 查看帮助
4.2 生成文件(prepare)
4.3 测试文件io(run)
4.4 结果分析
4.5 清除文件(cleanup)
5. 线程测试 5.1 查看帮助信息
5.2 测试过程
6. MySQL基准测试 6.1 语法参数
6.2 生成数据
6.3 测试(读)
6.4 测试(写)
6.5 清理数据

你可能感兴趣的:(bash,linux,unit,systemctl,mysql)