MySQL学习记录 —— 이십이 MySQL服务器文件系统(2)

文章目录

  • 1、日志文件的整体简介
  • 2、一般、慢查询日志
    • 1、一般查询日志
    • 2、慢查询日志
      • FILE格式
      • TABLE格式
  • 3、错误日志
  • 4、二进制日志
  • 5、日志维护


1、日志文件的整体简介

在这里插入图片描述

中继服务器的数据来源于集群中的主服务。每次做一些操作时,把操作保存到重做日志,这样崩溃时就可以从重做日志把之前的操作拿回来。

• 默认情况下,除 Windows 上的错误日志外,不启用任何日志,Linux下默认开启错误日志和二进制日志
• 在服务器运行期间可以控制一般查询和慢查询日志的禁用与开启,也可以更改日志文件名
• 一般查询日志和慢查询日志记录可以写入日志表、日志文件或两者同时写入

• 默认情况下,所有启用的日志将写人数据目录,可以通过刷新日志强制服务器关闭并重新打开日志文件
• 通过 FLUSH LOGS 语句刷新日志来强制服务器关闭并重新打开日志文件,也可以使用mysqladmin 的 flush-logs 或 refresh 参数,或mysqldump 的 --flush-logs 或 --master-data 选项
• 中继日志仅用于主从复制过程中的从服务器。

2、一般、慢查询日志

如果启用一般查询日志和慢查询日志,日志的输出方式可以指定为日志文件或 mysql 系统库中的 general_log 和 slow_log 表,也可以两者同时指定。log_output 系统变量指定日志输出的形式,但并不会真正的启用日志。 log_output 有三个值,分别是: TABLE (表)、 FILE (文件)、 NONE (不输出),可以同时指定多个值,并用逗
号隔开,未指定值时默认是 FILE ,如果列表中存在 NONE 则其他的不生效,即 NONE 的优先级最高。

通过设置 general_log 系统变量的值来控制一般查询日志的 开启 1 与 禁用 0 ,如果要为日志指定自定义的路径或文件名可以使用 general_log_file 系统变量。

通过设置 slow_query_log 系统变量的值来控制慢查询日志的 开启 1 与 禁用 0 ,如果要为日志指定自定义的路径或文件名可以使用 slow_query_log_file 系统变量。

两个log_file系统变量都需要绝对路径。

以选项文件中的配置为例:

[mysqld]
#日志写入表和文件
log_output=TABLE,FILE
#两个日志可以同时开, 可以只开一个 
#开启一般查询日志
general_log=1
#指定自定义的文件名 
general_log_file=/var/lib/mysql/general.log 
#开启慢查询日志
slow_query_log=1 
#指定自定义的文件名
slow_query_log_file=/var/lib/mysql/slow_query.log

如果没用_log_file系统变量来指定路径,那么默认路径在启动mysql后查看

show variables like 'general_log_file';
show variables like 'slow_query_log_file';

运行时修改:

SET [GLOBAL|SESSION] variable_name=value

可以修改日志的输出形式,输出到的文件。若只对当前会话禁用或启用一般查询日志记录,将 SESSION作用域的 sql_log_off 变量设置为 ON 或 OFF。

日志文件在mysql中就是一个表,可以通过 SQL 语句的条件查询过滤日志内容,,从而选择满足特定条件的日志记录。比如,某个客户端的日志;客户端程序连接到服务器就能用SQL语句查询表中的日志信息,这属于应用程序级别,无需用一个有相应权限的系统用户来登录服务器主机访问文件系统。

1、一般查询日志

一般查询日志记录客户端连接或断开连接的信息,也会记录从客户端接收的每个SQL语句。不过它很耗费服务器资源,所以默认为不开启。

默认日志文件名位host_name.log,用 general_log_file=file_name 修改。

记当客户端连接的日志行,使用 connection_type 来指示用于建立连接的协议。 TCP/IP 表示不使用SSL建立的TCP/IP连接、 SSL/TLS 表示使用SSL建立的TCP/IP连接、 Socket 表示Unix套接字文件连接、Named Pipe 表示Windows命名管道连接、 Shared Memory 表示Windows共享内存连接。

Mysqld按照接收到SQL语句的顺序将语句写入查询日志,这个顺序可能与语句执行的顺序不同。

SQL语句查询日志

select * from mysql.general_log\G

