-
【Oracle问题集1】ORA-00845: MEMORY_TARGET not supported on this system执行语句:启动Oracle 数据库(startup)出错现象:ORA-00845: MEMORY_TARGET not supported on this system错误原因:由于设置SGA的大小超过了操作系统/dev/shm的大小解决方法:第一种方法:修改初始化参数,使得初始化参数中的SGA设置小于/dev/shm的大小.第二种方法:是调整/dev/shm的大小调整/dev/shm的方法如下:[root@localhost ~]# vim /etc/fstabtmpfs /dev/shm tmpfs defaults,size=10240M 0 0 【修改tmpfs大小】[root@localhost ~]# umount /dev/shm[root@localhost ~]# mount /dev/ssh[root@localhost ~]# df -h /dev/shm文件系统 容量 已用 可用 已用% 挂载点tmpfs 10G 0 10G 0% /dev/shm相关知识A、tmpfs有以下特点:tmpfs 是一个文件系统,而不是块设备;您只是安装它,它就可以使用了。动态文件系统的大小。tmpfs 的另一个主要的好处是它闪电般的速度。因为典型的 tmpfs 文件系统会完全驻留在 RAM 中,读写几乎可以是瞬间的。tmpfs 数据在重新启动之后不会保留,因为虚拟内存本质上就是易失的。所以有必要做一些脚本做诸如加载、绑定的操作。B.linux /dev/shm 默认容量linux下/dev/shm的容量默认最大为内存的一半大小,使用df -h命令可以看到。但它并不会真正的占用这块内存,如果/dev/shm/下没有任何文件,它占用的内存实际上就是0字节;如果它最大为1G,里头放有100M文件,那剩余的900M仍然可为其它应用程序所使用,但它所占用的100M内存,是绝不会被系统回收重新划分的,否则谁还敢往里头存文件呢?通过df -h查看linux /dev/shm的大小[root@db1 shm]# df -h /dev/shmFilesystem Size Used Avail Use% Mounted ontmpfs 1.5G 0 1.5G 0% /dev/shmC.linux /dev/shm 容量(大小)调整linux /dev/shm容量(大小)是可以调整,在有些情况下(如oracle数据库)默认的最大一半内存不够用,并且默认的inode数量很低一般都要调高些,这时可以用mount命令来管理它。mount -o size=1500M -o nr_inodes=1000000 -o noatime,nodiratime -o remount /dev/shm在2G的机器上,将最大容量调到1.5G,并且inode数量调到1000000,这意味着大致可存入最多一百万个小文件通过/etc/fstab文件来修改/dev/shm的容量(增加size选项即可),修改后,重新挂载即可:[root@db1 shm]# grep tmpfs /etc/fstabtmpfs /dev/shm tmpfs defaults,size=2G 0 0[root@db1 /]# umount /dev/shm[root@db1 /]# mount /dev/shm[root@db1 /]# df -h /dev/shmFilesystem Size Used Avail Use% Mounted ontmpfs 2.0G 0 2.0G 0% /dev/shm[root@db1 /]# # mount -o remount /dev/shm[root@db1 /]# df -hFilesystem Size Used Avail Use% Mounted on/dev/mapper/rootvg-lv01 97G 9.2G 83G 10% //dev/sda1 99M 15M 80M 16% /boottmpfs 2.0G 0 2.0G 0% /dev/shm
【Oracle问题集1】ORA-00845: MEMORY_TARGET not supported on this system 详解
最新推荐文章于 2019-03-09 17:06:00 发布