在Oracle 11g中用看Oracle的共享内存段---------IPCS

原创 2013年10月18日 00:34:22

很早之前,在一次讲课了,用了命令ipcs,发现oracle的共享内段好小,如下:

oracle@mydb ~]$ ipcs -a

------ Shared Memory Segments --------
key        shmid      owner      perms      bytes      nattch     status      
0x00000000 32768      root      644        72         2                       
0x00000000 65537      root      644        16384      2                       
0x00000000 98306      root      644        280        2                       
0x00000000 1409028    oracle    640        4096       0                       
0x00000000 1441797    oracle    640        4096       0                       
0x079918e8 1474566    oracle    640        4096       0                       

------ Semaphore Arrays --------
key        semid      owner      perms      nsems     
0x87a36da4 1343489    oracle    640        154       

------ Message Queues --------
key        msqid      owner      perms      used-bytes   messages   

今天突然想起,刚好有空,来总结一下:

上面显示Oracle共享内存段只有4096个字节,这太小了吧,哦,对了,我这是Oracle11g:

sys@OCM> select * from v$version;

BANNER
--------------------------------------------------------------------------------
Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 - 64bit Production
PL/SQL Release 11.2.0.3.0 - Production
CORE    11.2.0.3.0      Production
TNS for Linux: Version 11.2.0.3.0 - Production
NLSRTL Version 11.2.0.3.0 - Production

Oraccle11g的对内存的管理用了两个新的参数:

sys@OCM> show parameter memory

NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
hi_shared_memory_address             integer     0
memory_max_target                    big integer 1G
memory_target                        big integer 0
shared_memory_address                integer     0



会不会是参数memory_max_target在作怪呢,把它关了试试,我这里把它设为0,然后重启数据库。

sys@OCM> alter system set memory_max_target=0 scope=spfile;

System altered.

sys@OCM> startup force;
ORACLE instance started.

Total System Global Area  943669248 bytes
Fixed Size                  2234000 bytes
Variable Size             541067632 bytes
Database Buffers          394264576 bytes
Redo Buffers                6103040 bytes
Database mounted.
Database opened.


再看共享内存:

[oracle@mydb ~]$ ipcs -a

------ Shared Memory Segments --------
key        shmid      owner      perms      bytes      nattch     status      
0x00000000 32768      root      644        72         2                       
0x00000000 65537      root      644        16384      2                       
0x00000000 98306      root      644        280        2                       
0x00000000 1802244    oracle    640        4096       0                       
0x00000000 1835013    oracle    640        4096       0                       
0x079918e8 1867782    oracle    640        4096       0                       

------ Semaphore Arrays --------
key        semid      owner      perms      nsems     
0x87a36da4 1736705    oracle    640        154       

------ Message Queues --------
key        msqid      owner      perms      used-bytes   messages    


怎么回事,没变啊?

是不是参数没改对,继续校验参数:

sys@OCM> show parameter mem

NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
hi_shared_memory_address             integer     0
memory_max_target                    big integer 904M
memory_target                        big integer 0
shared_memory_address                integer     0

果然没改过来,是不是命令alter system set memory_max_target=0 scope=spfile;没用啊,不能怎么设,但这命令本身设置重启也没报错。

来个狠一点的命令重置默认值:

sys@OCM> alter system reset memory_max_target;

System altered.

sys@OCM> startup force;
ORACLE instance started.

Total System Global Area  680665088 bytes
Fixed Size                  2231352 bytes
Variable Size             276825032 bytes
Database Buffers          394264576 bytes
Redo Buffers                7344128 bytes
Database mounted.
Database opened.
sys@OCM> show parameter mem

NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
hi_shared_memory_address             integer     0
memory_max_target                    big integer 0
memory_target                        big integer 0
shared_memory_address                integer     0

这下可以了,参数memory_max_target终于等于0了。

我们再来看ORACLE共享内存:

[oracle@mydb ~]$ ipcs -a

------ Shared Memory Segments --------
key        shmid      owner      perms      bytes      nattch     status      
0x00000000 32768      root      644        72         2                       
0x00000000 65537      root      644        16384      2                       
0x00000000 98306      root      644        280        2                       
0x00000000 1933316    oracle    640        12582912   30                      
0x00000000 1966085    oracle    640        671088640  30                      
0x079918e8 1998854    oracle    640        2097152    30                      

------ Semaphore Arrays --------
key        semid      owner      perms      nsems     
0x87a36da4 1867777    oracle    640        154       

------ Message Queues --------
key        msqid      owner      perms      used-bytes   messages    

