Debian 8 下安装 oracle 11g(手动建库非ASM)

    xiaoxiao2021-04-12  34

    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模式开启归档 ,结束。

    转载请注明原文地址: https://ju.6miu.com/read-668257.html

    最新回复(0)