查询到的内容有一些就看不出来什么意思,用CAST()来转换一下。

SELECT DATE_FORMAT(event_time, '%Y-%m-%d %H:%i:%s') AS time, user_host, thread_id, server_id, command_type, CAST(argument AS CHAR) AS query 
FROM mysql.general_log;

像这样,在查询DATE_FORMAT表时,把argument转换成char类型的。而select后的as和cast后的as都是重命名的意思。

除此之外,不启动mysql的情况下,查询Linux目录下的日志文件也行,通常在/var/lib/mysql下。

2、慢查询日志

慢查询日志由执行时间超过系统变量 long_query_time 指定的秒数的 SQL 语句组成,并且查询的行数要大于系统变量 min_examined_row_limit 指定值。被记录的慢查询需要进行优化,可以用 mysqldumpslow客户端程序对慢日志进行分析汇总。

获取初始锁的时间不计入执行时间,mysqld在执行完SQL语句并释放所有锁后才将符合条件的语句写入慢速查询日志,因此日志顺序可能与执行顺序不同。也就是说慢查询记录的时间是执行SQL语句并返回结果,释放锁的时间。

在这里插入图片描述

使用 --log-short-format 选项,以简要格式记录慢查询日志。

要记录管理语句,启用 log_slow_admin_statements 系统变量。管理语句包括 ALTER、TABLE 、 ANALYZE TABLE 、 CHECK TABLE 、 CREATE INDEX 、 DROP INDEX 、OPTIMIZE TABLE 和 REPAIR TABLE 。

要记录不使用索引的查询,启用 log_queries_not_using_indexes 系统变量。当记录不使用索引的查询时,日志会快速增长,通过设置系统变量log_throttle_queries_not_using_indexes 限制每分钟写入慢查询日志同类查询的数量,默认值是0,表示无限制。

通常设置启用或不启用就是1和0,或者ON和OFF,具体查看官方文档 MySQL 8.4。

修改可以在配置文件修改,也可以在mysql运行时修改,运行时修改就是:

SET [GLOBAL|SESSION] variable_name=value

当然全局还是会话也要看官方文档,变量有3种类型,全局,会话,全局及会话。

FILE格式

如果启用慢查询日志并将 FILE 作为输出目标,每条语句前面都用一行来表示日志的字段,该行以 # 字符开头并包含以下内容:

Query_time: SQL语句的执行时间,单位秒
Lock_time:获取锁的时间,单位秒
Rows_sent:发送到客户端的行数
Rows_examined:服务器扫描数据表中具体数据行的数量

就像这样

在这里插入图片描述

启用–log-slow-extra[={OFF|ON}]系统变量会让更多字段写入到FILE中,之后的博客再详细写。

TABLE格式

慢查询日志表的表结构:

SHOW CREATE TABLE mysql.slow_log;

在这里插入图片描述
query_time是查询总耗时,lock_time是争抢mysql级别的锁的时间,rows_sent是返回结果集中数据行的数量,rows_examined是服务器扫描数据表中具体数据行的数量,db是数据库名,两个insert是关于插入的记录,server_id是选项文件中配置的server-id,sql_text是具体执行的SQL语句。

建议使用日志文件的形式来记录慢查询日志。

3、错误日志

错误日志一般会记录mysqld 启动和关闭的次数、诊断消息,以及服务器运行期间发生的错误和警告;错误日志默认使用UTF-8 ( utf8mb3 )编码格式,并使用英语生成记录。

错误日志的输出位置是控制台或者指定文件。配置文件中mysqld部分用 --log-error 选项来指定默认错误日志目标,可以指定控制台或文件。

如果错误日志输出目标是控制台,则服务器将 log_error 系统变量设置为 stderr。否则,将以文件形式输入错误日志,并以 log_error 的值为文件名。

如果显式写出 --log-error 但没有指定具体文件,则默认路径是数据目录中host_name.err 的文件;可以通过指定绝对路径,来更改默认的日志位置

[mysqld]
log-error=/var/log/mysql/error_log.err # 自定义错误日志的路径

字段

time :件时间戳,精度为微秒;
msg :事件消息字符串;
prio :事件优先级,包括 System event(System是数据库系统)(0)、 Error event(必须处理)(1)、 Warning event(定期查看是否影响系统运行)(2)或 Note/information event - 通知 / 提示事件(3),值越小优先级越高;

