Mysql的日志管理,备份与回复

news2024/11/14 6:22:32

目录

一、Mysql日志管理

1、日志的默认位置及配置文件

2、日志分类

2.1错误日志

2.2通用查询日志

2.3二进制日志

2.4慢查询日志

2.5中继日志

3、日志配置

4、日志查询

4.1查询通用日志是否开启

4.2查询二进制日志是否开启

4.3查看慢查询日志是否开启

4.4查询慢查询日志超时时间

二、数据备份

1、数据备份的概念

2、数据备份的必要性

2.1数据丢失的原因:

3、数据备份的类型

3.1数据库备份从物理与逻辑的角度分类可以分为物理备份和逻辑备份

3.1.1物理备份

3.1.2、逻辑备份

3.2.1完全备份:

3.2.2差异备份:

3.2.3增量备份:

4、备份方法

4.1物理冷备份

4.2专用备份工具mysqldump或mysqlhotcopy

4.3通过二进制日志进行增量备份

4.4通过第三方工具备份

三、Mysql完全备份

1、完全备份的优缺点:

2、数据库完全备份的分类

2.1物理冷备份与恢复

2.2mysqldump备份与恢复

四、Mysql完全备份与恢复

1、物理冷备份与恢复

2、mysqldump完全备份与恢复(温备份)

2.1完全备份一个或多个完整的库(包括其中所有的表)

2.2完全备份mysql服务器中所有的库

2.3完全别分指定库中的部分表

2.4查看备份文件

3、恢复数据库

3.1方法一:source恢复

3.2方法二:mysql恢复

4、恢复表(依据上面的备份表来进行)

4.1方法一:source恢复

4.2方法二:mysql恢复

5、注意:

①当备份时加--databases,表示针对kgc库

②当备份时不加--databases时,表示针对kgc库下的所有表

③在实际生产环境中,可以使用shell脚本来实现自动定时备份。

五、Mysql增量备份与恢复

1、恢复的方式

1.1一般恢复

1.2基于位置恢复

1.3基于时间恢复

2、二进制文件介绍

2.1、开启二进制日志功能

2.2二进制日志的三种不同的记录格式

①statement(基于SQL语句)

②row(基于行)

③mixed(推荐使用)

2.3查看二进制日志文件的内容

2.4二进制日志中需要关注的部分

3、增量备份过程(全备+增备)

4、增量恢复

5、断点恢复

6、基于时间点恢复

六、小结:


一、Mysql日志管理

1、日志的默认位置及配置文件

1.1Mysql日志默认保存在/usr/local/mysql/data下

1.2配置文件的位置在/etc/my.cnf文件中的[mysqld]内

2、日志分类

2.1错误日志

用来记录Mysql的错误信息,默认开启的

log-error=/usr/local/mysql/data/mysql_error.log
2.2通用查询日志

用来记录Mysql所有的连接和语句,默认是关闭的

general_log=ON
general_log_file=/usr/local/mysql/data/mysql_general.log
2.3二进制日志

用来记录所有更新的数据或者已经潜在更新数据的语句,记录了数据的更改,可用于数据恢复,默认是开启的

log_bin=mysql-bin
或 log-bin=mysql-bin
2.4慢查询日志

用来记录所有执行时间超过long_query_time秒的语句,可以找到哪些查询语句执行时间长,以便于优化,默认也是关闭的。

slow_query_log=ON
slow_query_log_file=/usr/local/mysql/data/mysql_slow_query.log
long_query_time=5 单位时间为s,缺省时为10s
2.5中继日志

一般情况下,在Mysql主从复制,读写分离集群的从节点开启,主节点一般不需要这个日志

3、日志配置

在配置文件中修改

#错误日志
log-error=/usr/local/mysql/data/mysql_error.log	 
#通用查询日志
general_log=ON
general_log_file=/usr/local/mysql/data/mysql_general.log
#二进制日志
log-bin=mysql-bin	
#慢查询日志
slow_query_log=ON
slow_query_log_file=/usr/local/mysql/data/mysql_slow_query.log
long_query_time=5
#配置文件添加完后需要重启MySQL
systemctl restart mysql

