oracle一直是不支持debian系统的。怎奈领导非要在debian上装,所以开始。
1.创建目录及用户:
/usr/sbin/groupadd -g 501 oinstall && /usr/sbin/groupadd -g 502 dba && /usr/sbin/groupadd -g 503 oper && /usr/sbin/useradd -g oinstall -G dba,oper -d /home/oracle/ -s /bin/bash oracle
mkdir -p /data/ora11g/product/11.2.0.4/db_1 && mkdir -p /home/oracle && chown -R oracle:oinstall /data/ora11g && chmod -R 775 /data/ora11g && chown -R oracle:oinstall /home/oracle
2.安装依赖包
这里要配置好源 vi /etc/apt/sources.list
常用命令:
apt-cache pkgnames | grep libXp | more
apt-cache searche xxxx
安装好依赖包:(尽量检查全,不然后面不知道会报什么奇怪的错误)
apt-get install gcc g++ glibc-* libaio* libstdc++6 libstdc++-4.9-dev make binutils openjdk-7-jdk libc6 libc6-dev libstdc++6 libstdc++5 rpm gawk alien ksh lesstif2 libmotif3 libaio1 linux-headers-*common elfutils libaio-dev sysstat unixodbc-bin unixodbc-dev pdksh
3 . 修改配置文件
这里的机器配置是48核 120G内存,所以有些参数不要照抄 (top 按 1 看核数)
vi /etc/sysctl.conf
(至于这里的参数如何改,可以参考我的别的文章
http://blog.csdn.net/hkyw000/article/details/53486940)
fs.aio-max-nr = 1048576
fs.file-max = 6815744
kernel.shmall = 16515072
kernel.shmmax = 67645734912
kernel.shmmni = 4096
kernel.sem = 5010 641280 5010 128
net.ipv4.ip_local_port_range = 9000 65500
net.core.rmem_default = 262144
net.core.rmem_max = 4194304
net.core.wmem_default = 262144
net.core.wmem_max = 1048586
systcl -p 使之生效
vi /etc/security/limits.conf
oracle soft nproc 2047
oracle hard nproc 16384
oracle soft nofile 1024
oracle hard nofile 65536
vi /etc/pam.d/login 最后加上:
session required pam_limits.so
最后检查防火墙 iptables -F 清空所有规则。
4.解压文件
unzip p13390677_112040_Linux-x86-64_1of7.zip
unzip p13390677_112040_Linux-x86-64_2of7.zip
unzip p13390677_112040_Linux-x86-64_3of7.zip
5.开始静默安装
里面这些rsp模板文件的参数 自己看着改吧,不多说了。
./runInstaller -silent -force -ignoreSysPrereqs -ignorePrereq -responseFile /home/oracle/db_install.rsp
6 . 完成之后开始dbca建库的时候报错,缺少两个库文件
njni11,libclntsh.so.11.1
UnsatisfiedLinkError exception loading native library: njni11
Java.lang.UnsatisfiedLinkError: /data/ora11g/product/11.2.0/dbhome_1/lib/libnjni11.so: /data/ora11g/product/11.2.0/dbhome_1/lib/libclntsh.so.11.1: undefined symbol: nnfyboot
修改是把家目录下的inventory/Scripts/ext/lib/下的libclntsh.so.11.1 拷贝到$ORACLE_HOME/lib文件夹中去
7.之后dbca正常运行 但是开始报TNS无连接。后续安装监听后,sqlplus / as sysdba
登录也不行。lsnrctl命令无反应。 我这里采取了一个比较极端的方式,把别的机器的linux系统下正常运行的数据库机器上的 $ORACLE_HOME/bin 下的文件都 rsync到 这个debian机器上了。 之后就有反应了。。。其实很多奇怪诡异的地方,不好按正常思路解决。
8.这里贴两个标准的listener.ora 和tnsnames.ora 文件
LISTENER =
(DESCRIPTION_LIST =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.19)(PORT = 1521))
)
)
ADR_BASE_LISTENER = /data/ora11g
DIAG_ADR_ENABLED_LISTENER = OFF
SID_LIST_LISTENER =
(SID_LIST =
(SID_DESC =
(GLOBAL_DBNAME = test)
(ORACLE_HOME = /data/ora11g/product/11.2.0.4/db_1)
(SID_NAME = test)
)
(SID_DESC =
(SID_NAME = PLSExtProc)
(ORACLE_HOME = /data/ora11g/product/11.2.0.4/db_1)
(PROGRAM = extproc)
)
)
TEST =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.19)(PORT = 1521))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = test)
)
)
9 . 之后鉴于别的各种报错,决定手动建库
目录方面基本不用补了,因为开始都建的差不多了。
首先创建密码文件
orapwd file=orapwSID password=oracle entries=5
然后从好的机器上拷贝一份initXXX.ora文件,数据库以pfile启动到nomount状态
建库脚本:
create database test CONTROLFILE REUSE
MAXINSTANCES 8
MAXDATAFILES 3000
MAXLOGHISTORY 1024
MAXLOGFILES 64
MAXLOGMEMBERS 4
character set AL32UTF8 national character set AL16UTF16
logfile
group 1 ('/data/ora11g/oradata/test/redo01.log') size 1g reuse,
group 2 ('/data/ora11g/oradata/test/redo02.log') size 1g reuse,
group 3 ('/data/ora11g/oradata/test/redo03.log') size 1g reuse,
group 4 ('/data/ora11g/oradata/test/redo04.log') size 1g reuse,
group 5 ('/data/ora11g/oradata/test/redo05.log') size 1g reuse,
group 6 ('/data/ora11g/oradata/test/redo06.log') size 1g reuse,
group 7 ('/data/ora11g/oradata/test/redo07.log') size 1g reuse,
group 8 ('/data/ora11g/oradata/test/redo08.log') size 1g reuse,
group 9 ('/data/ora11g/oradata/test/redo09.log') size 1g reuse
datafile '/data/ora11g/oradata/test/system01.dbf' size 1g reuse extent management local
sysaux datafile '/data/ora11g/oradata/test/sysaux01.dbf' size 20g
default temporary tablespace temp tempfile '/data/ora11g/oradata/test/temp01.dbf' size 5g reuse
undo tablespace undotbs1 datafile '/data/ora11g/oradata/test/undotbs01.dbf' size 30g reuse
USER SYS IDENTIFIED BY "ora11g" USER SYSTEM IDENTIFIED BY "ora11g";
建库完成后要跑一个脚本,主要用什么用户来跑
spool /home/oracle/record.log
@?/rdbms/admin/catalog.sql ; (必跑,建数据字典视图)
@?/rdbms/admin/catproc.sql ; (必跑,建存储过程包)
@?/rdbms/admin/catblock.sql ; (建锁相关的几个视图)
@?/rdbms/admin/catoctk.sql ; (建密码工具包dbms_crypto_toolkit)
@?/rdbms/admin/owminst.plb ; (建工作空间管理相关对象,如dmbs_wm)
spool off
之后可以检查log 查看是否有不能接受的报错。
connect system/oracle
@?/sqlplus/admin/pupbld.sql
@?/sqlplus/admin/help/hlpbld.sql helpus.sql
connect /as sysdba
CREATE TABLESPACE USERS LOGGING DATAFILE '/data/ora11g/oradata/test/user01.dbf' SIZE 30g EXTENT MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT AUTO;
ALTER DATABASE DEFAULT TABLESPACE USERS;
最后重启数据库,到mount模式开启归档 ,结束。