err_code :事件错误代码;
err_symbol :以字符串形式表示的事件错误符,例如 ‘ER_DUP_KEY’ ;
SQL_state :事件 SQLSTATE 值,与 err_symbol 对应,例如 ‘ER_DUP_KEY’ 对应的SQLSTATE为23000;
上面三个是MySQL内部维护的一套错误代码的定义

subsystem :事件发生的子系统。可能的值: InnoDB (InnoDB存储引擎)、 Repl (复制子系统)、 Server (其他)。

可选的错误日志字段:

OS_errno :操作系统错误号;
OS_errmsg :操作系统错误消息;
label :与值对应的 prio 描述 ;
user :客户端用户;
host :客户端主机;
thread :产生错误事件 的线程的 ID;
query_id :查询 ID。

错误日志示例:

在这里插入图片描述

每一行从左到右分别是时间,优先级,错误码,子系统,日志详情。

错误码的说明参考官方文档

Error Summary Tables

Global Error Message Reference

当mysqld程序在运行时发生的错误会写到文件中,还有一些情况发生在客户端执行错误的SQL语句时,会出现提示,但不会写入文件:访问了不存在的库和表、语句错误、权限问题。

如果使用FLUSH ERROR LOGS 、 FLUSH LOGS 语句或 mysqladmin flush-logs 命令刷新错误日志,服务器会将正在写入的任何错误日志文件关闭并重新打开。

如果要手动重命名错误日志文件,可以在重命名操作之后执行刷新操作,服务器会以原文件名生成一个新的错误日志文件。

mv host_name.err host_name.err-old # 重命名日志文件
mysqladmin flush-logs # 刷新操作
mv host_name.err-old backup-directory # 把重命名的日志文件移动到备份目录

4、二进制日志

数据库的读写操作全都在一个服务器上,当数据量增大时,单台服务器性能就会出现瓶颈 。一个很有效的解决办法就是形成一个服务器集群,可以让每个服务器降低一点配置,但一定要有足够数量的节点。集群中有一个主服务器,其它为从服务器,让每个服务器都只执行一种操作;可以让主服务器进行数据写入,从服务器负责查询等操作;但服务器之间也要同步数据,这时候就需要有二进制日志,每个服务器所有的操作都生成二进制日志,主服务器的二进制日志的副本放在一个中继服务器上,也就是复制品,从服务器从中继服务器那里读取中继日志,也就是主服的二进制日志的副本,然后再进行各种操作,执行中继日志中的所有修改记录。

⼆进制日志包含数据库更改的"事件",不会记录 SELECT 和 SHOW;二进制日志还包含每个语句更新数据时花费的时间信息,启动二进制日志,对服务器性能稍微有些影响;除了基于行的日志模式,它还包含可能进行更改数据的语句事件,例如 DELETE 操作没有匹配到查找到的行。

二进制日志的作用:

主从节点数据复制:从节点服务器读取主节点服务器上的二进制日志文件,并根据二进制日志中记录的事件在从节点上执行相同的操作,保证主从节点服务器上数据一致,实现数据复制功能。

数据恢复:从某个时间点恢复备份数据后,将重新执行备份时间点之后记录在二进制日志中的事件。这些事件使数据库从备份点更新到当前最新状态。

⼆进制日志的语句中如果涉及用户的密码,则由服务器进行加密,不会以纯文本形式出现。

查看二进制日志相关的系统变量:

show variables like '%bin%';

状态变量就是把variables换成status。

默认情况下启用二进制日志, log_bin 系统变量为 ON ;

禁用二进制日志,可以指定 --skip-log-bin 或 --disable-log-bin 选项。如果同时指定了 --log-bin 则后指定的选项优先;

选项 --log-bin[=base_name] 用于指定二进制日志文件的基本名称,如果不指定 --log-bin 选项,默认基本名称为 binlog ,建议为二进制日志指定⼀个基本名;

二进制日志文件名是由基本名 + 数字扩展名组成的,服务器每次创建⼀个新的日志文件时,数字扩展名都会增加,从而保证有序的文件系列。当服务器已启动或重新启动、服务器刷新日志、当前日志文件的大小达到max_binlog_size(单个日志文件的最大字节数,最小值 4096 字节,最大值和默认值 1GB)时服务器会创建一个新的日志文件。二进制日志文件大小可能会超出 max_binlog_size 设定的值,因为二进制日志在记录事务
时,会完整的记录整个事务,不存在把一个事务拆分的情况,如果遇到一个大事务时,即使记录整个事务会超过日志大小限制,也会保证事务的完整性;

