当前位置: 首页 > news >正文

【数据库】Oracle内存结构与参数调优

Oracle内存结构与参数调优

    • Oracle 内存结构概览
    • oracle参数配置概览
      • 重要参数(系统运行前配置):
      • 次要参数(可在系统运行后再优化调整):
    • Oracle数据库服务器参数如何调整
      • OLTP内存分配
      • 操作系统核心参数配置
      • Disabling ASMM(禁用自动共享内存管理)
      • PGA(Program Global Area)
      • PGA_AGGREGATE_TARGET
      • PROCESSES
      • OPEN_CURSORS & SESSION_CACHED_CURSORS
      • 不用重新启动而修改初始参数文件
      • 启动大页(vm.nr_hugepages)

Oracle 内存结构概览

oracle 体系结构:
在这里插入图片描述
Oracle 内存结构:
在这里插入图片描述

  • System Global Area (SGA,系统全局区)
    • Share Pool (共享池)
    • Database Buffer Cache (数据库缓冲区缓存)
    • Redo Log Buffer (重做日志缓冲区)
    • Large Pool (大池)
    • Java Pool(Java池)
    • Streams Pool(流池)
    • Fixed SGA(固定SGA区域)
  • Program Global Area (PGA,程序全局区域)
    • User Global Area(UGA,用户全局区域)
      • Cursor Area(游标区)
      • User Session Data Storage_Area (用户会话数据存储区)
      • SQL Work Areas(SQL工作区)
        • 1). Sort Area(排序区)
        • 2). Hash Area(哈希区)
        • 3). Create Bitmap Area(位图索引创建区)
        • 4). Bitmap Merge Area (位图索引融合区)
    • Stack Space(堆栈空间)

oracle参数配置概览

重要参数(系统运行前配置):

带MAX的参数不能在线修改,需要重启后才生效,所以一定要提前规划好

  1. 内存管理参数:
    MEMORY_MAX_TARGET(11g): 定义了Oracle数据库实例允许使用的最大内存量,包括SGA和PGA。动态调整可用内存,无需重启实例。
    MEMORY_TARGET(11g): 指定数据库实例使用的内存目标,包括SGA和PGA。与MEMORY_MAX_TARGET结合使用,实现动态内存管理。

  2. SGA参数: SGA_TARGET(10g): 自动管理SGA的总内存大小,包括共享池、数据缓存等。通过自动调整子组件大小,适应变化的工作负载需求。

  3. PGA参数:PGA_AGGREGATE_TARGET(9i): 指定PGA的目标大小,由系统动态调整,根据工作负载需求自动分配内存给各个会话的PGA。

  4. 数据缓存参数:DB_CACHE_SIZE(10g): 指定数据库缓存的大小,用于缓存数据块,影响数据的读取性能。

  5. 共享池参数:SHARED_POOL_SIZE(10g): 定义共享池的大小,用于缓存SQL语句、PL/SQL块和执行计划。影响SQL执行性能。

  6. 连接和进程参数:
    PROCESSES(10g): 控制并发用户连接的最大数量。
    OPEN_CURSORS(10g): 设置一个会话可以打开的最大游标数。
    SESSION_CACHED_CURSORS(10g): 缓存在会话中的游标数,减少游标重新解析的开销。

在这里插入图片描述
在这里插入图片描述

