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

目录

一、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时默认将表以及结构都保存。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

web——rce,代码执行,命令执行

eval就会将里面的内容当成php来执行 ctf 第一 第二 过滤system\ 也可也怎么做 然后访问2.txt 第三&#xff08;参数逃逸&#xff09; 可以用这个&#xff0c;url中的eval是让get函数的使用&#xff0c;网页中的eval是为了让system中的函数起效 第四 过滤分号&#xff0c;因为上…

解决:PytorchStreamWriter failed writing file data

文章目录 问题内容问题分析解决思路 问题内容 今天在炼丹的时候&#xff0c;我发现模型跑到140步的时候保存权重突然报了个问题&#xff0c;详细内容如下&#xff1a; Traceback (most recent call last):File "/public/home/dyedd/.conda/envs/diffusers/lib/python3.8…

【Java核心能力】一篇文章了解 ZooKeeper 底层运行原理

欢迎关注公众号&#xff08;通过文章导读关注&#xff1a;【11来了】&#xff09;&#xff0c;及时收到 AI 前沿项目工具及新技术的推送&#xff01; 在我后台回复 「资料」 可领取编程高频电子书&#xff01; 在我后台回复「面试」可领取硬核面试笔记&#xff01; 文章导读地址…

Mysql数据库——主从复制与读写分离

目录 前言 一、主从复制 1.主从复制的定义 2.Mysql主从复制支持的类型 3.主从复制的过程 4. 主从复制出现的问题 5.解决方法 二、读写分离 1.读写分离的定义 2.读写分离的作用 3.读写分离作用场景 3.1基于程序代码内部实现 3.2基于中间代理层实现 4.主从复制与读…

Redis命令介绍

一、redis启动&#xff1a; 本地启动&#xff1a;redis-cli 远程启动&#xff1a;redis-cli -h host -p port -a password Redis 连接命令 1 AUTH password 验证密码是否正确 2 ECHO message 打印字符串 3 PING 查看服务是否运行 4 QUIT 关闭当前连接 5 SELECT index 切换…

UI设计案例,B端后台界面设计教程

B端产品是为“组织”提供服务&#xff0c;以业务为中心&#xff0c;追求时效性&#xff0c;在视觉上&#xff0c;内容为王&#xff0c;视觉为功能让步&#xff0c;追求简洁、清晰、克制、理性的视觉风格。B 端产品业务比较复杂&#xff0c;页面内容也会较多&#xff0c;B端界面…

Python与人工智能:气象领域的数据处理与模型优化

Python是功能强大、免费、开源&#xff0c;实现面向对象的编程语言&#xff0c;在数据处理、科学计算、数学建模、数据挖掘和数据可视化方面具备优异的性能&#xff0c;这些优势使得Python在气象、海洋、地理、气候、水文和生态等地学领域的科研和工程项目中得到广泛应用。可以…

LLM资料:中文embedding库

Highlight&#xff08;重点提示&#xff09; 理解LLM&#xff0c;就要理解Transformer&#xff0c;但其实最基础的还是要从词的embedding讲起。 毕竟计算机能处理的只有数字&#xff0c;所以万事开头的第一步就是将要处理的任务转换为数字。 面向中文的开源embedding库在自然…

MQ集合了

消息队列&#xff0c;FIFO &#xff1a;异步 解耦 削峰 复杂度上升 幂等 重复消费 消息丢失 / 可用性降低 mq故障 / 一致性要求 mq对比&#xff1a; activeMQ&#xff1a;jms规范&#xff0c;支持事务 xa协议 rabbitMQ&#xff1a;erlang 性能&#x1f44c; 高并发 多语…

react-router v6的Link组件relative属性解释

Link组件有一个名为relative的属性,值为route或path,默认为route 当Link的to为两个点时,配置relativeroute|path会有不同的效果, 之前由于路径嵌套不够深,看不出区别,于是尝试加深路径,一眼就看出了区别 官方解释 | React Router6 中文文档 下方代码请看根路径/cd及其二级路…

