实例
在8i版本之前,oracle数据库只能由单个实例来对应。SID即INSTANCE_NAME是用来唯一标示实例的。
实例是访问Oracle数据库所需的一部分计算机内存和辅助处理后台进程(PMON、SMON、DBWR、LGWR、CKPT等),是由进程和这些进程所使用的内存(SGA)所构成一个集合。
在下面连接串中
jdbc:oracle:thin:@localhost:1521:orcl
orcl就是实例的名字。也就是上面所说的SID。
一个数据库实例可以有多个表空间,一个表空间可以有多个表。
创建用户时需要为用户指定表空间
CREATE USER 用户名
IDENTIFIED BY 密码
DEFAULT TABLESPACE 表空间(默认USERS)
TEMPORARY TABLESPACE 临时表空间(默认TEMP)
一个数据库服务器可以安装多个数据库实例,他们都公用一个端口。
在8i后,在并行的数据系统中,一个数据库可以对应多个实例。当一个实例出现故障后,其他实例回自动进行服务。而一个实例只能对应一个数据库。多个实例的场景下,此时就需要指定ServiceName了。
表空间
- Oracle数据库开创性地提出了表空间的设计理念
- 一个ORACLE数据库能够有一个或多个表空间,而一个表空间则对应着一个或多个物理的数据库文件。表空间是ORACLE数据库恢复的最小单位,容纳着许多数据库实体,如表、视图、索引、聚簇、回退段和临时段等。
- 每个ORACLE数据库均有SYSTEM表空间,这是数据库创建时自动创建的。当然,对于小型应用,你也可以只使用该表空间。
- 数据块(DATA BLOCK)是ORACLE最小的逻辑组成部分。ORACLE存储数据的最小单位。
- extent是几个逻辑上相邻的data block组合在一块。
- segment通常一张表是一个segment,一个INDEX,BLOB,CLOB各自占用一个segment。(BLOB就是使用二进制保存数据。CLOB使用CHAR来保存数据。 ) 一个segment包含若干个extent。
表空间的存储参数
- PCTFREE
要形容一个 BLOCK 的运作,我们可以把一个 BLOCK 想成一个水杯。侍者把水倒入放在我们面前的水杯,要多满呢,我们要求他倒 9 分满好了,这时候 PCTFREE 代表着设定为 10 ,意思就是说,当 BLOCK 使用到达 90% 的时候,就不可以在使用了,这个 BLOCK 应该从 FREELIST 列表中移除 (un-link) 。为何要保留 10% 的空间呢?这是为了提供 update 数据时所可能增加的空间使用,如果空间保留的太小,就容易发生 row chaining (行迁移)。
- PCTUSED
PCTUSED 代表着这杯水什么时候可以添加,假设 PCTUSED 为 40 ,代表当我们把水杯的水喝到剩下 40% 以下时,侍者就会知道需要加水了。你想想看,如果说在餐厅里妳每喝一口水侍者就来加水,你会不会觉得很烦,对餐厅来说,也要派很多人不断帮每桌客人加水,这生意还能做吗?所以说, PCTUSED 代表着 re-link 回 FREELIST 的意义,如果说 PCTUSED 设的太大,例如 70 好了,代表这杯水你随便喝一口侍者就要来加水了,这隐含的意义是,这个杯子的利用率增加,但是侍者频繁的服务造成了负荷 (I/O Overhead) 。 PCTUSED 设小一点,例如 10 ,代表当水喝到剩下 10% 的时候 ( 如同 DELETE 事务操作 ) ,才须要放回 FREELIST ,代表可以加水了 ( 如同 INSERT 事务操作 ) 。
简单的说,如果希望储存空间发挥最大使用效益,可以把PCTUSED设大一点,相反的,如果想要提高IO效能,应该把PCTUSED设定小一点。
FREELIST 储存着可使用的 BLOCK 信息,当 BLOCK 被 DELETE 数据使用量下降到 PCTUSED 时,就会重新放置到 FREELIST 上,让其它交易新增数据使用。 FREELIST 存放在 TABLE/INDEX 的 Segment Header 中,他管理着所有可以新增数据的 BLOCK 信息。想想,如果有多人同时要新增数据而要求 FREELIST 提供可使用的 BLOCK 信息, FREELIST 不就也会成为另一个 Overhead ?所以依照 TABLE 使用的需求调整 FREELIST 的数量也是 IO Tuning 的一个重点。
这个参数在ASSM中已经没有用了,只剩下PCTFREE是生效的了。
- INITRANS
INITRANS 指的是一个 BLOCK 上初始预分配给并行交易控制的空间 (ITL,事务槽)。事务槽存在于枚意block的headder部分。如果一个事务一直没有提交,那么,这个事务将一直占用一个itl槽位,itl里面记录了事务信息,回滚段的入口,事务类型。提交后的ITL可以被复用。
( 当 BLOCK 上某笔 ROW 被交易更新锁定时,会在 BLOCK header ITL allocate 一个锁,当下一个交易要更新同一笔 row 时,就会发现他已经被先前的交易持有锁了,会先去检查该交易是否 active? 如果是,后来的该笔交易就会被 blocking ,等待 ) 如果一个表格需要同时有大量交易存取,你应该设定 INITRANS 大一点,可以减少 ITL 还要动态扩充的 Overhead 。
For tables INITRANS defaults to 1 for indexes 2
- MAXTRANS
MAXTRANS 指的是如果 INITRANS 空间不够用了,就会自动扩展 ITL ,直到最大值也就是 MAXTRANS 值为止,预设是 255 。但是,如果 BLOCK 空间已经不足,也有可能无法持续扩充到 255 个 ITS 空间喔。