修改my.cnf配置文件,在mysqld中添加如下内容

然后再重启mysql服务即可

4、日志查询

进入mysql数据库,查询日志是否开启

#variables 表示变量
#like 表示模糊查询
#%xxx,以什么结尾,xxx%以什么开头,%xxx%包含
#查看通用查询日志是否开启
show variables like 'general%';	
#查看二进制日志是否开启
show variables like 'log_bin%';	
#查看慢查询日功能是否开启
show variables like '%slow%';		
#查看慢查询时间设置
show variables like 'long_query_time';
#在数据库中设置开启慢查询的方法
set global slow_query_log=ON;		
4.1查询通用日志是否开启
show variables like ‘general%’; 

4.2查询二进制日志是否开启
show variables like ‘log_bin%’;

4.3查看慢查询日志是否开启
show variables like ‘long_query_time’;

4.4查询慢查询日志超时时间
show variables like ‘long%’;

二、数据备份

1、数据备份的概念

数据备份的主要目的是灾难恢复,而且还可以用来测试应用,回滚数据,查询历史数据等

2、数据备份的必要性

在生产环境中,数据很重要,数据保障了企业业务的正常运行。因此数据的安全性及数据的可靠性是运维工作的重中之重,任何数据的丢失都可能是对企业产生十分严重的后果。

2.1数据丢失的原因:

①程序的错误

②人为操作错误

③运算错误

④磁盘故障

⑤灾难(自然灾害,以及人为盗窃等)

3、数据备份的类型

3.1数据库备份从物理与逻辑的角度分类可以分为物理备份和逻辑备份
3.1.1物理备份

①物理备份是对数据库操作系统的物理文件(如数据文件、日志文件等)的备份。

②物理备份适用于在出现问题时需要快速恢复的大型重要数据库。

③物理备份又可以分为冷备份(脱机备份)、热备份(联机备份)和温备份。

3.1.2、逻辑备份

①逻辑备份是对数据库逻辑组件(如表等数据库对象)的备份,表及数据库结构(CREATE DATABASE, CREATETABLEia)和内容(INSERT语句或分隔文本文件)的信息。

②逻辑备份适用于可以编辑数据值或表结构较小的数据量,或者在不同的机器体系结构上重新创建数据

3.1.3冷备份:在数据库关闭的状态下进行备份操作

3.1.4热备份:在数据库处于运行状态时进行备份操作,该备份方法依赖数据库的日志文件。

3.1.5温备份:数据库锁定表格(不可写入但可读)的状态下进行别分操作。

3.2从数据库的备份策略角度分类

3.2.1完全备份:


每次对数据进行完整的备份,即对整个数据库、数据库结构和文件结构的备份,保存的时备份完成时刻的数据库,是差异备份与增量备份的基础。完全备份的备份与恢复操作都非常简单方便,但是数据存在大量的重复,并且会占用大量的磁盘空间,备份的时间也很长。

3.2.2差异备份:

备份那些上次完全备份之后被修改过的所有文件,备份的时间节点是从上次完整备份,备份数据量会越来越大。恢复数据时,只需要恢复上次的完全备份与最近的一次差异备份即可。

3.2.3增量备份:

只有那些在上次完全备份或者增量备份后被修改的文件才会被备份。以上次完整备份或上次增量备份的时间为时间点,仅备份这之间的数据变化,因而备份的数据量小,占用空间小,备份速度快。但恢复时,需要从上一次的完整备份开始到最后一次增量备份之的所有增量依次恢复,如中间某次的备份数据损坏,将导致数据的丢失。

4、备份方法

数据库的备份可以采用很多种方式,如直接打包数据库文件(物理冷备份)、专用备份工具(mysqldump)、二进制日志增量备份,第三方工具备份等

