Oracle管理磁盘空间和资源
1.可恢复的空间分配
## 1.1 了解可恢复的空间分配 ##
一般情况,我们发出一个大型数据库操作,比如创建大表索引,如果表空间不足,数据库最终会终止操作。
而可恢复的空间分配功能可以使得这类操作挂起,等待DBA去处理,等成功处理之后大型数据库操作自动恢复,这样就避免了这类棘手问题,节省了时间。
## 1.2 配置可恢复的空间分配 ##
相关参数和用法:
```
--参数resumable_timeout
show parameter resumable_timeout
--实例级别启用resumable
alter system set resumable_timeout = 7200;
--实例级别禁用resumable
alter system set resumable_timeout = 0;
--赋权resumable权限给某个用户
grant resumable to jingyu;
--会话级别修改
--启用resumable
alter session enable resumable;
--设定挂起时长
alter session enable resumable timeout 144000;
--设定名称
alter session enable resumable name 'Create Big Index';
--禁用resumable
alter session disable resumable;
--查询DBA_RESUMABLE了解挂起语句的详细信息
set linesize 140
col name for a40
col error_msg for a30
select USER_ID, SESSION_ID, INSTANCE_ID, STATUS, NAME, ERROR_MSG from dba_resumable;
实验-配置使用当前会话的可恢复的空间分配:
--如果表空间不足,创建表会直接失败
SQL> show user
USER is "JINGYU"
SQL> create table t_s1 as select * from dba_objects;
create table t_s1 as select * from dba_objects
*
ERROR at line 1:
ORA-01652: unable to extend temp segment by 128 in tablespace DBS_D_JINGYU
--如果启用session的resumable,再创建表就会挂起操作
SQL> alter session enable resumable timeout 7200;
Session altered.
SQL> create table t_s1 as select * from dba_objects;
...这里长时间挂起
--此时我们从告警日志中可以看到对应的日志信息,操作被挂起:
Wed Jan 13 09:51:55 2016
statement in resumable session 'User JINGYU(99), Session 62, Instance 1' was suspended due to
ORA-01652: unable to extend temp segment by 128 in tablespace DBS_D_JINGYU
--扩展表空间
SQL> alter tablespace DBS_D_JINGYU add datafile size 30M;
Tablespace altered.
--此时告警日志信息可以看到操作继续执行:
Wed Jan 13 10:01:12 2016
statement in resumable session 'User JINGYU(99), Session 62, Instance 1' was resumed
Completed: alter tablespace DBS_D_JINGYU add datafile size 30M autoextend on
--再去看刚刚挂起的建表语句已经执行成功
SQL> create table t_s1 as select * from dba_objects;
Table created.
--禁用当前会话的resumable
alter session disable resumable;
## 1.3 使用可恢复的空间分配功能 ##
--触发器基本结构如下,需要根据具体需求来完善
create or replace trigger resumable_notify
after suspend on database
declare
-- variables, if required
begin
-- check DBA_RESUMABLE for user ID, type of
-- object, then send e-mail
dbms_resumable.space_error_info(. . .);
if object_type = 'TABLE' and object_owner = 'HR' then
-- give DBA 2 hours to resolve
dbms_resumable.set_timeout(7200);
utl_mail.send('DBA@company.com',. . .);
else
dbms_resumable.abort(. . .);
end if;
end;
<h1 id="2">2.可移动表空间</h1>
使用Data Pump导出表空间中对象的元数据,将组成表空间的数据文件复制到目的数据库,然后把表空间的元数据导入到目的数据库中。
## 2.1 配置可移动表空间 ##
在平台间传输数据,源平台和目的平台必须是Oracle支持的平台列表中的成员。
### 2.1.1 确定兼容性需求 ###
Oracle数据库的功能兼容性由COMPATIBLE初始化参数进行控制,此参数启用或禁用数据库中的某些功能。创建可移动表空间集合时,Oracle将确定目标数据库的最低兼容性级别,并将相应值存储在可移动数据集的元数据中。从Oracle Database 11g开始,不管对于哪种目标平台,始终可以将表空间移动到拥有相同或更高兼容性级别的另一个数据库中。
另外,两个数据库必须使用相同的字符集。
### 2.1.2 确定字节序要求 ###
--查询可移动表空间的所有支持平台及其ENDIAN_FORMAT:
SQL> select platform_id, platform_name, endian_format from v$transportable_platform order by 3,1;
PLATFORM_ID PLATFORM_NAME ENDIAN_FORMAT
1 Solaris[tm] OE (32-bit) Big
2 Solaris[tm] OE (64-bit) Big
3 HP-UX (64-bit) Big
4 HP-UX IA (64-bit) Big
6 AIX-Based Systems (64-bit) Big
9 IBM zSeries Based Linux Big
16 Apple Mac OS Big
18 IBM Power Based Linux Big
5 HP Tru64 UNIX Little
7 Microsoft Windows IA (32-bit) Little
8 Microsoft Windows IA (64-bit) Little
10 Linux IA (32-bit) Little
11 Linux IA (64-bit) Little
12 Microsoft Windows x86 64-bit Little
13 Linux x86 64-bit Little
15 HP Open VMS Little
17 Solaris Operating System (x86) Little
19 HP IA Open VMS Little
20 Solaris Operating System (x86-64) Little
21 Apple Mac OS (x86-64) Little
20 rows selected.
--查询当前平台的字节序格式
select PLATFORM_NAME my_platform, ENDIAN_FORMAT my_endian_format from v$transportable_platform join v$database using(platform_name);
SQL> select PLATFORM_NAME my_platform, ENDIAN_FORMAT my_endian_format
2 from v$transportable_platform
3 join v$database using(platform_name);
MY_PLATFORM MY_ENDIAN_FORMAT
Linux x86 64-bit Little
## 2.2 传输表空间 ##
**传输表空间核心步骤:**
1)源数据库上的表空间设为只读模式;
2)源数据库上提取表空间元数据;
3)如果源和目的的字节序格式不同,转换表空间内容;
4)拷贝表空间数据文件以及表空间元数据到目的数据库;
5)目的数据库导入表空间元数据;
6)源数据库和目的数据库的表空间设置为读写模式。
--用户的默认表空间和默认临时表空间
select username, DEFAULT_TABLESPACE, TEMPORARY_TABLESPACE from user_users;
--用户用到的表空间
select tablespace_name from user_tables union
select tablespace_name from user_tab_partitions union
select tablespace_name from user_indexes union
select tablespace_name from user_ind_partitions;
### 2.2.1 使用EM传输表空间 ###
web图形化界面操作,
1.点击数据移动 -> 传输表空间 -> 生成可传输的表空间集,然后按提示一步步生成;
2.在目的地数据库 点击数据移动 -> 传输表空间 -> 集成现有可传输表空间集,然后按提示一步步集成在目的数据库中。
我这里实验在生成可传输的表空间集时报错:ORA-02097,ORA-19529。
--根据MOS文档:Received ORA-19529 Attempting To Do A Transportable Tablespace Export Through OEM (文档 ID 2073402.1)
ORA-02097: parameter cannot be modified because specified value is invalid
ORA-19529: Pattern /home/kqualls/transport/epsdev/o1_mf_ekb_cons_b6qc1hbm_.dbf in initialization parameter db_file_name_convert has an Oracle Managed Files file name.
--原因:
EM Cloud Control 12c does not support conversion of OMF files. Currently only user managed files are supported using the EM feature. There is an enhancement logged, Bug 21233808 - Cloud Control TTS generates invalid db_file_name_convert command ORA-02097
--解决:
Create RMAN Job in EM Cloud Control Job system, enter command line script commands there.
Using the RMAN Job in the EM Job system will allow the process to use the database parameters to convert the datafiles rather than using the EM perl scripts that don't support OMF files.
PS:即使没有问题,一般生产环境传输表空间也不采用EM,因为很多生产环境都没有安装EM,或者复杂的网络环境因素导致不方便使用EM。还是手动使用SQL传输表空间更加靠谱。
### 2.2.2 使用SQL传输表空间 ###
参考:
- [Oracle使用SQL传输表空间](http://www.cnblogs.com/jyzhao/p/5148905.html)
<h1 id="3">3.Oracle段收缩功能</h1>
参考:
- [Oracle段收缩功能](http://www.cnblogs.com/jyzhao/p/5150772.html)
<h1 id="4">4.Oracle数据库资源管理</h1>
参考:
- [Oracle数据库资源管理](http://www.cnblogs.com/jyzhao/p/5151168.html)
<h1 id="5">Reference</h1>
- OCP 认证考试指南 (1Z0-053)[M]. 清华大学出版社, 2010.
Oracle管理磁盘空间和资源的更多相关文章
- oracle所在磁盘空间不足导致了数据库异常
oracle所在磁盘空间不足导致了数据库异常.需要减小数据文件的大小来解决. 1.检查数据文件的名称和编号 select file#,name from v$datafile; 2.看哪个数据文件所占 ...
- oracle服务器硬盘磁盘空间满了
问题描述:oracle服务器硬盘磁盘空间满了,没有空间写入数据: 解决思路: a.服务器是虚拟机还是实体机? 虚拟机,->物理机上有空间直接给它扩容,再给数据库的相关表空间添加文件就可: 实体机 ...
- Oracle管理表空间和数据文件详解
介绍 表空间是数据库的逻辑组成部分 从物理上将:数据库数据存放在数据文件中 从逻辑上将:数据库则是存放在表空间中 表空间由一个或是多个数据文件组成 数据库的逻辑结构 介绍: Oracle中逻辑结构包括 ...
- ORACLE - 管理表空间和数据文件
ORACLE表空间是一个逻辑分区,一个数据文件只能属于一个表空间,一个表空间可以拥有多个数据文件. 一般情况下,如果一个实例分配给多个应用使用,需要创建不同的表空间,每个用户使用自己的表空间. 一.表 ...
- oracle 管理表空间
表空间:是oracle数据库中最大的逻辑存储结构,与操作系统中的数据文件相对应,用于存储数据库中用户创建的所有内容 表空间>数据文件 4.1创建一个永久性表空间myspace create ta ...
- Oracle管理监控之Oracle用户权限
数据字典 1.动态数据字典是以v$xxx开始的数据字典,在数据库中约有150个左右,这些数据字典反映数据库动态运行状况,在不同时间查询会得到不同的结果. 2.DBA数据字典是以DBA_xxx表示,该数 ...
- Ubuntu查看磁盘空间命令(转载)
linux中df命令的功能是用来检查linux服务器的文件系统的磁盘空间占用情况.可以利用该命令来获取硬盘被占用了多少空间,目前还剩下多少空间等信息. 1.命令格式: df [选项] [文件] 2.命 ...
- 如何清理Docker占用的磁盘空间?
摘要:用了 Docker,好处挺多的,但是有一个不大不小的问题,它会一不小心占用太多磁盘,这就意味着我们必须及时清理. 作为一个有信仰的技术公司,我们Fundebug的后台采用了酷炫的全 Docker ...
- 如何清理Docker占用的磁盘空间?(转载)
本文转载自https://blog.fundebug.com/2018/01/10/how-to-clean-docker-disk/ , 感谢原作者. 摘要:用了Docker,好处挺多的,但是有一个 ...
随机推荐
- js,css控制网页内容不让选中和复制
---恢复内容开始--- JS, CSS控制网页内容不让选择和复制 CSS 控制: <style> body{ -moz-user-select:none;//针对火狐浏览器,谷歌则-we ...
- webpack模块加载css文件及图片地址
webpack支持css文件加载并打包,只需安装相应加载器并在配置文件中配置 . 加载的css文件内容会与该模块里的js内容混合封装,这样做的好处是一个js文件包含了所有的css与js内容,有效减少了 ...
- Linux堆溢出漏洞利用之unlink
Linux堆溢出漏洞利用之unlink 作者:走位@阿里聚安全 0 前言 之前我们深入了解了glibc malloc的运行机制(文章链接请看文末▼),下面就让我们开始真正的堆溢出漏洞利用学习吧.说实话 ...
- Azure 新的管理模式 —— Resource Manager
var appInsights=window.appInsights||function(config){ function r(config){t[config]=function(){var i= ...
- ENode框架Conference案例分析系列之 - 复杂情况的读库更新设计
问题背景 Conference案例,是一个关于在线创建会议(类似QCon这种全球开发者大会).在线管理会议位置信息.在线预订某个会议的位置的,这样一个系统.具体可以看微软的这个项目的主页:http:/ ...
- JavaScript面试时候的坑洼沟洄——表达式与运算符
上篇博客JavaScript面试时候的坑洼沟洄--数据类型总结了一下JavaScript数据类型几转换的相关知识,很多朋友可能和我一样,买了书后对数据类型啊.运算符啊.语句啊都是扫两眼或直接略过的,自 ...
- YY一下微信线下支付的场景
在上一篇文章里面提到了 <跨行清算的实现原理>,这次来分析一下线下支付的场景和流程. 今天看到一篇文章:http://www.huxiu.com/article/23248/1.html? ...
- Ubuntu 安装OpenERP
网上的都TM不靠谱.... 1.用root登录,修改/etc/apt/sources.list 文件 sudo /etc/apt/sources.list u root 注意一定要加U root否则没 ...
- C# Azure 存储-分布式缓存Redis在session中的配置
1. 开始 对于分布式的缓存,平常的session的处理是一个用户对应一台分布式的机器,如果这台机器中途挂机或者不能处理这个用户session的情况发生,则此用户的session会丢失,会发生不可预知 ...
- Spring学习记录(十一)---使用注解和自动装配
Spring支持用注解配置Bean,更简便. 上面的组件,是根据实际情况配的.比如写的一个类,是做业务处理的,那就用注解@Service表示服务层组件,以此类推.将整体分成不同部分. 要在xml加入c ...