ORA-00845问题、以及tmpfs

环境:

       RHEL 6.8+Oracle 11.2.0.4

起库时报错ORA-00845: MEMORY_TARGET not supported on this system

 原因: 

         11G的AMM和LINUX的/dev/shm有关联,如果库启用了AMM特性,就要求操作系统的共享内存要大于MEMORY_TARGET和MEMORY_MAX_TARGET,redhat中/dev/shm默认大小为操作系统内存的一半。

解决办法:

         1)调整/dev/shm的大小,在/etc/fstab中修改,然后重新挂载tmpfs

         2)修改MEMORY_TARGET的值,将其减少到小于tmpfs(不过一般都不这么做= =)

Starting with Oracle Database 11g, the Automatic Memory Management feature requires more shared memory (/dev/shm)and file descriptors. The size of the shared memory should be at least the greater of MEMORY_MAX_TARGET and MEMORY_TARGET for each Oracle instance on the computer. If MEMORY_MAX_TARGET or MEMORY_TARGET is set to a non zero value, and an incorrect size is assigned to the shared memory, it will result in an ORA-00845 error at startup.

关于tmpfs:

      1)虚拟内存文件系统,基于内存的文件系统
      2)存储空间在VM(virtual memory),VM是由linux内核里面的vm子系统管理的。linux下面VM的大小由RAM(Real Memory)和SWAP(磁盘虚拟出来的内存空间)组成
      3)tmpfs的大小默认为RAM的一半,理论上tmpfs最大空间为(RAM+SWAP)     

      挂载/tmp目录,使用tmpfs文件系统:mount tmpfs /tmp -o size=1024M -t tmpfs
      如果需要持久化,需要修改/etc/fstab 添加:tmpfs  /tmp   tmpfs size=1G 0 0,然后重启操作系统
      如果之前操作系统上有/tmp文件夹的话,直接mount挂载可能导致有的程序无法正常使用(例如我的mysql.sock之前存放在/tmp中,直接挂载上然后mysql登陆就提示找不到mysql.sock) 

SWAP和RAM:
      SWAP和RAM两者是如何相互搭配使用的呢,这个主要是由内核参数swappiness来控制,默认值为60,当内存的使用率(%)为100-swappiness时,开始使用SWAP,在内存足够的情况下,强烈建议把这个值调低
      临时调整,重启失效:echo 10 > /proc/sys/vm/swappiness
      永久生效的方法:在 /etc/sysctl.conf中增加参数 vm.swappiness = xxx,然后sysctl -p生效 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值