DBA_Oracle基本体系内存和进程结构(概念)

简介: 2014-08-05 Created By BaoXinjian 一、摘要 1. Oracle的内存结构 内存结构式Oracle数据库体系中最为重要的一部分,内存也是印象数据库性能的第一因素 分类 系统全局区SGA (System Global Area) 程序全局区PGA (...

 2014-08-05 Created By BaoXinjian

一、摘要


1. Oracle的内存结构

  • 内存结构式Oracle数据库体系中最为重要的一部分,内存也是印象数据库性能的第一因素
  • 分类
    • 系统全局区SGA (System Global Area)
    • 程序全局区PGA (Program Gobal Area)
    • 用户全局区UGA (User Global Area)

2. Oracle进程结构

进程是操作系统中的一种机制,它可执行一系列的操作步骤,操作系统会使用多个进程来执行Oracle的不同部分,并且对每个连接的用户都有一个进程

(1). 用户进程

(2). Oracle进程

  • 服务器进程
  • 后台进程
    • PMON(进程监控进程)
    • SMON(系统监控进程)
    • DBWR(数据库写入进程)
    • LGWR(日志写入进程)
    • ARCH(归档进程)
    • CKTP(检查点进程)
    • CJQO(作业队列协调器进程)
    • RECO(恢复进程)

3. Oracle易混淆概念

  • 实例和数据
  • 用户和模式
  • 用户和角色

 

二、内存结构


1. 系统全局区SGA (System Global Area)

(1). 概念:是所有数据都可以访问的实例的共享区, 数据块、事物处理日志、数据字典信息等都存储在SGA中

(2). 详解:其中每个实例都只能有一个系统全局区,它是不同用户进程与服务进程进行通信的中心。数据库的各种操作主要在系统全局区进行。

(3). SGA所包含的数据:

  • 缓存数据块
  • 在数据库上执行的SQL语句
  • 用户执行的存储过程、函数和触发器

(4). SGA的组成:

  • DB高速缓存
    • 数据高速缓存database buffer cache (DBC)
    • DBC的作用:保存最近从数据文件中读取的数据块,其中的数据被所有用户共享
    • 影响DBC的两个参数: DB_BLOCK_SIZE和DB_BLOCK_BUFFERS
  • 共享池
    • 共享池保存了最近执行的SQL语句、PLSQL程序和数据字典信息,是对SQL语句和PLSQL程序进行预防解析、编译执行的内存去
  • 重做日志缓存
    • 重做日志高速缓存就是存储重做记录的缓存
    • 重做记录并不直接写入磁盘的重做日志文件,而是先写入重做的日志缓存
    • 当重做日志缓存中的重做记录达到一定的数量时,由LGWR进程写入重做日志
  • 大型池
    • 大型池用于大内存操作提供相对独立的内存空间那件
    • 需要大型池的操作有:数据库备份和恢复,用于共享服务进程的会话内存(大量排序的SQL语句),并行化数据操作

2. 程序全局区PGA (Program Gobal Area)

(1). 概念: 是一类没有共享的内存,专用于特定的服务器进程,并只能够由这个进程访问

(2). PGA的组成

  • 排序区
    • 保存执行order by、group by等包含排序操作的SQL语句时所产生的临时数据
  • 会话区
    • 保存所具有的权限、角色、性能统计信息
  • 游标区
    • 保存执行带有游标的PLSQL语句所产生的临时数据
  • 堆栈区
    • 保存会话中绑定的变量,会话变量以及SQL语句运行的内存结构信息

3. 用户全局区UGA (User Global Area)

(1).概念: 这个内存区域为我们用户进程存储了会话状态

 

三、进程结构


1. 用户进程

2. Oracle进程

(1). 服务器进程

(2). 后台进程

  • PMON (进程监控进程)
    • 用以监控服务器进程,以确保能否销毁发生损坏或者出现故障的进程,释放他们的资源
    • 在主机操作系统上使用Oracle监听器注册数据库服务器
  • SMON (系统监控进程)
    • 在实例出现故障的情况下,SMON负责重新启动系统,执行崩溃恢复
    • SMON将会清楚已经分配但还没有被释放的临时段
    • SMON也会在表空间管理中执行盘区结合
  • DBWR (数据库写入进程)
    • 该进程将缓存区的用户所使用的数据写入数据文件
    • 使用户进程总是可以得到未用的缓存区
  • LGWR (日志写入进程)
    • 是向在线重做日志文件中所记录的所有数据库的已提交事务
    • 日志写入进程会在以下四种情况执行写入操作
      • 事务处理进程提交
      • 重做日志缓存已填充1/3
      • 重做日志缓存中的数据量达到1MB
      • 每3秒时间
  • ARCH (归档进程)
    • 将重做日志事务变化写入归档日志
  • CKTP (检查点进程)
    • 在检查点出现时,对全部数据文件的标题进行修改
  • CJQO (作业队列协调器进程)
    • 在Oracle中规划将要再数据后台运行的进程或者作业
  • RECO (恢复进程)
    • 在分布式数据库环境中恢复进程自动恢复失败的分布式事务

 

四、概念区分


1. 实例和数据库

(1). 实例 (进程+内存结构)

  • Oracle实例时SGA和后台进程的组合
  • 数据库只是调入到实例所包含的内存和进程中,才可以使用

(2). 数据库 (数据文件+重做文件+控制文件+临时文件)

(3). 两者区别

  • Oracle实例时SGA(系统全局区)和一组后台进程的组合
  • Oralce数据库时指运行数据库所有的所有数据库文件
  • Oracle服务启动时先启动实例,然后转载数据库文件,即装在数据库

2. 用户和模式

(1). 用户:

  • 能够唯一标识一组信任凭着的名称和密码组合
  • Oracle中的用户其实就是用于登录Oracle命名账号
  • 用户可以拥有自己的数据对象

(2). 模式

  • 是用户所创建的数据库对象的总称
  • 模式中的对象包括:表、视图、索引、同义词、序列、过程、程序包

(3). 两者关系

  • 模式本身不是对象,模式只是一个用来描述特定用户的对象集合的属于
  • 模式和用户是一一对应的关系

3. 用户和角色

(1). 用户

用户就是用户登录Oracle的命名账号

例如:sys, system, scott, hr

(2). 角色

角色就是一组相关权限的命名结合

例如:connect, resource, DBA

(3). 两者关系

角色是一组权限的组合,我么将角色付给用户,从而让用户拥有角色所拥有的权限

 

 

Thanks and Regards

ERP技术讨论群: 288307890
技术交流,技术讨论,欢迎加入
Technology Blog Created By Oracle ERP - 鲍新建
相关实践学习
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
相关文章
|
Arthas 存储 算法
深入理解JVM,包含字节码文件,内存结构,垃圾回收,类的声明周期,类加载器
JVM全称是Java Virtual Machine-Java虚拟机JVM作用:本质上是一个运行在计算机上的程序,职责是运行Java字节码文件,编译为机器码交由计算机运行类的生命周期概述:类的生命周期描述了一个类加载,使用,卸载的整个过类的生命周期阶段:类的声明周期主要分为五个阶段:加载->连接->初始化->使用->卸载,其中连接中分为三个小阶段验证->准备->解析类加载器的定义:JVM提供类加载器给Java程序去获取类和接口字节码数据类加载器的作用:类加载器接受字节码文件。
1048 55
|
存储 Linux API
【Linux进程概念】—— 操作系统中的“生命体”,计算机里的“多线程”
在计算机系统的底层架构中,操作系统肩负着资源管理与任务调度的重任。当我们启动各类应用程序时,其背后复杂的运作机制便悄然展开。程序,作为静态的指令集合,如何在系统中实现动态执行?本文带你一探究竟!
【Linux进程概念】—— 操作系统中的“生命体”,计算机里的“多线程”
|
9月前
|
存储 监控 算法
基于 Go 语言跳表结构的局域网控制桌面软件进程管理算法研究
针对企业局域网控制桌面软件对海量进程实时监控的需求,本文提出基于跳表的高效管理方案。通过多级索引实现O(log n)的查询、插入与删除性能,结合Go语言实现并发安全的跳表结构,显著提升进程状态处理效率,适用于千级进程的毫秒级响应场景。
325 15
|
Unix Linux
对于Linux的进程概念以及进程状态的理解和解析
现在,我们已经了解了Linux进程的基础知识和进程状态的理解了。这就像我们理解了城市中行人的行走和行为模式!希望这个形象的例子能帮助我们更好地理解这个重要的概念,并在实际应用中发挥作用。
276 20
|
存储 NoSQL Redis
阿里面试:Redis 为啥那么快?怎么实现的100W并发?说出了6大架构,面试官跪地: 纯内存 + 尖端结构 + 无锁架构 + EDA架构 + 异步日志 + 集群架构
阿里面试:Redis 为啥那么快?怎么实现的100W并发?说出了6大架构,面试官跪地: 纯内存 + 尖端结构 + 无锁架构 + EDA架构 + 异步日志 + 集群架构
阿里面试:Redis 为啥那么快?怎么实现的100W并发?说出了6大架构,面试官跪地: 纯内存 + 尖端结构 +  无锁架构 +  EDA架构  + 异步日志 + 集群架构
|
存储 Linux Shell
Linux进程概念-详细版(二)
在Linux进程概念-详细版(一)中我们解释了什么是进程,以及进程的各种状态,已经对进程有了一定的认识,那么这篇文章将会继续补全上篇文章剩余没有说到的,进程优先级,环境变量,程序地址空间,进程地址空间,以及调度队列。
247 0
|
Linux 调度 C语言
Linux进程概念-详细版(一)
子进程与父进程代码共享,其子进程直接用父进程的代码,其自己本身无代码,所以子进程无法改动代码,平时所说的修改是修改的数据。为什么要创建子进程:为了让其父子进程执行不同的代码块。子进程的数据相对于父进程是会进行写时拷贝(COW)。
310 0
|
存储 Linux 调度
【Linux】进程概念和进程状态
本文详细介绍了Linux系统中进程的核心概念与管理机制。从进程的定义出发,阐述了其作为操作系统资源管理的基本单位的重要性,并深入解析了task_struct结构体的内容及其在进程管理中的作用。同时,文章讲解了进程的基本操作(如获取PID、查看进程信息等)、父进程与子进程的关系(重点分析fork函数)、以及进程的三种主要状态(运行、阻塞、挂起)。此外,还探讨了Linux特有的进程状态表示和孤儿进程的处理方式。通过学习这些内容,读者可以更好地理解Linux进程的运行原理并优化系统性能。
542 4
|
存储 算法 数据处理
进程基础:概念、状态与生命周期
进程是操作系统进行资源分配和调度的基本单位,由程序段、数据段和进程控制块(PCB)组成。线程是进程中更小的执行单元,能独立运行且共享进程资源,具有轻量级和并发性特点。进程状态包括就绪、运行和阻塞,其生命周期分为创建、就绪、运行、阻塞和终止阶段。
1033 2
|
SQL 存储 缓存
【赵渝强老师】达梦数据库的内存结构
本文介绍了达梦数据库管理系统的内存结构,包括内存池、缓冲区、排序区和哈希区。内存池分为共享内存池和运行时内存池,能够提高内存申请与释放效率,并便于监控内存使用情况。缓冲区涵盖数据缓冲区、日志缓冲区、字典缓冲区和SQL缓冲区,用于优化数据读写和查询性能。排序区和哈希区分别提供排序和哈希连接所需的内存空间,通过合理配置参数可提升系统效率。文内附有具体配置示例及视频讲解,帮助用户深入理解达梦数据库的内存管理机制。
537 0

热门文章

最新文章

推荐镜像

更多