次要参数(可在系统运行后再优化调整):

  1. 大池参数: LARGE_POOL_SIZE: 用于备份和并行操作的大型I/O的合并。适用于特定工作负载需求。

  2. Java虚拟机参数: JAVA_POOL_SIZE: 指定Java虚拟机使用的内存大小。影响Java相关操作的性能。

  3. 数据流参数: STREAMS_POOL_SIZE: 为Oracle Streams提供的内存池,用于处理数据流操作。

  4. 保留缓存参数: DB_KEEP_CACHE_SIZE: 为频繁访问的对象提供的保留缓存,提高这些对象的性能。

  5. 循环缓存参数:DB_RECYCLE_CACHE_SIZE: 为一次性或不经常访问的对象提供的循环缓存。

  6. 日志缓冲区参数: LOG_BUFFER: 控制数据库日志缓冲区的大小,适应不同的日志写入需求。

  7. 结果缓存参数: RESULT_CACHE_SIZE: 指定结果集缓存的大小,用于缓存SQL查询结果,提高重复查询性能。

  8. 自动PGA管理: PGA_AGGREGATE_LIMIT(11g R2以后):指定PGA的硬限制,防止PGA使用过多内存。

  9. 自动诊断和调整:
    ADDM(Automatic Database Diagnostic Monitor):自动数据库诊断监控,提供关于性能问题和建议的报告。
    AWR(Automatic Workload Repository):自动工作负载存储库,用于存储性能统计信息。

  10. SQL执行计划管理:
    OPTIMIZER_CAPTURE_SQL_PLAN_BASELINES:启用或禁用自动捕获SQL执行计划基线的功能。
    OPTIMIZER_USE_SQL_PLAN_BASELINES:启用或禁用使用SQL执行计划基线的功能。

  11. 自动调整:ADAPTIVE_PLAN_MANAGEMENT:启用或禁用自适应计划管理,允许数据库自动调整执行计划。

  12. 分区表和分区索引:
    PARTITION_TABLE:用于启用或禁用分区表。
    PARTITION_INDEX:用于启用或禁用分区索引。

  13. 数据压缩: COMPATIBLE:指定数据库版本,决定数据库是否支持特定的功能,例如表级数据压缩。

  14. 连接管理:SHARED_SERVERS:指定共享服务器的数量,用于连接管理。

  15. 并行执行:
    PARALLEL_DEGREE_POLICY:用于设置并行度策略,可以是 MANUAL(手动)或 AUTO(自动)。
    PARALLEL_MIN_SERVERSPARALLEL_MAX_SERVERS:用于设置最小和最大并行服务器的数量。

  16. 数据库缓存: DB_nK_CACHE_SIZE:根据不同块大小设置数据库缓存大小。

  17. RAC (Real Application Clusters) 参数:
    CLUSTER_DATABASE_INSTANCES:指定在RAC环境中的数据库实例数量。
    CLUSTER_DATABASE:用于启用或禁用RAC功能。

Oracle数据库服务器参数如何调整

以 IBM3850 服务器为例,在安装好oracle软件且数据库建好之后,投入使用之前需要调整好相关参数

  • CPU数量:4颗
  • 内存容量:64G
    请添加图片描述

OLTP内存分配

  1. 工作区(Work Area,排序、Hash Join、位图连接):6G
    在OLTP(联机事务处理)环境下,数据库工作区用于临时存放排序、哈希连接、位图连接等操作产生的中间数据。这里的6GB是指为这些操作预留的内存空间,确保在处理复杂查询时有足够的内存供运算使用,减少对磁盘I/O的需求,从而提高系统性能。

  2. Oracle服务器进程:一个连接 5M~10M,processes参数 * 10M,2000 * 10M=20G
    在Oracle数据库中,每个客户端连接都会对应一个服务器进程。这里假定每个服务器进程需要5MB至10MB的内存。如果数据库参数processes设置为可以同时接受2000个并发连接,那么所有服务器进程所需的总内存大约在10M * 2000 = 20GB左右。这部分内存是为了支持并发用户的活动,包括处理SQL查询、事务管理等操作。

  3. OS系统自用:6G
    这里的6GB内存是留给操作系统自己使用的,包括内核内存、缓存、以及其他系统组件的内存需求。这部分内存确保操作系统稳定运行,并可以处理各种系统级别的任务。

  4. SGA = 64 - 6G - 20G - 6G = 32G
    SGA(系统全局区)是Oracle数据库中用于存储共享数据结构的一个内存区域,包括数据缓冲区、重做日志缓冲区、共享池、大池等。根据给定的内存分配,64GB总内存减去工作区的6GB、服务器进程所需的20GB以及系统自用的6GB之后,剩余的32GB内存会被分配给SGA,以确保数据库的高效运作。

操作系统核心参数配置