4.1物理冷备份

①物理冷备份时需要在数据库出入关闭状态下,能够较好的保证数据库的完整性。

②物理冷备份一般用于非核心业务,这类业务一般都允许中断

③物理冷备份的特点就是速度快,恢复时也是最简单的

④通常通过直接打包数据库文件夹(usr/local/mysql/data)来实现备份

4.2专用备份工具mysqldump或mysqlhotcopy

①mysqldump程序和musqlhotcopy都可以备份

②mysqldump是客户端常用逻辑备份程序,能够产生一组被执行以后再现原始数据库对象定义和表数据的SQL语句。它可以转储一个到多个mysql数据库,对其进行备份或传输到远程SQL服务器mysqldump更为通用,因为它可以备份各种表。

③mysqlhotcopy仅适用于存储引擎

4.3通过二进制日志进行增量备份

①支持增量备份,进行增量备份时必须启用二进制日志

②二进制日志文件为用户提供复制,对执行备份点后进行的数据库更改所需要的信息进行恢复

③如果进行增量备份(包含自上次完全备份或增量备份以来发生的数据修改),需要刷新二进制日志。

4.4通过第三方工具备份

第三方工具percona xtrabackup是一个免费的mysql热备份软件,支持在线热备份innodb和xtradb,也可以支持mysql表备份,不过myisam表的备份要在表锁的情况下进行。

三、Mysql完全备份

是对整个数据库,数据库结构和文件结构的备份,保存的是备份完成时刻的数据库,是差异备份与增量备份的基础。

1、完全备份的优缺点:

①优点:备份与恢复操作简单方便

②缺点:数据存在大量的重复,占用大量的备份空间,备份与恢复的时间长

2、数据库完全备份的分类

2.1物理冷备份与恢复

①关闭mysql数据库

②使用tar命令直接打包数据库文件夹

③直接替换现有的mysql目录即可

2.2mysqldump备份与恢复

①mysql自带的备份工具,可方便实现对mysql的备份

②可以将指定的库,表导出为SQL脚本

③使用命令mysql导入备份的数据

四、Mysql完全备份与恢复

1、物理冷备份与恢复

systemctl stop mysqld
yum -y install xz
 
#压缩备份
cd /usr/local/mysql/data
tar jcvf mysql_all_$(date +%F).tar.xz /usr/local/mysql/data
systemctl start mysqld
 
#模拟故障,删除数据库
drop database kgc;
 
