zoukankan      html  css  js  c++  java
  • Oracle 数据库裸设备扩容处理

    前段时间,我管理的一台Oracle数据库表空间容量不足了,由于本人以前没有接触过Oracle的使用所以,就自己查资料来研究如何扩容,网上的文档多数都是在物理机上扩容,而偏偏我的数据文件是存储在裸设备上的,裸设备和磁盘文件稍有不同,再加上Oracle默认是以表空间为归类的,操作上与MySQL有些不一样。

    先是查询了前人留下的扩容文档,但多数写的草率根本无从下手,气得我直接当场气死,后来经过各种查资料各种尝试,最终还是扩容完成了,这里做个总结,免得以后再碰到类似的问题,防止二次当场气死。

    首先确定数据库的基本信息,先查询数据库名称,表空间位置等。

    SQL> select name from v(database; 查当前数据库名 SQL> select * from v)datafile; 查表空间文件位置

    查询当前裸设备容量情况,如下命令

    SQL> select name,total_mb,free_mb,(free_mb/total_mb)*100 as usage from v$asm_diskgroup;

    查询所有的表空间。

    SQL> select tablespace_name from dba_tablespaces;

    查询表空间与用户对应关系。

    SQL> select default_tablespace as "默认表空间", temporary_tablespace as "临时表空间", d.username as "用户" from dba_users d;

    以TBS_CSP_PUB_DAT为例,查询该表空间中有哪些表。

    SQL> select TABLE_NAME,TABLESPACE_NAME from dba_tables where TABLESPACE_NAME='TBS_CSP_PUB_DAT';

    接着查询一下裸设备的使用情况。

    SQL> set line 200
    SQL> col path for a40

    首先查询组ID与裸设备名称对应关系。

    SQL> select group_number,name,state,total_mb,free_mb from v$asm_diskgroup;

    接着查询其挂载位置。

    SQL> select group_number,mount_status,header_status,path,total_mb,free_mb from v$asm_disk;

    如上可知道裸设备所对应的位置为/dev/目录下,我们可以Linux切换过去看看,裸设备无法直接在linux上操作,Linux只保留一个类似于符号链接的东西。

    查询TBS_CSP_PUB_DAT所对应到裸设备中的位置。

    SQL> select file_name from dba_data_files where tablespace_name='TBS_CSP_PUB_DAT' order by file_id;

    查询表空间利用率使用情况。
    set pagesize 9999
    set pagesize 9999
    set linesize 132
    select
    a.tablespace_name,
    a.Total_mb,
    f.Free_mb,
    round(a.total_MB-f.free_mb,2) Used_mb,
    round((f.free_MB/a.total_MB)100) "%_Free"
    from
    (select tablespace_name, sum(bytes/(1024
    1024)) total_MB from dba_data_files group by tablespace_name) a,
    (select tablespace_name, round(sum(bytes/(1024*1024))) free_MB from dba_free_space group by tablespace_name) f
    WHERE a.tablespace_name = f.tablespace_name(+)
    order by "%_Free"
    /

    其他有用的参数查询

    确定好参数以后,只需要保证裸设备中容量足够,即可执行一条命令完成扩容任务,以扩容 TBS_CSP_PUB_DAT 为例

    先来看一下扩容前的数据

    SQL> select tablespace_name,file_name,autoextensible from dba_data_files where autoextensible='YES';

    首先开启表空间自动扩展。

    SQL> ALTER DATABASE DATAFILE '+DG_DATA1/rlv_pub_dat001' AUTOEXTEND ON;

    扩大容量可以这么写,注意pub_dat0xx不能冲突,如下增加1个GB

    SQL> alter tablespace 需要扩容的空间 add datafile '+DG_DATA1/rlv_pub_dat017' SIZE 1g;

    最后查询一下,已经添加上了。

    SQL> select file_name from dba_data_files where tablespace_name='TBS_CSP_PUB_DAT' order by file_id;

    需要注意的是,如果裸设备中的容量严重不足,那么就无法直接扩容,正确的做法是去机房,给裸设备增加一块新磁盘,然后规划好容量,之后在使用上面的方法对Oracle数据库扩容。


    许可协议: 文章中的代码均为学习时整理的笔记,博客中除去明确标注有参考文献的文章,其他文章【均为原创】作品,转载请务必【添加出处】,您添加出处是我创作的动力!
  • 相关阅读:
    runc create container 流程分析
    cri-o pod 创建源码分析
    hyperstart 容器创建流程分析
    MIT jos 6.828 Fall 2014 训练记录(lab 4)
    python 邮件发送 脚本
    jvm: 理解gc日志
    jvm:垃圾收集器
    GC 垃圾收集
    jvm结构
    Java transient关键字使用小记
  • 原文地址:https://www.cnblogs.com/LyShark/p/14338325.html
Copyright © 2011-2022 走看看