cp /etc/sysctl.conf /etc/sysctl.conf.bak  # 将当前的sysctl配置文件做一个备份,以防万一需要回滚MemTotal=`grep MemTotal /proc/meminfo | awk '{print $2}'`  # 从/proc/meminfo中提取系统总的内存大小(以KB为单位)
PAGE_SIZE=`getconf PAGE_SIZE`  # 获取操作系统中一页内存的大小(以字节为单位)shmmax=`expr $MemTotal \* 1024`  # 根据总内存大小计算 shmmax 参数的最大值,此处将其设为总内存的四倍(转换为KB后再乘以1024转为字节)
shmall=`expr $shmmax / $PAGE_SIZE`  # 计算 shmall 参数的值,表示系统范围内共享内存段的总页数上限,这里的计算方法是将 shmmax 值除以一页的大小得出cat >> /etc/sysctl.conf << EOF  # 向sysctl配置文件追加以下配置项
fs.file-max = 6815744  # 设置系统允许的最大文件句柄数
kernel.sem = 10000 10240000 10000 1024  # 设置信号量参数,分别代表SEMMSL(一个信号集中的信号量最大数)、SEMMNS(系统信号量总数)、SEMOPM(一次操作中的信号量操作数)、SEMMNI(系统信号集总数)
kernel.shmmni = 4096  # 设置系统范围内共享内存段标识符的最大数目
kernel.shmall = $shmall  # 设置共享内存段页数上限,参考前面计算的结果
kernel.shmmax = $shmmax  # 设置共享内存段的最大大小,参考前面计算的结果
net.ipv4.ip_local_port_range = 9000 65500  # 设置本地TCP/UDP端口范围
net.core.rmem_default = 16777216  # 设置接收缓冲区的默认大小
net.core.rmem_max = 16777216  # 设置接收缓冲区的最大大小
net.core.wmem_max = 16777216  # 设置发送缓冲区的最大大小
net.core.wmem_default = 16777216  # 设置发送缓冲区的默认大小
fs.aio-max-nr = 6194304  # 设置异步I/O请求数量上限
vm.dirty_ratio=20  # 设置脏页比例阈值,当系统中脏页占总内存的比例超过这个值时,开始写入磁盘
vm.dirty_background_ratio=3  # 设置后台脏页刷新比率,后台线程开始刷新脏页前,系统中脏页占总内存的比例
vm.dirty_writeback_centisecs=100  # 设置脏页写回时间间隔(以百分秒计)
vm.dirty_expire_centisecs=500  # 设置脏页过期时间间隔(以百分秒计)
vm.swappiness=10  # 控制系统换出内存到硬盘的速度,值越低,尽量避免换出,值越高,倾向于换出
vm.min_free_kbytes=524288  # 设置系统试图保留的最小空闲内存(以KB为单位)
net.core.netdev_max_backlog = 30000  # 设置网络设备接收数据包的最大队列长度
net.core.netdev_budget = 600  # 设置每次软中断处理的数据包数量
net.ipv4.conf.all.rp_filter = 2  # 开启IPv4反向路径过滤(RFC 3704),防止IP欺骗攻击
net.ipv4.conf.default.rp_filter = 2  # 对新建的网络接口开启默认的反向路径过滤# vm.nr_hugepages =16384 # 若物理内存太小(<64G),则不需要开启大页,可以直接注释掉该行
# 注意:此处暂时先注释掉,后面启动大页会解释,需要根据实际需求和内存使用情况决定是否启用和设置正确的 HugePages 数量
EOF# 配置生效
sysctl -p  # 执行sysctl命令使得配置文件中所做的更改立即生效#kernel.shmall:系统任意时刻可以分配的所有共享内存段的总和的最大值(以页为单位),其值应不小于shmmax/page_size,推荐设置为物理内存大小除以分页大小。
#kernel.shmmax:单个内存段最大,设置为内存大小

Disabling ASMM(禁用自动共享内存管理)

  • SGA_TARGET 设置为0时,将禁用自动调优
  • 自动调优参数设置为当前大小
  • SGA的大小作为一个整体不受影响

在这里插入图片描述

PGA(Program Global Area)

PGA是Oracle数据库中每个服务器进程独有的内存区域,用于存储会话数据、排序区、临时变量以及其他与特定会话相关的数据结构。

PGA_AGGREGATE_TARGET

  • 在OLTP系统中,典型PGA内存设置应该是总内存(物理内存)的较小部分(例如20%),剩下80%分配给SGA 。OLTP:PGA_AGGREGATE_TARGET = (total_mem * 80%) * 20%
  • 在DSS系统中,由于会运行一些很大的查询,典型的PGA内存最多分配70%的内存。DSS:PGA_AGGREGATE_TARGET = (total_mem * 80%) * 50%
  • 设置 PGA 自动分配
