环境:
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生效