OCA读书笔记(1) - 浏览Oracle数据库架构
Objectives:
List the major architectural components of Oracle Database
Explain the memory structures
Describe the background processes
Correlate the logical and physical storage structures
Describe ASM storage components
三种连接方式
直接登录server
Client(PL/SQL Developer)-->Server
Client-->Middle Tier(WebLogical)-->Server
Connection: User process-->Server process
一次确定的连接:会话(身份权限认证)
进程间通信方式:
共享内存段:(SGA)
信号量
管道
Shared Pool
父游标--SQL语句转换后形成的二进制代码,解析
通过字符集转换
子游标--执行计划
语法语义检查
在数据字典中查询对象是否存在
Database Buffer Cache
select * from emp;
如果内存不存在emp,则需要读取数据文件。
需要读取一行数据,需要将该行所在数据快读入内存。
缓存最近访问过的数据块,供当前所有用户共享,减少I/O。
Redo Log Buffer
保存DML和DDL进行更改所产生的日志,而不是语句本身。
以上三种是必须的。
Large Pool
提供大的内存分配
RMAN备份恢复
并行查询
不是必须的,当没有的时候,使用shared pool.
Java Pool
在oracle中使用java时才用。
Streams Pool
只被流使用,流复制。公安部--人口信息表。分部更改之后同步到总部数据库。
class 2 started
--------------------------------------------
用户进程
数据库进程:
--服务器进程,为用户进程服务
--后台进程,当oracle实例启动时启动
守护进程(应用进程)
--网络监听
--网格基础架构监听
后台进程
--必须的进程(DBWn, CKPT, LGWR, SMON, PMON, RECO)
--可选的进程(ARCn, ASMB, RBAL, Others)
DBWn:
异步写脏数据(增,删,改产生的数据),提交时也不一定写。
LGWR
将redo log buffer写到redo log file
什么时候写?
用户提交
日志缓冲区1/3满
DBWn写脏块之前
每隔3秒钟
CKPT
通知数据库写进程写脏块
记录检查点信息到控制文件和每个文件的文件头
scn: system change number
演示:获取数据库当前scn
select current_scn from v$database;
select scn_to_timestamp() from dual;
SMON
当实例启动时执行恢复(实例恢复)
清除不再使用的临时段,如排序使用过的临时段空间
PMON
当用户进程失败时,执行进程恢复
--清除数据库buffer cache
--释放用户进程使用的资源,使其不成为僵尸进程
监控空闲会话的超时
动态注册数据库服务到监听器
RECO
recover 进程,但数据中不用,主要用户分布式
演示:查看进程以及关闭进程
select status from v$instance;
exit
ps -ef | grep ora
kill -9 进程号
sqlplus / as sysdba;
startup;(重启数据库则进程启动起来)
ARCn:
备份redo log
select group#, status from v$log;
查看日志文件:
select a.group#, a.sequence#, a.status, b.member, a.bytes/1024/1024 MB, a.first_change# from v$log a, v$logfile b where a.group#=b.group#;
select current_scn from v$database;
alter system switch logfile;
归档
执行检查点
select a.group#, a.sequence#, a.status, b.member, a.bytes/1024/1024 MB, a.first_change# from v$log a, v$logfile b where a.group#=b.group#;
最近一次检查点
select checkpoint_change# from v$database;
看检查点位于日志文件对应的区间。
实例恢复一般使用active和current状态的日志文件,inactive一般用不上。
查看SGA大小:
[oracle@ ~]ipcs -m
当前通信机制,-m共享内存段
查看SGA各部分内存大小
desc v$memory_dynamic_components;
select component, current_size from v$memory_dynamic_components;
desc v$process;
select pname, background from v$process;
background 为1的是后台进程。
数据库存储结构
控制文件
select name from v$controlfile;
alter database backup controlfile to trace as '/u01/app/oracle/control.trace' reuse;
vi control.trace
数据文件
select name from v$datafile;
日志文件
select member from v$logfile;
参数文件
show parameter spfile;
cd $ORACLE_HOME/dbs
echo $ORACLE_HOME
改错参数之后
create pfile from spfile(二进制文件);
vi initorcl.ora(文本文件)
vi init.ora
在initoracl.ora上进行修改,然后进入数据库运行如下命令
create spfile from pfile;
口令文件
select * from v$pwfile_users;
grant sysdba to scott;
select * from v$pwfile_users;
revoke sysdba from scott;
告警和跟踪文件
11g之前 adump, bdump, cdump, udump
11g:
cd $ORACLE_BASE
cd diag/rdbms/orcl/orcl
/u01/app/oracle/diag/rdbms/orcl/orcl/trace/alert_orcl.log
/u01/app/oracle/diag/rdbms/orcl/orcl/alert/log.xml
逻辑和物理数据库结构
表空间:
select name from v$tablespace;
数据文件
desc dba_data_files;
select tablespace_name, file_name from dba_data_files;
占用空间的数据库对象叫做数据段。
select distinct object_type from dba_objects;
select distinct segment_type from dba_segments;
conn scott/tiger;
select segment_name, segment_type from user_segments;
11g延迟分配空间。
create table t(id number);
select * from t;
查看段
select segment_name, segment_type from user_segments;
insert into t values (1);
select segment_name, segment_type from user_segments;
数据块
数据库分配数据块按照区(Extent)来进行分配。多个数据块打包成为段进行分配。
演示
drop table e purge;
drop table t purge;
create table t as select * from emp;
desc dba_extents;
select segment_name, file_id, extent_id, blocks from dba_extents where segment_name='T' and owner='SCOTT';
select tablespace_name, file_name from dba_data_files where file_id=4;
不停插入数据
insert into t select * from t;
select segment_name, file_id, extent_id, blocks from dba_extents where segment_name='T' and owner='SCOTT';
show parameter db_block_size;
继续插入:
块的大小会调整,8-128-896-1024-8192.区的自动管理
OCA读书笔记(1) - 浏览Oracle数据库架构的更多相关文章
- OCA读书笔记(11) - 实现Oracle数据库审计
11 Implementing Oracle Database Auditing 描述DBA对于安全和审计的职责使能标准的数据库审计安全审计选项查看审计信息维护审计路径 最小权限原则只在计算机上安装所 ...
- OCA读书笔记(2) - 安装Oracle软件
Objectives: •Describe your role as a database administrator (DBA) and explain typical tasks and tool ...
- OCA读书笔记(6) - 配置Oracle网络环境
6.Configuring the Oracle Network Environment su - grid装grid时自动创建了监听netca--创建新的监听 vi $ORACLE_HOME/net ...
- Oracle 数据库架构
Oracle 数据库架构 查看数据库在linux系统的安装目录路径情况: [root@localhost ~]# cd /u01/app/oracle/oradata/orcl/ [root@loca ...
- OCA读书笔记(7) - 管理数据库存储结构
7.Managing Database Storage Structures 逻辑结构 数据库的存储结构有物理结构和逻辑结构组成的 物理结构:物理上,oracle是由一些操作系统文件组成的 SQL&g ...
- OCA读书笔记(18) - 使用Support工具
调查和解决问题 问题:数据库中的任一严重的错误定义为一个问题,一般来说,这些错误包括大家熟悉的ORA-600错误和ORA-04031(共享池超出)错误,涉及数据库问题的所有元数据都存储在ADR中,每个 ...
- 【学习笔记】Y2-1-1 Oracle数据库基础
Oracle 简介关系型(二维表)数据库 用来存储海量数据在大数据量的并发检索的情况下,性能要高于其他同类数据库产品一般运行环境是Linux和UnixOracle版本中的I(Internet) G(G ...
- OCA读书笔记(9) - 管理数据同步
9.Managing Data Concurrency 描述锁机制以及oracle如何管理数据一致性监控和解决锁冲突 管理数据的并发--管理锁数据的不一致:脏读更改丢失幻影读 脏读:数据是指事务T2修 ...
- OCA读书笔记(3) - 使用DBCA创建Oracle数据库
Objectives: •Create a database by using the Database Configuration Assistant (DBCA) •Generate databa ...
随机推荐
- Python 执行字符串表达式函数(eval exec execfile)
eval:计算字符串中的表达式 exec:执行字符串中的语句 execfile:用来执行一个文件 在python 2中exec是语句,在python3中exec变为函数,后面要跟括号.在python3 ...
- 基于Sql Server 2008的分布式数据库的实践(二)
原文 基于Sql Server 2008的分布式数据库的实践(二) 从Win7连接Win2003的Sql Server 2008 1.新建链接服务器链接到Win2003的Sql Server 2008 ...
- 基于visual Studio2013解决C语言竞赛题之0607strcpy
题目
- 死锁 android ANR
以下为一段ANR的LOG,主要是在WindowManagerService.java和ActivityManagerService.java中实现. W/WindowManager( 2183): K ...
- weblogic中设置数据源的注意点
一.基本概念 进入weblogic的管理页面,点击服务——>数据源,可以进行数据源的配置.通过新建,输入地址,用户名,密码等信息可以新建一个数据源. 二.发现问题 建立好数据源之后,跑项目,发现 ...
- Eclipse 和 MyEclipse控制台console不停的自动跳动,跳出来解决方案
有时候Eclipse启动,控制台console不会自动跳出来,需要手工点击该选项卡才行,按下面的设置,可以让它自动跳出来(或不跳出来):由二种方法: 一.windows -> prefer ...
- 用css实现列表菜单的效果
<!doctype html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- Jsp的include指令静态导入和动态导入的区别
1.什么是静态导入? 静态导入指的是,将一个外部文件嵌入到当前JSP文件中,同时解析这个页面的JSP语句,它会把目标页面的其他编译指令也包含进来. include的静态导入指令使用语法: <%@ ...
- extern、static、auto、register 定义变量的不同用法
首先得说明什么叫“编译单元”.每个 .c 文件会被编译为一个 .o 文件,这个就是一个编译单元.最后所有的编译单元被链接起来,就是一个库或一个程序. 一个变量/函数,只要是在全局声明的,链接之后都隐含 ...
- WCF技术剖析之二十四: ServiceDebugBehavior服务行为是如何实现异常的传播的?
原文:WCF技术剖析之二十四: ServiceDebugBehavior服务行为是如何实现异常的传播的? 服务端只有抛出FaultException异常才能被正常地序列化成Fault消息,并实现向客户 ...