mysqld还会创建一个包含二进制日志文件名的日志索引文件,默认情况下,这与二进制日志文件具有相同的基本名称,扩展名为 .index . 可以使用选项 --log-bin-index[=file_name]修改索引文件名;

二进制日志文件和索引文件的默认位置是数据目录。可以使用 --log-bin[=file_name] 选项指定自定义路径, file_name 格式 = 绝对路径 + 基本名。 --log-bin 对应的系统变量是log_bin_basename ;

要区分官方文档的这四个变量:

在这里插入图片描述

MySQL 8.4

MySQL 5.7 中,启用二进制日志必须指定服务器 ID,对应 server_id 选项,否则服务器将无法启动。在MySQL 8.0 中, server_id 系统变量默认设置为 1,在集群环境中,每台MySQL服务器必须有唯一的 server_id。

可以用客户端工具mysqlbinlog来查看二进制日志

mysqlbinlog binlog.000001 > binlog.000001

前面是二进制日志名,后面是导出的日志文件名,不过导出的是加密的。

SQL语句查看

show binlog events in 'binlog.000001' from N limit S;

在mysql查到的内容中,Pos表示当前这条日志在文件中的起始偏移量;Event_type是查询日志事件类型;End_log_pos是当前日志在文件中的结束偏移量;Info后面是具体执行的操作。

二进制日志有几种日志格式:

基于语句的日志格式,最初MySQL 是基于 SQL 语句复制实现主从节点同步,通过指定选项 --binlog-format=STATEMENT 使用此格式 。执行了什么语句就完整地写进去。

基于行的日志格式(默认)中,主节点将事件写入二进制日志,表示各个表的行受到的影响,可以通过指定选项 --binlog-format=ROW 使用此格式 。像下面的:

update student set age = 18 where id = 10;
update student set age = 18 where id = 11;
update student set age = 18 where id = 12;
...
update student set age = 18 where id = 19;
update student set age = 18 where id = 20;

当使用MySQL内部的一些函数时,必须以行的格式记录日志。

混合日志记录格式,默认情况下使用基于语句的日志记录,如果MySQL认为基于语句的格式不能保证主从复制过程中的数据安全时,会自动切换到基于行的日志格式,比如主节点在语句中用了UUID() 函数,那么日志文件中记录的是UUID生成的真实值而不是直接使用原始的SQL语句,使用混合日志格式中以指定选项 --binlog-format=MIXED。

设置二进制格式:

--binlog-format=[STATEMENT|ROW|MIXED]

5、日志维护

MySQL 服务器可以创建多种不同日志文件来帮助我们查看服务器的活动。但是必须定期清理这些文件,以免日志占用过多的磁盘空间。在启用日志的情况下,通常希望备份和删除旧的日志文件,并把日志写到新文件。

默认二进制日志的过期时间为30天,过期后将自动删除,要指定自定义过期时间,可以使用系统变量 binlog_expire_logs_seconds=N 单位为秒,在下一次启动服务器和刷新日志时删除过期日志文件。

强制使用新的日志文件可以手动刷新日志,当执行 FLUSH LOGS 语句或 mysqladmin flush-logs、mysqladmin refresh 、mysqldump --flush-logs、 mysqldump --master-data 命令时,会发生日志刷新。此外当二进制日志文件大小达到max_binlog_size 系统变量指定的值时,服务器会自动刷新二进制日志。

FLUSH BINARY LOGS # 刷新二进制日志
FLUSH ERROR LOGS # 刷新错误日志
FLUSH GENERAL LOGS # 刷新一般查询日志
FLUSH RELAY LOGS # 刷新中继日志
FLUSH SLOW LOGS # 刷新慢查询日志

刷新一般查询日志、慢查询日志或错误日志只是关闭并重新打开日志文件,如果要备份可以先重命名再执行刷新操作,一般查询日志、慢查询日志或错误日志文件名分别为:mysql.log 、mysql-slow.log 和 err.log。

要在运行时重命名一般、慢查询日志,要先禁用日志