C++优先队列——priority_queue,函数对象,labmda表达式,pair等

头文件&#xff1a;#include<queue> 内部使用堆来实现&#xff0c;在需要或得最大的几个值或最小的几个值而不关心整个数组的顺序时非常好用。 用法&#xff1a; priority_queue<int, vector<int>, greater<int>>q; 第一个参数为堆中存储的元素。 …

vue 借助vue-amap插件对高德地图的简单使用

需求&#xff1a;实现点击获取经纬度、定位、对特殊位置标点及自定义信息窗体功能。 高德地图的官网API&#xff1a;概述-地图 JS API 1.4 | 高德地图API vue-amap的中文文档&#xff1a;组件 | vue-amap 实现&#xff1a; 1、安装vue-amap插件 npm install vue-amap --save…

AI预测福彩3D第20弹【2024年3月28日预测--第4套算法重新开始计算第6次测试】

今天继续对第4套算法进行测试&#xff0c;测试的目的主要是为了记录统计两套方案的稳定性和命中率&#xff0c;昨天的第二套方案已命中。今天是第5次测试&#xff0c;同样测试两个方案。废话不多说&#xff0c;直接上结果。 2024年3月28日福彩3D的七码预测结果如下 …

武忠祥《660题》高效刷题包+资料分享

660题的难度书虽然比较难&#xff0c;对于基础的考察比较深入&#xff0c;所以&#xff0c;有没有一种可能&#xff0c;做题太慢&#xff0c;是因为基础不好导致的&#xff01; 所以再继续做下去&#xff0c;就没有什么意义了&#xff0c;因为这就像是用一把钝刀去砍树&#x…

mybatis搭建开发环境

1.创建maven工程 2.配置pom.xml <!--数据库驱动--> <dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.47</version> </dependency> <!--Mybatis--> <depend…

vscode使用sftp上传

1.用vscode打开项目 2.安装一下这个sftp 3.使用快捷键 ctrlshiftP 打开指令窗口&#xff0c;输入 sftp:config&#xff0c;选中回车&#xff0c;在当前目录中会自动生成 .vscode 文件夹及 sftp.json 4.修改sftp.json文件配置&#xff0c;改成以下&#xff08;默认的参数可能上传…

八种顺序读写函数的介绍(fput/getc;fput/gets;fscanf,fprintf;fwrite,fread)

一&#xff1a;读写的含义的解释&#xff1a; 读&#xff08;读出&#xff09;&#xff1a;即从文件里面读出数据----------->和scanf从键盘里面读出数据类似 写&#xff08;写入&#xff09;&#xff1a;即把数据写入文件里面----------->和printf把数据写入到屏幕上类…

【leetcode】双“指针”

标题&#xff1a;【leetcode】双指针 水墨不写bug 我认为 讲清楚为什么要用双指针 比讲怎么用双指针更重要&#xff01; &#xff08;一&#xff09;快乐数 编写一个算法来判断一个数 n 是不是快乐数。 「快乐数」 定义为&#xff1a; 对于一个正整数&#xff0c;每一次将该数…

Unity 窗口化设置

在Unity中要实现窗口化&#xff0c;具体设置如下&#xff1a; 在编辑器中&#xff0c;选择File -> Build Settings。在Player Settings中&#xff0c;找到Resolution and Presentation部分。取消勾选"Fullscreen Mode"&#xff0c;并选择"Windowed"。设…

Linux:Jenkins:参数化版本回滚(6)

上几章我讲到了自动集成和部署 Linux&#xff1a;Jenkins全自动持续集成持续部署&#xff08;4&#xff09;-CSDN博客https://blog.csdn.net/w14768855/article/details/136977106 当我们觉得这个页面不行的时候&#xff0c;需要进行版本回滚&#xff0c;回滚方法我这里准备了…