oacle的安装
一.在oracle官网可以免费下载oracle的软件和安装文档,如果是在虚拟机中的linux系统里安装,可以用FileZilla Client把软件发送到系统中。
linux_11gR2_database_1of2.zip
linux_11gR2_database_2of2.zip
二.硬件要求
1.oracle11g内存至少是1G,磁盘不要选择虚拟机中默认的20G,要更大些(30,40即可)。
虚拟内存容量,检查的命令
内存
# grep MemTotal /proc/meminfo
交换空间
# grep SwapTotal /proc/meminfo
磁盘空间
# df -ah
三.软件要求
1.内核检查:cat /proc/version(一般CentOS都是符合文档要求的)
2.检查和安装所需的软件包
通过查看Oracle安装文档中列出的Package Requirements可以查看在不同平台上需要的软件包,下面列出Asianux 3, Oracle Enterprise Linux 5.0, and Red Hat Enterprise Linux 5.0的要求,检查下系统是否安装过这些包,如果没在对应的系统光盘查找对应的rpm包并安装。
检查工作:依次执行:rpm -qa | grep 下面软件包
binutils-2.17.50.0.6-2.el5
compat-libstdc++-33-3.2.3-61
elfutils-libelf-0.125-3.el5
elfutils-libelf-devel-0.125
glibc-2.5-12
glibc-common-2.5-12
glibc-devel-2.5-12
gcc-4.1.1-52
gcc-c++-4.1.1-52
libaio-0.3.106
libaio-devel-0.3.106
libgcc-4.1.1-52
libstdc++-4.1.1
libstdc++-devel-4.1.1-52.e15
make-3.81-1.1
sysstat-7.0.0
unixODBC-2.2.11
unixODBC-devel-2.2.11
缺少的软件包在CentOS-5.8-i386-bin-DVD-1of2.iso中可以找到,可以用FileZilla Client把软件包发送到系统中,如下图
一般缺少的如下:
elfutils-libelf-devel-0.137-3.el5.i386.rpm
libaio-devel-0.3.106
sysstat-7.0.0
unixODBC-2.2.11
unixODBC-devel-2.2.11
然后安装软件包,命令如下
rpm -ivh *.rpm
在安装时会提示出现问题,因为还需要其它软件包
再加上
unixODBC-libs-2.2.11-10.el5.i386.rpm
elfutils-libelf-devel-static-0.137-3.el5.i386.rpm
安装即可。
3.创建用户组和安装目录
root用户:创建Oracle安装组oinstall,数据库管理员组dba,及oracle用户,还有目录
groupadd oinstall
groupadd dba
mkdir -p /u01/oracle
useradd -g oinstall -G dba oracle -d /u01/oracle (主组oinstall,其它组:dba,默认的根目录是/u01/oracle)
但是在RHEL 5或CentOS5中安装oracle11g时,会出现下面的错误,
useradd: warning: the home directory already exists.
Not copying any file from skel directory into it.
进入/u01/oracle目录,没有.bash_profile',.bashrc,bash_logout
原因:
系统添加用户的标准步骤
1.编辑/etc/passwd与/etc/group
2.创建用户主目录
3.从/etc/skel拷贝文件与目录
4.让新用户获得其主目录与文件的拥有权限
5.给新用户一个密码
解决办法:
依旧使用上面的脚本建用户,然后手动拷贝配置文件到/u01/oracle下。
cp /etc/skel/.bash_profile /u01/oracle
cp /etc/skel/.bashrc /u01/oracle
cp /etc/skel/.bash_logout /u01/oracle
这样既可。
最后加密码和修改/u01的用户和用户组
passwd oracle
chown -R oracle:oinstall /u01
4.修改内核参数
root用户:修改 /etc/sysctl.conf 文件,加上如下参数
fs.aio-max-nr = 1048576
fs.file-max = 6815744
kernel.shmall = 2097152
kernel.shmmax = 536870912
kernel.shmmni = 4096
kernel.sem = 250 32000 100 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
为使上述配置生效而不重启系统,执行如下命令
# /sbin/sysctl -p
5.修改用户限制
root用户:修改 /etc/security/limits.conf 文件,加上下面的参数
oracle soft nproc 2047
oracle hard nproc 16384
oracle soft nofile 1024
oracle hard nofile 65536
6.修改用户验证选项
root用户下:修改/etc/pam.d/login文件加上如下参数
session required pam_limits.so
session required /lib/security/pam_limits.so
7.修改用户配置文件
root用户下:修改/etc/profile文件加入如下参数:
if [ $USER = "oracle" ]; then
if [ $SHELL = "/bin/ksh" ]; then
ulimit -p 16384
ulimit -n 65536
else
ulimit -u 16384 -n 65536
fi
fi
8.修改用户bash shell
su - oracle切换到oracle用户下
$ vi .bash_profile
增加如下内容,主要是修改
unset USERNAME
ORACLE_BASE=/u01
ORACLE_HOME=$ORACLE_BASE/oracle
ORACLE_SID=wilson
PATH=$ORACLE_HOME/bin:$PATH
export ORACLE_BASE ORACLE_HOME ORACLE_SID PATH
其中ORACLE_SID是你要设置的oracle sid,随便你取
完成后退出orcle用户,然后再进入,
#su –oracle
#env | grep ORA查看环境变量是否完成
四.oracle软件安装
1.在root用户下,解压两个文件
unzip linux_11gR2_database_1of2.zip
unzip linux_11gR2_database_2of2.zip
2.解压后会有个文件件目录:database
可以把这个目录移到/u01中(这一步不是必须的,建议这么做),
mv database/ /u01
把database目录下的文件修改为oracle用户可读的,
chown -R oracle:oinstall database
3.在database文件中有个runInstaller程序,执行这个程序要在图形界面下执行,必须以oracle用户登录,以oracle用户进行安装。
运行runInstaller程序,
$ ./runInstaller
4.然后按照提示安装,有一步选择只安装oracle软件,如下图
下图出现提示,继续YES
本来给出的是/oralInventory,将其修改为/u01/oralInventory,如下图
继续,将下面的dba组改为oinstall组。
go on,会发现到缺少一个pdksh-5.2.14-37.el5.i386.rpm软件包,
解决方法:参照上面——三.软件要求 2.检查和安装所需的软件包
然后选择重新检查,继续安装,即可。
运行完后,选择ok,即完成了oracle软件的安装。
五.在oracle中创建数据库
首先在11g版本中需要先执行netca命令来配置listener,如下图
继续,选择第一个,如下图
next,输入SID号,输入wilson(要和前面所设置的环境变量配套),如下图
各种的next,注意如下,设置字符集~~~如果要存储汉字使用unicode,如下图
即可完成oracle数据库的创建。
六.如果用SecureCRT登陆
1.在oracle用户的主目录下vi .bash_profie最后加上stty erase ^h,这样可以再其sqlplus中使用删除(Backspace)。
2. 在 Linux中oracle中如何使用rlwrap解决上下键使用出现乱码,请参照: 解决方法