alter system set workarea_size_policy = auto scope = both;
alter system set pga_aggregate_target = 2048M scope = both;
show parameter pga
show parameter area
show parameter work
  • 监控 PGA
select * from v$pgastat;
# 看 over allocation count(排序时,PGA不够用时需要换页,这个值就是换页次数):如果=0 就正常 PGA够用;若 >0 则PGA不够用需要调整

PROCESSES

  • 在Oracle数据库中,设置参数 PROCESSES 和 SESSIONS 是非常重要的,以确保系统能够处理足够的并发连接。这只是一个基本的起点,实际的设置应该根据你的具体应用、系统硬件和负载情况来调整。建议在设置参数之前先进行性能测试,确保系统能够处理预期的并发连接数。
    典型的设置是:
    10g: sessions = processes + 10% * processes + 5
    11g+: sessions = processes + 15 % * processes + 22
  • 查看内存使用情况
select p.spid from v$session s,v$process p where p.addr=s.paddr and s.sid in (select sid from v$mystat where rownum=1);
select pga_used_mem,pga_alloc_mem,pga_freeable_mem from v$process where spid = &spid;
  • Processes参数优化
create pfile='/tmp/pfileORCL_20240307.ora' from SPFILE; --备份配置文件
alter system set processes = 200 scope = spfile; 

OPEN_CURSORS & SESSION_CACHED_CURSORS

  • OPEN_CURSORS
    • 指定了保存(打开)用户语句的专用区域的大小。如果获得“ORA-01000:maximun open cursors exceeded” 错误,则可能需要增大该参数,但是要确保关闭不在需要的游标。
    • 如果 OPEN_CURSORS 设置得过高,则有时也会造成问题:ORA-4031错误(共享池)
  • SESSION_CACHED_CURSORS
    • 不要将参数 SESSION_CACHED_CURSORS 设置的和 OPEN_CURSORS 一样高,否则就可能产生 ORA-4031 或 ORA-7445 错误(软软解析)

不用重新启动而修改初始参数文件

  1. spfile<SID>.ora (大部分不需要重启)
  2. spfile.ora (用的少)
  3. init<SID>.ora (一定要重启)
  4. v$parameter 视图
    ISSES_MODIFIABLE 表名拥有 ALTER SESSION 特权的用户是否可以修改这个参数
    ISSYS_MODIFIABLE 表名拥有 ALTER SYSTEM 特权的用户是否可以修改这个参数

启动大页(vm.nr_hugepages)

什么是大页?
在操作系统层面,默认情况下内存页大小通常为4KB。大页是一种内存管理机制,将标准内存页尺寸增大,例如从4KB改为2MB。使用大页可以减少TLB(Translation Lookaside Buffer)未命中的情况,从而降低页交换频率和I/O开销,提高系统的性能,特别是在大规模内存管理和Oracle数据库等场景下。

什么时候需要启动大页?
当服务器物理内存>=64GB,启用大页可以带来显著的性能提升。

如何启动大页?

  1. 关闭Oracle Database中的AMM(Automatic Memory Management)
    如果尚未手动管理内存,请确保禁用自动内存管理功能。

  2. 计算hugepages的大小
    根据SGA_MAX_SIZE的值来决定hugepages的数量。hugepages的总量应略大于SGA的需求量,同时也要注意避免过大导致内存浪费。例如,如果SGA_MAX_SIZE为32G,而每个大页是2MB,那么至少需要16384个大页(32GB / 2MB)。

  3. 设置hugepages
    编辑内核参数文件/etc/sysctl.conf,加入以下行:

    vi /etc/sysctl.conf
    vm.nr_hugepages = 16384 #<计算得出的大页数量>
    

    然后执行 sysctl -p 命令使更改生效。

  4. 设置用户进程内存锁定限制
    /etc/security/limits.conf文件中为Oracle数据库用户设置内存锁定限制,确保其能够锁定足够大的内存以支持大页。

    [root@mydb ~]# vi /etc/security/limits.conf
    oracle soft memlock 2056000
    oracle hard memlock 2056000
    
  5. 重启数据库
    重启Oracle数据库以便新的内存设置生效。

  6. 查看大页使用情况
    使用如下命令实时监控大页的使用情况:

    [root@mydb ~]# watch -n1 'cat /proc/meminfo | grep -i HugePages'
    
  7. 设置pre_page_sga参数
    需要在数据库实例启动前预分配并初始化SGA,以利用大页优化性能:

    alter system set pre_page_sga = true scope = spfile;
    