可以了!已从4096字节变成671088640多字节了。大笑,总结只要把参数memory_max_target设为0就能看到。这里不建议大家去这样改,只是为了解释一下这个现象。

上面那幅图留给童鞋们思考,不再解释了。。。


QQ:252803295

技术交流QQ群:
DSI&Core Search  Ⅰ 群:127149411(2000人技术群:未满)
DSI&Core Search  Ⅱ 群:177089463(1000人技术群:未满)
DSI&Core Search  Ⅲ 群:284596437(500人技术群:未满)
DSI&Core Search  Ⅳ 群:192136702(500人技术群:未满)
DSI&Core Search  Ⅴ 群:285030382(500人闲聊群:未满)


MAIL:dbathink@hotmail.com

BLOG: http://blog.csdn.net/guoyjoe

WEIBO:http://weibo.com/guoyJoe0218

ITPUB: http://www.itpub.net/space-uid-28460966.html

OCM:   http://education.oracle.com/education/otn/YGuo.HTM 

ACONG:  http://www.acoug.org/category/membership




<Unix/Linux>删除key:0x00000000的共享内存方法

在终端下输入命令ipcs -m
  • u013550907
  • u013550907
  • 2014年04月20日 13:55
  • 1818

Oracle 11gR2构建RAC之(2)--配置共享存储

Oracle 11gR2构建RAC之(2)--配置共享存储系统环境:操作系统:RedHat EL5Cluster: Oracle GI(Grid Infrastructure)Oracle:  Ora...
  • lqx0405
  • lqx0405
  • 2015年03月31日 12:03
  • 3501

window下的默认共享(与安装Oracle 11g r2先决条件检查失败-物理内存等有关)

在Windows 2000/XP/2003系统中,逻辑分区与Windows目录默认为共享,这是为管理员管理服务器的方便而设,但却成为了别有用心之徒可趁的安全漏洞。 目 录 1默...
  • haiross
  • haiross
  • 2013年10月14日 13:33
  • 3080

oracle 共享内存段探究

欢迎使用Markdown编辑器写博客本Markdown编辑器使用StackEdit修改而来,用它写博客,将会带来全新的体验哦: Markdown和扩展Markdown简洁的语法 代码块高亮 图片链接和...
  • stephen11111
  • stephen11111
  • 2016年09月18日 12:01
  • 659

Oracle 11g 的 自动内存管理

Oracle 的 9i/10g 中已经对内存管理逐步做了很大的简化,11g 则更进一步,引入了一个新的概念自动化内存管理(Automatic Memory Management,AMM) . 如果 D...
  • taotao821130
  • taotao821130
  • 2013年05月30日 14:45
  • 672

ORACLE 11g 自动内存管理

Overview 在oracle 11g中,使用一个参数memory_target就能够实现SGA和PGA组件依据工作负荷进行自动内存分配。oracle推荐使用自动内存管理简化内存分配。 or...
  • liqfyiyi
  • liqfyiyi
  • 2014年09月16日 17:18
  • 725

oracle 11g 自动内存管理。

Oracle数据库在系统占用的内存分为两个部分:SGA 和 PGA。 根据Oracle的建议,Oracle最多可以使用80%的物理内存,其余20%保留给操作系统使用。 在这80%的内存中,OLTP...
  • zq9017197
  • zq9017197
  • 2012年07月05日 11:32
  • 1525

oracle 11g内存管理

本文主要针对oracle 11g的内存参数进行说明 SQL> show sga Total System Global Area  780824576 bytes Fixed Size     221...
  • u011563716
  • u011563716
  • 2014年02月13日 15:14
  • 321

Tomcat 初始内存配置、MySQL 的8小时连接失效、Oracle 11g 密码180天过期

项目维护中遇到的问题,这里记录已方便日后查阅。 Tomcat初始内存设置 对于4G内存的配置,给出以下配置参考: [Windows]在catalina.bat的第一行增加: set JAVA_...
  • thisinnocence
  • thisinnocence
  • 2014年04月03日 18:34
  • 2319

Oracle 11g 新特性 -- 自适应游标共享(Adaptive Cursor Sharing: ACS) 说明

一.自适应游标共享(Adaptive Cursor Sharing) 说明 1.1 ACS概述绑定变量使Oracle DB 可以为多条SQL 语句共享单个游标,以减少分析SQL 语句所使用的共享内存量...
  • tianlesoftware
  • tianlesoftware
  • 2012年05月16日 17:30
  • 10362
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:在Oracle 11g中用看Oracle的共享内存段---------IPCS
举报原因:
原因补充:

(最多只允许输入30个字)