SET GLOBAL general_log = 'OFF';
SET GLOBAL slow_query_log = 'OFF';

然后在bash命令行中去mv重命名,最后恢复日志

SET GLOBAL general_log = 'ON';
SET GLOBAL slow_query_log = 'ON';

这种方法各平台通用且不需要重启mysql服务器。

结束。

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

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

相关文章

JAVASE-医疗管理系统项目总结

文章目录 项目功能架构运行截图数据库设计设计模式应用单列设计模式JDBC模板模板设计模式策略模式工厂设计模式事务控制代理模式注解开发优化工厂模式 页面跳转ThreadLocal分页查询实现统计模块聊天 项目功能架构 传统的MVC架构,JavaFX桌面端项目,前端用…

R语言进行集成学习算法:随机森林

# 10.4 集成学习及随机森林 # 导入car数据集 car <- read.table("data/car.data",sep ",") # 对变量重命名 colnames(car) <- c("buy","main","doors","capacity","lug_boot","safety"…

ARM体系结构和接口技术(五)封装RCC和GPIO库

文章目录 一、RCC&#xff08;一&#xff09;思路1. 找到时钟基地址2. 找到总线的地址偏移&#xff08;1&#xff09;AHB4总线&#xff08;2&#xff09;定义不同GPIO组的使能宏函数&#xff08;3&#xff09;APB1总线&#xff08;4&#xff09;定义使能宏函数 二、GPIO&#x…

基于Java的汽车租赁管理系统设计(含文档、源码)

本篇文章论述的是基于Java的汽车租赁管理系统设计的详情介绍&#xff0c;如果对您有帮助的话&#xff0c;还请关注一下哦&#xff0c;如果有资源方面的需要可以联系我。 目录 摘 要 系统运行截图 系统总体设计 系统论文 资源下载 摘 要 近年来&#xff0c;随着改革开放…

React遍历tree结构,获取所有的id,切换自动展开对应层级

我们在做一个效果的时候&#xff0c;经常可能要设置默认展开多少的数据 1、页面效果&#xff0c;切换右侧可以下拉可切换展开的数据层级&#xff0c;仅展开两级等 2、树形的数据

C语言中常见库函数(1)——字符函数和字符串函数

文章目录 前言1.字符分类函数2.字符转换函数3.strlen的使用和模拟实现4.strcpy的使用和模拟实现5.strcat的使用和模拟实现6.strncmp的使用和模拟实现7.strncpy函数的使用8.strncat函数的使用9.strncmp函数的使用10.strstr的使用和模拟实现11.strtok函数的使用12.strerror函数的…

【文献阅读】Social Bot Detection Based on Window Strategy

Abstract 机器人发帖的目的是在不同时期宣传不同的内容&#xff0c;其发帖经常会出现异常的兴趣变化、而人类发帖的目的是表达兴趣爱好和日常生活&#xff0c;其兴趣变化相对稳定。提出了一种基于窗口策略&#xff08;BotWindow Strategy&#xff09;的社交机器人检测模型基于…

深入了解MySQL文件排序