参考链接:

  • Oracle 23c 官方文档
  • 【Oracle】内存结构详解(万字长文,建议收藏,蚕食为佳)

相关文章:

【数据库】Oracle内存结构与参数调优

Oracle内存结构与参数调优 Oracle 内存结构概览oracle参数配置概览重要参数&#xff08;系统运行前配置&#xff09;:次要参数&#xff08;可在系统运行后再优化调整&#xff09;: Oracle数据库服务器参数如何调整OLTP内存分配操作系统核心参数配置Disabling ASMM&#xff08;禁…...

PS学习-抠图-蒙版-冰块酒杯等透明物体

选中图&#xff0c;ctrlA 全选 ctrlC复制 创建一个蒙版图层 选中蒙版Alt 点击进入 ctrlv 复制 ctrli 反转 原图层 ctrldelete填充为白色 添加一个背景&#xff0c;这个方法通用 首选创建一个 拖到最底部 给它填充颜色 这个可能是我图片的原因。视频是这样做的...

绝赞春招拯救计划 -- 操作系统,组成原理,计网

进程和线程 进程 一个在内存中运行的应用程序。每个进程都有自己独立的一块内存空间&#xff0c;一个进程可以有多个线程 线程 进程中的一个执行任务&#xff08;控制单元&#xff09;&#xff0c;负责当前进程中程序的执行。一个进程至少有一个线程&#xff0c;一个进程可以…...

c语言:于龙加

于龙加 任务描述 于龙同学设计了一个特别的加法规则&#xff0c;加法被重新定义了&#xff0c;我们称为于龙加。 两个非负整数的于龙加的意义是将两个整数按前后顺序连接合并形成一个新整数。 于龙想编程解决于龙加问题&#xff0c;可是对下面的程序他没有思路&#xff01; …...

AcWing 790:数的三次方根 ← 浮点数二分

【题目来源】https://www.acwing.com/problem/content/792/【题目描述】 给定一个浮点数 n&#xff0c;求它的三次方根。【输入格式】 共一行&#xff0c;包含一个浮点数 n。【输出格式】 共一行&#xff0c;包含一个浮点数&#xff0c;表示问题的解。 注意&#xff0c;结果保留…...

【LLM】LLama2模型(RMSNorm、SwiGLU、RoPE位置编码)

note 预训练语言模型除了自回归&#xff08;Autoregressive&#xff09;模型GPT&#xff0c;还有自编码模型&#xff08;Autoencoding&#xff09;BERT[1]、编-解码&#xff08;Encoder-Decoder&#xff09;模型BART[67]&#xff0c;以及融合上述三种方法的自回归填空&#xf…...

【力扣白嫖日记】1934.确认率

前言 练习sql语句&#xff0c;所有题目来自于力扣&#xff08;https://leetcode.cn/problemset/database/&#xff09;的免费数据库练习题。 今日题目&#xff1a; 1934.确认率 表&#xff1a;Signups 列名类型user_idinttime_stampdatetime User_id是该表的主键。每一行都…...

TinTin Web3 动态精选:以太坊坎昆升级利好 Layer2,比特币减半进入倒计时

TinTin 快讯由 TinTinLand 开发者技术社区打造&#xff0c;旨在为开发者提供最新的 Web3 新闻、市场时讯和技术更新。TinTin 快讯将以周为单位&#xff0c; 汇集当周内的行业热点并以快讯的形式排列成文。掌握一手的技术资讯和市场动态&#xff0c;将有助于 TinTinLand 社区的开…...

PCL 高斯投影反算:高斯投影坐标转大地坐标(C++详细过程版)

