原因:由于机器使用阿里云服务器,初期内存较大,所以选择中途降配,由8G减少到4G,降配完成后,数据库无法正常启动,报以下错误
ORA-00845: MEMORY_TARGET not supported on this system
经过查资料了解其原理后
发现:
原因可能:ORACLE MEMORY_TARGET参数设置超过了oracle服务器本身内存、或超过了现在服务器空闲内存(就是oracle启动时无法获取设置的内存),或者 超过了/dev/shm的大小/. 这些都有可能造成以上错误、
问题确认:
确认为oracle MEMORY_TARGET参数设置SGA大于操作系统的空闲内存,超过了/dev/shm的大小
解决:
修改MEMORY_TARGET的值为合适的范围之内(如果是正式环境切oracle需要设置MEMORY_TARGET的内存,需要增加服务器内存,本初不讨论)
1.备份现有spfile文件
1
|
cp
init.ora.715201510237 init.ora.715201510237_bak
|
2.使用spfile创建pfile(spfile为二进制文本,不可直接修改),修改pfile后,重新生成spfile
1
2
|
SQL>
create
pfile
from
spfile;
File created.
|
修改pfile参数*.memory_target=104857600(此处的值小于 操作系统的空闲内存,小于/dev/shm的大小)
1
2
3
|
SQL>
create
spfile
from
pfile;
File created.
确认后,启动oracle
|
3,如果以上完成后,还无法正常startup,
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
|
SQL> startup pfile=/app/oracle/admin/orcl/pfile/init.ora.103201271612
SQL>
alter
system
set
memory_max_target=1258M scope=both;
alter
system
set
memory_max_target=1258200M scope=both
*
ERROR
at
line 1:
|