#解压恢复
tar jxvf /opt/mysql_all_2022-06-21.tar.xz -C /usr/local/mysql/data
cd /usr/local/mysql/data
mv usr/local/mysql/data/* ./

前期准备:

模拟故障,删除kgc

恢复故障

2、mysqldump完全备份与恢复(温备份)

2.1完全备份一个或多个完整的库(包括其中所有的表)

mysqldump -u root -p[密码] --databases 库名1 [库名2] ... > /备份路径/备份文件名.sql   
#导出的就是数据库脚本文件
 
例:
 
mysqldump -u root -p --databases ky35 > /opt/kgc.sql       #备份一个kgc库
mysqldump -u root -p --databases mysql kgc > /opt/mysql-kgc.sql    #备份mysql与 kgc两个库

备份kgc库

2.2完全备份mysql服务器中所有的库
mysqldump -u root -p[密码] --all-databases > /备份路径/备份文件名.sql
 
例:
 
mysqldump -u root -p --all-databases > /opt/all.sql
2.3完全别分指定库中的部分表
mysqldump -u root -p[密码] 库名 [表名1] [表名2] ... > /备份路径/备份文件名.sql
 
例:
 
mysqldump -u root -p [-d] kgc ky35 ky36 > /opt/kgc_ky.sql
 
#使用“-d”选项,说明只保存数据库的表结构
 
#不使用“-d"选项,说明表数据也进行备份
#做为一个表结构模板
2.4查看备份文件
grep -v "^--" /opt/kgc_ky35.sql | grep -v "^/" | grep -v "^$"

3、恢复数据库

3.1方法一:source恢复
使用mysqldump导出的文件,可使用导入的方法
 
source命令  进入数据库  
 
mysql> source  /opt/kgc.sql ------>备份文件路径
 
登录到MySQL数据库,执行source备份sql脚本的路径

3.2方法二:mysql恢复
mysql -uroot -p123456 < /opt/kgc.sql

4、恢复表(依据上面的备份表来进行)

4.1方法一:source恢复

4.2方法二:mysql恢复

5、注意:

mysqldump严格来说属于温备份,会对表进行写入的锁定

在全量备份与恢复实验中,有kgc库,kgc库中有ky35表,此时需要注意

①当备份时加--databases,表示针对kgc库
#备份命令
mysqldump -uroot -p123456 --databases kgc > /opt/ky35.sql 备份库后
 
#恢复命令过程为:
mysql -uroot -p123123
drop database kgc;
exit
mysql -uroot -p123123 < /opt/ky35.sql

②当备份时不加--databases时,表示针对kgc库下的所有表
当备份时不加 --databases,表示针对school库下的所有表
 
#备份命令
mysqldump -uroot -p123456 kgc > /opt/ky35.sql
 
#恢复过程:
mysql -uroot -p123456
drop database kgc;
create database kgc;
exit
mysql -uroot -p123456 kgc < /opt/ky35.sql

此时只能先进入mysql中创建kgc才能将数据表恢复

二者的差别就是在于--databases,①会先创建databases,开始,而②时直接针对表进行操作。

③在实际生产环境中,可以使用shell脚本来实现自动定时备份。
0 1* * 7 /usr/local/mysql/bin/mysqldump -uroot -p123456 kgc info1 > ./kgc_infol_$(date +%Y%m%d).sql ;
/usr/local/mysql/bin/mysqladmin -u root -p flush-logs

五、Mysql增量备份与恢复

1、恢复的方式

1.1一般恢复

就是将所有备份的二进制日志内容全部恢复

1.2基于位置恢复

数据库在某一时间点可能既有错误也有正确的操作

可以基于精准的位置跳过错误的操作

发生错误节点之前的一个节点上,上一次正确操作的位置点停止

1.3基于时间恢复

跳过某个发生错误的时间点实现数据恢复

在错误时间点停止,在下一个正确时间点开始

2、二进制文件介绍

2.1、开启二进制日志功能
vim /etc/my.cnf
 
[mysqld]
 
log-bin=mysql-bin
 
binlog_format = MIXED      
#可选,指定二进制日志(binlog)的记录格式为MIXED(混合输入)
 
server-id = 1              
#可加可不加该命令
 
systemctl restart mysqld

2.2二进制日志的三种不同的记录格式
①statement(基于SQL语句)

每一条涉及到被修改的sql都会被记录在binlog中

缺点:日志量过大,如sleep()函数,last_insert_id()>,以及user-defined fuctions(udf)、主从复制等架构记录日志时会出现问题

②row(基于行)

只记录变动的记录,不记录sql的上下文环境

缺点:如果遇到update......set....where true 那么binlog的数据量会越来越大

③mixed(推荐使用)

一般的语句使用statement,函数使用row方式存储

2.3查看二进制日志文件的内容
cp /usr/local/mysql/data/mysql-bin.000002 /opt/
 
mysqlbinlog --no-defaults  /opt/mysql-bin.000002
mysqlbinlog --no-defaults --base64-output=decode-rows -v /opt/mysql-bin.000002
 
#--base64-output=decode-rows:使用64位编码机制去解码(decode)并按行读取(rows)
#-v: 显示详细内容
#--no-defaults : 默认字符集(不加会报UTF-8的错误)
PS: 可以将解码后的文件导出为txt格式,方便查阅
 
mysqlbinlog --no-defaults --base64-output=decode-rows -v /opt/mysql-bin.000002 > /opt/mysql-bin.000002

2.4二进制日志中需要关注的部分

①at:开始的位置点

②end_log_pos:结束的位置

③时间戳:240325 19:00

④SQL语句

3、增量备份过程(全备+增备)

使用mysqldump

可每天进行增量备份操作,生成新的二进制日志文件(例如:mysql-bin.000006)
 
mysqladmin -u root -p flush-logs

插入新数据,以模拟数据的增加或变更

注意:在第一次完全备份之后刷新二进制文件,在第二个二进制文件中记载着“增量备份的数据”

在kgc库中创建ky36,并插入数据

创建njzb库,并复制kgc中的ky36表,命名为ky01

再次生成新的二进制日志文件(例如:mysql-bin.000007)
 
mysqladmin -u root -p flush-logs
 
#之前的步骤创建kgck库中的sss表和创建NJ库以及库中的ZB表的操作会保存到mysql-bin.000006文件中

4、增量恢复

全部恢复

模拟所有数据丢失,直接删除kgc跟njzb库

先恢复完全备份

基于mysql-bin.000006恢复增量,恢复所有
 
mysqlbinlog --no-defaults / usr/local/mysql/data/mysql-bin.000006 | mysql -uroot -p123456

5、断点恢复

#查看日志
mysqlbinlog --no-defaults --base64-output=decode-rows -v /usr/local/mysql/data/mysql-bin.000006

基于位置点恢复
#仅恢复到操作 ID 为“623"之前的数据,即不恢复"user4"的数据
 
mysqlbinlog --no-defaults --stop-position='1793' /opt/mysql-bin.000002 | mysql -uroot -p密码
#仅恢复"user4"的数据,跳过"user3"的数据恢复
 
mysqlbinlog --no-defaults --stop-position='623' /opt/mysql-bin.000002 | mysql -uroot -p
mysqlbinlog --no-defaults --start-position='400' --stop-position='623' /opt/mysql-bin.000002 | mysql -uroot -p      
#恢复从位置为400开始到位置为623为止

6、基于时间点恢复

#仅恢复到16:41:24 之前的数据,即不恢复"user4"的数据
mysqlbinlog --no-defaults --stop-datetime='2020-11-22 16:41:24' /opt/mysql-bin.000002 | mysql -uroot -p
 
#仅恢复"user4"的数据,跳过"user3"的数据恢复
mysqlbinlog --no-defaults --start-datetime='2020-11-2216:41:24' /opt/mysql-bin.000002 | mysql -uroot -p
 
如果恢复某条SQL语之前的所有数据,就stop在这个语句的位置节点或者时间点
如果恢复某条SQL语句以及之后的所有数据,就从这个语句的位置节点或者时间点start

六、小结:

①在增量备份恢复时,应该先从完全备份恢复,然后再到二进制日志逐一恢复

②在恢复某条sql语句之前的所有数据,就stop在这个语句的位置节点或者时间点

③如果恢复某个sql语句以及之后的所有数据,就从这个语句的位置节点或者时间节点start

④全备库source针对库mysql针对库中的表,备份时使用--databases使得恢复时source和mysql效果一致。

⑤只保存数据库表结构时在加-d,不加-d时默认将表以及结构都保存。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1551867.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

损坏的RAID5csp

1.解题思路 这道题太抽象了&#xff0c;一开始都没太搞懂在讲啥。。。解决该题需要了解条带、磁盘号的定义。 下图以样例2&#xff0c;输入编号为5的块为例&#xff1a; 请务必加上ios::sync_with_stdio(false),否则会超时只有30分 2.满分代码 #include<iostream> us…

C++进阶之路---C++11新特性 | lambda表达式

顾得泉&#xff1a;个人主页 个人专栏&#xff1a;《Linux操作系统》 《C从入门到精通》 《LeedCode刷题》 键盘敲烂&#xff0c;年薪百万&#xff01; 前言&#xff1a;简介lambda 在C中&#xff0c;lambda表达式是一种匿名函数的方式&#xff0c;它可以用来解决以下问题&a…

2023年蓝桥杯省赛——矩形面积总和

目录 题目链接&#xff1a; 1.矩形总面积 - 蓝桥云课 (lanqiao.cn) 思路 暴力 数学杯思路 数学逻辑 难点之重合区域 代码实现 总结 题目链接&#xff1a; 1.矩形总面积 - 蓝桥云课 (lanqiao.cn) 思路 暴力 开幕雷击&#xff0c;我直接开始暴力&#xff0c;但是我暴力…

深入解析RSA算法原理及其安全性机制

码到三十五 &#xff1a; 个人主页 心中有诗画&#xff0c;指尖舞代码&#xff0c;目光览世界&#xff0c;步履越千山&#xff0c;人间尽值得 ! 目录 一、RSA算法简介二、RSA算法原理2.1 背景与数学基础2.2 密钥生成2.3 加密过程2.4 解密过程 三、安全性考虑四、RSA的使用五、…

【Linux】详解进程程序替换

一、替换原理 用fork创建子进程后执行的是和父进程相同的程序(但有可能执行不同的代码分支)&#xff0c;子进程往往要调用一种exec函数以执行另一个程序。当进程调用一种exec函数时&#xff0c;该进程的用户空间代码和数据完全被新程序替换&#xff0c;从新程序的启动例程开始执…

爱上数据结构:顺序表和链表

一、线性表 线性表&#xff08;linear list&#xff09;是n个具有相同特性的数据元素的有限序列。 线性表是一种在实际中广泛使 用的数据结构&#xff0c;常见的线性表&#xff1a;顺序表、链表、栈、队列、字符串... 线性表在逻辑上是线性结构&#xff0c;也就说是连续的一条…

iOS - LLVM的中间代码(IR)

文章目录 iOS - LLVM的中间代码&#xff08;IR&#xff09;1. 转为汇编代码2. 中间代码&#xff08;IR&#xff09;2.1 Objective-C在变为机器代码之前&#xff0c;会被LLVM编译器转换为中间代码&#xff08;Intermediate Representation&#xff09;2.2 可以使用以下命令行指令…

MySQL 索引:索引为什么使用 B+树?

Hash 索引不支持顺序和范围查询&#xff1b; 二叉查找树(BST)&#xff1a;解决了排序的问题&#xff0c;极端情况下可能会退化成线性链表&#xff0c;查询效率急剧下降&#xff1b; 平衡二叉树(AVL) &#xff1a;通过旋转解决了平衡的问题&#xff0c;但是旋转操作效率太低&am…

蓝桥杯练习题总结(三)线性dp题(摆花、数字三角形加强版)

目录 一、摆花 思路一&#xff1a; 确定状态&#xff1a; 初始化&#xff1a; 思路二&#xff1a; 确定状态&#xff1a; 初始化&#xff1a; 循环遍历&#xff1a; 状态转移方程&#xff1a; 二、数字三角形加强版 一、摆花 题目描述 小明的花店新开张&#xff0c;为了吸…

spring boot3自定义注解+拦截器+Redis实现高并发接口限流

⛰️个人主页: 蒾酒 &#x1f525;系列专栏&#xff1a;《spring boot实战》 &#x1f30a;山高路远&#xff0c;行路漫漫&#xff0c;终有归途 目录 写在前面 内容简介 实现思路 实现步骤 1.自定义限流注解 2.编写限流拦截器 3.注册拦截器 4.接口限流测试 写在前…

戴尔电脑Dell SupportAssist占用内存高,卸载Dell SupportAssist

咨询戴尔客服了解到&#xff0c;SupportAssist是机器出厂自带的一款应用&#xff0c;主要的功能是可以检查驱动更新以及做一些硬件方面的健康检测&#xff0c;有时候后台运行可能会导致进程占用内存比较大&#xff0c;导致访问被的应用崩溃。 咨询卸载不影响之后&#xff0c;然…

在CentOS7上部署Nginx并测试指南

Nginx部署测试 Nginx简介 Nginx是俄罗斯人Igor Sysoev编写的一款高性能的HTTP和反向代理服务器。 Nginx选择了epoll和kqueue作为网络I/O模型&#xff0c;在高连接并发的情况下&#xff0c;内存、CPU等系统资源消耗非常低&#xff0c;运行稳定。 正向代理与反向代理 正向代…

FLStudio多少钱FL Studio中文版软件序列号-激活码购买

fl studio是一款编曲软件&#xff0c;接触这款软件的大多都是做音乐的小伙伴吧&#xff0c;对于初学者想了解这款软件在意的应该就是它的价格。很多打算入手正版FL Studio的新手朋友都会纠结一个问题&#xff1a;哪个版本的FL Studio更适合我&#xff0c;到底应该入手哪一款FL …

Java安全篇-Fastjson漏洞

前言知识&#xff1a; 一、json 概念&#xff1a; json全称是JavaScript object notation。即JavaScript对象标记法&#xff0c;使用键值对进行信息的存储。 格式&#xff1a; {"name":"wenda","age":21,} 作用&#xff1a; JSON 可以作为…

OCP NVME SSD规范解读-15.DSSD set feature功能要求-2

启用IEEE1667隔离区(Enable IEEE1667 Silo)&#xff1a;特征标识符C4h允许开启符合IEEE1667标准的安全存储区功能&#xff0c;以实现数据的隔离和安全存储。 4.15.9章节描述了启用IEEE1667 Silo&#xff08;通过Feature Identifier C4h标识的Set Feature命令&#xff09;的相关…

C++:转义符(10)

在c中有一些字符无法被显示出来&#xff0c;所以需要使用些特殊字符加字母来展示 可以看到基本都是一个\加一个字母去只执行对应的一个效果 这里我选择几个对于当前来说比较重要的&#xff1a;\n &#xff0c;\\ &#xff0c;\t \n换行符 可以看到在c语言中他就是一个可以换行…

echarts图表动态监听dataZoom滑动,控制柱条的宽度以及数值的显示隐藏

当数值过多时&#xff0c;显示所有柱条看着会很凌乱且文字会挤在一起&#xff0c;于是就需要监听datazoom的滑动&#xff0c;拿到对应的阈值后做出相应的配置。 “dataZoom” 事件通常用于响应用户对图表进行数据缩放的操作。 这里是datazoom官网api地址&#xff1a;点击跳转至…

【计算机网络篇】数据链路层(4.1)可靠传输的相关概念

文章目录 &#x1f354;可靠传输的相关概念⭐分组丢失⭐分组失序⭐分组重复 &#x1f95a;注意 &#x1f354;可靠传输的相关概念 使用差错检测技术&#xff08;例如循环冗余校验CRC&#xff09;&#xff0c;接收方的数据链路层就可以检测出帧在传输过程中是否产生了误码&…

基于SpringBoot后端实现连接MySQL数据库并存贮数据

目录 一、什么是MySQL数据库 二、基于SpringBoot框架连接MySQL数据库 1、首先添加MySQL依赖&#xff1a; 2、配置数据库连接&#xff1a; 3、创建实体类&#xff1a; 4、创建Repository接口&#xff1a; 5、使用Repository&#xff1a; 三、编写业务SQL语句 1、使用Spring Data…

大模型LLM的数学推理

1 算术 例如: 2 数学文字题 2.1 问题-答案 直接给出答案 2.2 问题-方程式-答案 给出解答的方程式&#xff08;过程&#xff09; 2.3 问题-论证-答案 给出论证的过程&#xff08;应该含有方程式&#xff09; 综上&#xff0c;考虑到视频的可视化过程&#xff0c;着…