数据准备 CREATE TABLE user_info (id bigint(20) NOT NULL AUTO_INCREMENT COMMENT ID,name varchar(20) NOT NULL COMMENT 用户名,age tinyint(4) NOT NULL DEFAULT 0 COMMENT 年龄,sex tinyint(2) NOT NULL DEFAULT 0 COMMENT 状态 0&#xff1a;男 1&#xff1a; 女,creat…

R语言实现对模型的参数优化与评价KS曲线、ROC曲线、深度学习模型训练、交叉验证、网格搜索

目录 一、模型性能评估 1、数据预测评估 2、概率预测评估 二、模型参数优化 1、训练集、验证集、测试集的引入 2、k折线交叉验证 2、网格搜索 一、模型性能评估 1、数据预测评估 ### 数据预测评估 #### 加载包&#xff0c;不存在就进行在线下载后加载if(!require(mlben…

NFS存储、API资源对象StorageClass、Ceph存储-搭建ceph集群和Ceph存储-在k8s里使用ceph(2024-07-16)

一、NFS存储 注意&#xff1a;在做本章节示例时&#xff0c;需要拿单独一台机器来部署NFS&#xff0c;具体步骤略。NFS作为常用的网络文件系统&#xff0c;在多机之间共享文件的场景下用途广泛&#xff0c;毕竟NFS配置方 便&#xff0c;而且稳定可靠。NFS同样也有一些缺点&…

《Towards Black-Box Membership Inference Attack for Diffusion Models》论文笔记

《Towards Black-Box Membership Inference Attack for Diffusion Models》 Abstract 识别艺术品是否用于训练扩散模型的挑战&#xff0c;重点是人工智能生成的艺术品中的成员推断攻击——copyright protection不需要访问内部模型组件的新型黑盒攻击方法展示了在评估 DALL-E …

昇思25天训练营Day18 - 基于MobileNetv2的垃圾分类

基于MobileNetv2的垃圾分类 本文档主要介绍垃圾分类代码开发的方法。通过读取本地图像数据作为输入&#xff0c;对图像中的垃圾物体进行检测&#xff0c;并且将检测结果图片保存到文件中。 1、实验目的 了解熟悉垃圾分类应用代码的编写&#xff08;Python语言&#xff09;&a…

[MySQL][复核查询][多表查询][自连接][自查询]详细讲解

目录 1.铺垫&基本查询回顾1.多表查询1.何为笛卡尔积&#xff1f;2.示例 2.自连接1.何为自连接&#xff1f;2.示例 3.子查询1.何为子查询&#xff1f;2.单行子查询3.多行子查询4.多列子查询5.在from子句中使用子查询6.合并查询 1.铺垫&基本查询回顾 前面讲解的MYSQL表的…

【深度学习入门篇 ⑨】循环神经网络实战

【&#x1f34a;易编橙&#xff1a;一个帮助编程小伙伴少走弯路的终身成长社群&#x1f34a;】 大家好&#xff0c;我是小森( &#xfe61;ˆoˆ&#xfe61; ) &#xff01; 易编橙终身成长社群创始团队嘉宾&#xff0c;橙似锦计划领衔成员、阿里云专家博主、腾讯云内容共创官…

运算符的使用

一、运算符介绍 运算符是一种特殊的符号&#xff0c;用以表示数据的运算、赋值和比较等 算术运算符赋值运算符比较运算符逻辑运算符位运算符 二、算术运算符 1、算术运算符是对数值类型的变量进行运算的&#xff0c;在程序中使用的非常多 2、算术运算符的使用 # 算术运算符…

Learning vtkjs之vtkSource

vtkSource的主要类型 Cone 锥体Circle 圆形Arrow 箭头ConcentricCylinder 同心圆Cube 方形Cursor3D 包围盒Cylinder 圆柱体Line 线Plane 平面Point 点Sphere 球不能调整center的source 目前整理的有下面几种source&#xff0c;对应有点类似threejs的mesh&#xff0c;通过一定的…

【.NET全栈】ASP.NET开发Web应用——站点导航技术

文章目录 前言一、站点地图1、定义站点地图文件2、使用SiteMapPath控件3、SiteMap类4、URL地址映射 二、TreeView控件1、使用TreeView控件2、以编程的方式添加节点3、使用TreeView控件导航4、绑定到XML文件5、按需加载节点6、带复选框的TreeView控件 三、Menu控件1、使用Menu控…

C语言指针超详解——进阶篇

C语言指针系列文章目录 入门篇 强化篇 进阶篇 文章目录 C语言指针系列文章目录1. 字符指针变量2. 数组指针变量2. 1 概念2. 2 数组指针变量的初始化 3. 二维数组传参的本质4. 函数指针变量4. 1 函数指针变量的创建4. 2 指针变量的使用4. 3 两个有趣的代码4. 3. 1 代码一4. 3. …

c++初阶知识——内存管理与c语言内存管理对比

目录 前言&#xff1a; 1.c&#xff0b;&#xff0b;内存管理方式 1.1 new和delete操作自定义类型 2.operator new与operator delete函数 2.1 operator new与operator delete函数 3.new和delete的实现原理 3.1 内置类型 3.2 自定义类型 new的原理 delete的原理 new…

完整教程 linux下安装百度网盘以及相关依赖库,安装完成之后启动没反应 或者 报错

完整教程 linux下安装百度网盘以及相关依赖库&#xff0c;安装完成之后启动没反应 或者 报错。 配置国内镜像源&#xff1a; yum -y install wget mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.bak wget -O /etc/yum.repos.d/CentOS-Base.repo ht…