目录 一、算法原理二、代码实现三、结果展示四、测试数据PCL 高斯投影反算:高斯投影坐标转大地坐标(C++详细过程版)由CSDN点云侠原创。如果你不是在点云侠的博客中看到该文章,那么此处便是不要脸的爬虫。 一、算法原理...

解决:IDEA编译Java程序时报编译失败

1、问题展示&#xff1a; 2、解决方法&#xff1a;...

vue+vite根据版本号清空用户浏览器缓存

项目生产环境发布新版本之后&#xff0c;用户可能会因为一些本地缓存的数据不一样而导致页面报错。这时候可以根据版本号去清空用户缓存。 1、在package.json文件中有一个管理版本号属性&#xff1a;version&#xff0c;在每次打包部署之前修改当前版本号。 2、在main.js文件中…...

AXI CANFD MicroBlaze 测试笔记

文章目录 前言测试用的硬件连接Vivado 配置Vitis MicroBlaze CANFD 代码测试代码测试截图Github Link 前言 官网: CAN with Flexible Data Rate (CAN FD) (xilinx.com) 特征: 支持8Mb/s的CANFD多达 3 个数据位发送器延迟补偿(TDC, transmitter delay compensation)32-deep T…...

操作系统——cpu、内存、缓存介绍

一、内存是什么 内存就是系统资源的代名词&#xff0c;它是其他硬件设备与 CPU 沟通的桥梁&#xff0c; 计算机中的所有程序都在内存中运行。其作用是暂时存放CPU的运算数据&#xff0c;以及与硬盘交换的数据。也是相当于CPU与硬盘沟通的桥梁。只要计算机在运行&#xff0c;CP…...

【理解机器学习算法】之岭回归Ridge - L2 Rgularization

Ridge 回归&#xff08;Ridge Regression&#xff09;也称作岭回归或脊回归&#xff0c;是一种专用于共线性数据分析的有偏估计回归方法。在多元线性回归中&#xff0c;如果数据集中的特征&#xff08;自变量&#xff09;高度相关&#xff0c;也就是说存在共线性(Multicollinea…...

【Linux进程状态】

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 目录 前言 一、直接谈论Linux的进程状态 看看Linux内核源代码怎么说 1.1、R状态 -----> 进程运行的状态 1.2、S状态 -----> 休眠状态(进程在等待“资源”就绪) 1.3、T状…...

【RS422】基于未来科技FT4232HL芯片的多波特率串口通信收发实现

功能简介 串行通信接口常常用于在计算机和低速外部设备之间传输数据。串口通信存在多种标准&#xff0c;以RS422为例&#xff0c;它将数据分成多个位&#xff0c;采用异步通信方式进行传输。   本文基于Xilinx VCU128 FPGA开发板&#xff0c;对RS422串口通信进行学习。   根…...

Internet协议的安全性

Internet协议的安全性 文章目录 Internet协议的安全性1. 网络层1. IP*62. ARP*33. ICMP * 3 2. 传输层协议1. TCP1. * SYN-Flood攻击攻击检测* 防御 2. TCP序号攻击攻击 3. 拥塞机制攻击 2. UDP 3. 应用层协议1. DNS攻击*3防范*3: 2. FTP3. TELNET: 改用ssh4. 电子邮件1. 攻击2…...

LeetCode每日一题——移除元素

移除元素OJ链接&#xff1a;27. 移除元素 - 力扣&#xff08;LeetCode&#xff09; 题目&#xff1a; 思路&#xff1a; 题目给定要求只能使用O(1)的额外空间并且原地修改输入数组&#xff0c;然后返回移除后的数组行长度。那 么我们就可以确我没有办法建立临时的数组存放我…...

vue3之自定义指令

除了 Vue 内置的一系列指令 (比如 v-model 或 v-show) 之外&#xff0c;Vue 还允许你注册自定义的指令。自定义指令主要是为了重用涉及普通元素的底层 DOM 访问的逻辑。 写法 1. 没有使用 <script setup>的情况下 export default {setup() {/*...*/},directives: {// 在…...

MySQL语法分类 DQL(5)分组查询

为了更好的学习这里给出基本表数据用于查询操作 create table student (id int, name varchar(20), age int, sex varchar(5),address varchar(100),math int,english int );insert into student (id,name,age,sex,address,math,english) values (1,马云,55,男,杭州,66,78),…...

