`
daniel.wuz
  • 浏览: 103316 次
  • 性别: Icon_minigender_1
  • 来自: 纽约
最近访客 更多访客>>
社区版块
存档分类

oracle学习笔记1

阅读更多

随便记记,用以备忘

oracle结构组件
1.oracle由实例和database组成
database是物理的存在,是数据的集合
实例是操作oracledatabase的异种手段

我们发出的command实际上是在内存完成的,oracle先把数据从物理上读到内存中
在内存中进行改变,再写回database中去
所有这些动作的完成都依赖实例提供的内存结构和后台进程协作完成。

如图:

SGA的全称 System global area
 包括三部分:
 share pool,database buffer cache ,redo log Buffer cache
实例的后台进程包括:
PMON,SMON,DBWR,LGWR,CKPT,Others

物理的存在database:
体现在操作系统就是实实在在的物理文件
包括:
数据文件,控制文件,redo日志文件(必须三类)
参数的物理文件,口令物理文件,以及归档物理文件。(并非必须的)

用户进程和服务器进程

用户启动某个工具(如sqlplus)实际上就是启动了一个用户进程,必须通过某种方式建立与数据库的连接.当建立链接口,oracle后台就会
启动一个server process.我们发出的command就是server process通过instance进行改变的.

oracle的启动过程
startup nomount;    启动一个实例
alter database mount;  读取控制文件
alter database open;  database物理文件,对数据文件和控制文件进行一致性验证,校验其状态

instance由两部分组成:
memory structure和background process.

database由三类文件组成:
data file 数据文件
log file日志文件
control file控制文件

任何时候一个instance只能操作一个database ,但是一个database可以由多个实例操作

命令: show sga 显示一些内存结构信息
    set wrap off
    set linesize 200
    select * from v$bgprocess 所有可能会使用到的后台进程,并不是所有后台进程在
    oracle中都是必须的
    必须的有:***,rec0(实在分布式transaction的recovery)
   
database的物理结构
control files ,data files ,redo log files
可能有多个
redo log files最少都有两个
select * from v$controlfile;
select * from v$datafile;
select * from v$logfile;//查看在线日志

oracle的内存结构:
包括:系统全局区(SGA,可共享)和程序全局区(PGA,不可共享,依据是否共享服务器,pga中内容不一样);

SGA包括:
shared pool
database buffer cache写到数据文件中
redo log buffer对数据库的操作,最终会写到online log文件中。
其他结构:eg:large pool,java pool
查看sga缓冲区参数的命令:show parameter shared
          show parameter db_cache
          show parameter log
         
oracle9i后,SGA缓存区大小可以动态调整,三个缓存区内存总和SGA_MAX_SIZE。
命令:show parameter sga

alter system set db_cache_size = 64m 如果内存不够,该操作会失败
(alter session set mls_language=american);

Share pool:
alter system set shared_pool_size = 64m;
由两部分组成:library cache和data dictionary cache
library cache包含最近经常使用的sql,pl/sql的一些执行计划,编译数及文本,主要是提高代码共享
对于性能调整很重要的一方面就是必须给library cache提供充足的内存
要求library cache的命中率达到99%以上,结构上包含两部分:shared sql area 和shared plsql area


数据字典包含用户权限,访问权限对象,database的结构信息,dictionary cache=row cache
包含数据对象的结构信息,eg:select * from authors;
首先oracle会验证authors数据对象是否存在
其次进行语法分析
还要验证是否有权限
这些信息均属于数据字典的内容

 

以上两部分都不可以单独定义,必须透过share pool加以定义

oracle9i中加入了不同块大小的定义参数,show parameter db
9i以前的:db_block_buffers
9i以后的:db_cache_size
具体使用多大内存的块,oracle会根据读取的数据取对应的块,可能是2k,4k,8k,16k,32k;
在$ORACLE_HOME/admin/pfile/init.ora文件中,db_block_size=8192指定了初始安装时的块大小

动态调整database cache的命令:alter system set db_cache_size = 96m
oracle9i中,可以通过 db_cache_advice自动设置share pool的分配
alter system set db_cache_advice=on;

 

redo buffer cache
show parameter log_buffer;要求不大


large pool buffer共享服务时,用户信息(UGA)会放到large pool里面

java pool安装或者使用java时会用到.

PGA针对服务器进程而保留的内存区域

process structure进程信息
1.用户进程(不可以直接操作数据库)
2.服务器进程(操作数据库)
3.后台进程


查看oracle归档模式信息:archivae log list

后台进程:
dbwn:database writer
log writer:lgwr,把redo buffer中的信息写到日志文件
system monitor:smon
pmon:process monitor进程监控进程
ckpt:check point实现同步的
ARcn:归档日志的进程,用来自动备份在线日志

 

 

 
分享到:
评论

相关推荐

    Oracle学习笔记1.docx

    Oracle 学习笔记 1 本文档涵盖了 Oracle 学习的基础知识,包括客户端工具、用户管理、表结构、SELECT 语句、DISTINCT 操作、WHERE 子句、ORDER BY 子句和 SQL 函数等内容。 客户端工具 Oracle 提供了多种客户端...

    Oracle学习笔记 PDF

    ### Oracle学习笔记知识点详解 #### 一、Oracle简介 Oracle是一家知名的软件公司,以其数据库管理系统闻名全球。该公司成立于1977年,总部位于美国加利福尼亚州。Oracle不仅提供数据库解决方案,还涉及中间件、...

    Oracle学习笔记1.doc

    ### Oracle学习笔记知识点详解 #### 一、Oracle的卸载步骤及注意事项 ##### 软件环境 - **操作系统:** Windows XP - **Oracle版本:** 8.1.7 - **安装路径:** C:\ORACLE ##### 卸载方法 1. **停止Oracle服务:** -...

    Oracle学习笔记

    Oracle学习笔记 Oracle学习笔记是李兴华老师编写的Oracle从入门到精通的学习笔记,涵盖了 Oracle 的多表查询、连接、组函数和分组统计等知识点。在本篇笔记中,李兴华老师详细介绍了多表查询的基本语法、左右连接...

    Oracle学习笔记精华版

    Oracle学习笔记精华版是针对数据库管理系统Oracle的一份重要学习资源,涵盖了从基础概念到高级特性的全面知识。Oracle,作为全球广泛使用的大型企业级数据库系统,对于IT专业人员尤其是数据库管理员(DBA)来说,是...

    Oracle学习笔记.doc

    Oracle学习笔记 以下是我这一周学习oracle整理的笔记,包括课堂的内容和自己看额外看的视频补充的一些内容,基本上囊括了所有oracle的基本知识。主要的形式是例子代码加代码解释加运行结果,我个人认为对于没有学习...

    Oracle学习笔记.pdf

    在Oracle学习笔记中,对安装卸载和配置的详尽讲解,不仅为学习者提供了操作指导,而且还涉及到了数据库管理的一些基础知识点。这些内容对于数据库管理员和开发人员来说都是十分重要的,因为它们是操作Oracle数据库的...

    Oracle学习笔记-日常应用、深入管理、性能优化

    资源名称:Oracle学习笔记-日常应用、深入管理、性能优化内容简介:Oracle学习笔记-日常应用、深入管理、性能优化Oracle 11g是最具代表性的高端关系型数据库管理系统,它在世界各地的大型商务数据库应用系统中被广泛...

    oracle dba学习笔记

    Oracle DBA 学习笔记 标题:Oracle DBA 学习笔记 描述:学习使用维护 Oracle 数据库数年,对认为值得记录的 Oracle 维护脚本进行记录总结,存起来,虽然今后开源是方向,但不可否认 Oracle 仍然非常有水平的,在...

    oracle学习笔记整理

    以下是对Oracle学习笔记整理的主要知识点的详细说明: 1. **数据库选择**: 在决定使用哪种数据库时,通常需要考虑项目的规模、性能需求、安全性要求以及可用资源。Oracle数据库因其稳定性、可扩展性和高性能而被...

    Oracle学习笔记 Oracle学习笔记

    根据提供的信息,我们可以总结出以下Oracle数据库学习的关键知识点: ...以上是基于提供的内容整理出的Oracle学习笔记中的关键知识点。通过理解这些基础知识,可以更好地管理和操作Oracle数据库。

    oracle学习笔记.txt

    超详细Oracle学习笔记,详细记录了oracle的学习过程中遇到的各种问题及基础知识,适合初中级oracle使用人员学习参考。

    oracle学习笔记-入门基础

    Oracle数据库是世界上最流行的数据库管理系统之一,它提供了丰富的特性和功能来优化数据管理和查询性能。本文主要探讨Oracle数据库的入门基础知识,特别是与索引相关的概念。 首先,我们要理解ROWID的概念。ROWID是...

    Oracle学习笔记——日常应用、深入管理、性能优化 示例代码

    Oracle 11g是最具代表性的高端关系型数据库管理系统,它在世界各地的大型商务数据库应用系统中被广泛应用。本书设计了大量的应用情景,介绍了数据库管理员和开发人员常用的管理、维护和优化Oracle 11g数据库的技术和...

    oracle学习笔记下载

    ### Oracle 学习笔记知识点概览 #### 一、Oracle 数据库系统参数查询与管理 在 Oracle 数据库的学习过程中,了解如何查看和管理数据库的系统参数是非常重要的。这些参数直接影响着数据库的性能和稳定性。 ##### ...

    ORACLE经典学习笔记

    ### ORACLE经典学习笔记知识点概览 #### 第一章 ORACLE 命令 本章节主要介绍了Oracle数据库中常用的命令及其使用方法。 1. **查看参数文件**: `Desc v$parameter` - 这个命令用于查看Oracle的参数文件信息,通过...

Global site tag (gtag.js) - Google Analytics