C++程序设计-练手题集合【期末复习|考研复习】

前言 总结整理不易&#xff0c;希望大家点赞收藏。 给大家整理了一下C程序设计中的练手题&#xff0c;以供大家期末复习和考研复习的时候使用。 C程序设计系列文章传送门&#xff1a; 第一章 面向对象基础 第四/五章 函数和类和对象 第六/七/八章 运算符重载/包含与继承/虚函数…...

文件上传漏洞------一句话木马原理解析

目录 一、实验环境 二、实验过程 构造一句话木马 一句话木马的使用: 木马原理解析: 一、实验环境 小皮面板搭建:upload-labs靶场 二、实验过程 构造一句话木马 这是一个最简单的一句话木马&#xff0c;我们用GET传参接受了两个参数&#xff0c;其最终目的是构造出:ass…...

Openfeign使用教程(带你快速体验Openfeign的便捷)

文章摘要 本文中将教会您如何快速使用Openfeign&#xff0c;包括Opengfeign的基础配置、接口调用、接口重试、拦截器实现、记录接口日志信息到数据库 文章目录 文章摘要一、Openfeign初步定义二、Openfeign快速入门1.引入maven坐标2.启动类增加EnableFeignClients注解3.定义fei…...

【leetcode】相同的树➕对称二叉树➕另一棵树的子树

大家好&#xff0c;我是苏貝&#xff0c;本篇博客带大家刷题&#xff0c;如果你觉得我写的还不错的话&#xff0c;可以给我一个赞&#x1f44d;吗&#xff0c;感谢❤️ 目录 一. 相同的树二. 对称二叉树三. 另一棵树的子树 一. 相同的树 点击查看题目 思路: bool isSameTree(…...

uni-app 安卓手机判断是否开启相机相册权限

// 安卓相机权限 androidCameraPermiss(index){ plus.android.requestPermissions([android.permission.CAMERA],(e) > { if (e.deniedAlways.length > 0) { this.androidAuthCamera false …...

GPT实战系列-LangChain构建自定义Agent

GPT实战系列-LangChain构建自定义Agent LangChain GPT实战系列-LangChain如何构建基通义千问的多工具链 GPT实战系列-构建多参数的自定义LangChain工具 GPT实战系列-通过Basetool构建自定义LangChain工具方法 GPT实战系列-一种构建LangChain自定义Tool工具的简单方法 GPT…...

uniapp-vue3 项目初始化集成配置【开箱即用】

地址 https://gitee.com/charrie/vue3-uniapp-init 部分截图展示 技术说明 采用vue3viteuniapp技术栈&#xff0c;setup语法糖编码方式使用完全免费的sard-uniapp组件库引入unocss量子化样式引擎&#xff0c;动态css不用自己写样式&#xff0c;引用class即可&#xff0c;降低…...

【Qt】使用Qt实现Web服务器(一):QtWebApp介绍、演示

1、简介 QtWepApp是使用Qt实现的Web服务器库,虽然名字中有“App”但是它的确是一个lib库,编译生产的是libQtWebAppd.so 作者开发QtWepApp是从 Java Servlet 获得的灵感,本人不懂Java,对本人没有帮助。 QtWepApp是一个跨平台的项目,适用于:Linux、Windows、Mac OS 和Qt…...

SQLiteC/C++接口详细介绍之sqlite3类(八)

返回目录&#xff1a;SQLite—免费开源数据库系列文章目录 上一篇&#xff1a;SQLiteC/C接口详细介绍之sqlite3类&#xff08;七&#xff09; 下一篇&#xff1a; SQLiteC/C接口详细介绍之sqlite3类&#xff08;八&#xff09;&#xff08;暂未发表&#xff09; 24.sqlite3_cr…...

面视题之——悲观锁和乐观锁

面视题之——悲观锁和乐观锁 概念 悲观锁 悲观锁是在执行线程任务时直接加锁&#xff0c;以确保同一时刻只有一个线程可以访问共享资源。在使用悲观锁时&#xff0c;每次访问共享资源时都会尝试获取锁&#xff0c;如果锁已经被其他线程占用&#xff0c;当前线程就会被阻塞&a…...