安装包信息:linux_11gR2_database_1of2.zip,linux_11gR2_database_2of2.zip,FTP-linux/database下。
参考内容:
http://www.hack520.com/linux-oracle-config/(安装)
http://www.blogjava.net/xiangjava/archive/2010/06/23/324091.html(安装,本机连接数据库)
http://database.51cto.com/art/200911/160283.htm(创建用户,权限)
http://www.ha97.com/4788.html(解决启动报错问题)
http://zhumeng8337797.blog.163.com/blog/static/100768914201128840388/(远程连接配置,没有用到)
一,安装oracle前配置
1,安装依赖包
使用系统安装盘,yum install 方法安装,安装不完整也没有关系,oracle安装过程中会检测依赖包。
# yum install binutils
# yum install libaio libaio-devel
# yum install sysstat
# yum install unixODBC unixODBC-devel
# yum install compat-libstdc++-33
# yum install ksh
2、修改系统版本
vi /etc/redhat-release
redhat-4 #Red Hat Enterprise Linux Server release 5.4 (Tikanga)
因为oracle 的官方只支持到RHEL4为止,所以要修改版本说明。把Red Hat Enterprise Linux Server release 5.4 (Tikanga)这一行注释掉,前面加上一行redhat-4。当然oracle安装完成后要修改回来。redhat-4 必须为redhat-release文件的第一行,否则安装时还会报警告。
3、修改内核参数
#vi /etc/sysctl.conf
增加下面的内容到文件中:
kernel.shmall = 2097152 kernel.shmmax = 2147483648 kernel.shmmni = 4096 # semaphores: semmsl, semmns, semopm, semmni kernel.sem = 250 32000 100 128 fs.file-max = 65536 net.ipv4.ip_local_port_range = 1024 65000 net.core.rmem_default=262144 net.core.rmem_max=262144 net.core.wmem_default=262144 net.core.wmem_max=262144
我都加在最下面了,如下图:
运行下面的命令使得内核参数生效:
/sbin/sysctl --p
4、建立安装Oracle需要的用户、组及目录
(1)新增组和用户:
groupadd oinstall
groupadd dba
groupadd oper
useradd -g oinstall -G dba oracle
passwd oracle
(2)创建Oracle的安装目录,并把权限付给oracle用户:
mkdir -p /u01/app/oracle/product/11.2.0/db_1
chown -R oracle.oinstall /u01
5、设置oracle用户的shell limit
#vi /etc/security/limits.conf
增加下面的内容到文件 /etc/security/limits.conf 文件中:
* soft nproc 2047 * hard nproc 16384 * soft nofile 1024 * hard nofile 65536
增加下面的内容到文件 /etc/pam.d/login 中,使shell limit生效:
session required /lib/security/pam_limits.so
6、配置静态IP地址
安装RedHat Linux的时候最好采用静态IP地址,如果当时选择的是DHCP,现在需要更改/etc/sysconfig/network-scripts/ifcfg-eth0文件:
DEVICE=eth0 BOOTPROTO=dhcp HWADDR=00:0C:29:74:5B:62 ONBOOT=yes HWADDR=00:0C:29:74:5B:62 #你的mac地址 IPADDR=192.168.89.130 #你的IP地址 NETMASK=255.255.255.0 #你的IP地址 GATEWAY=192.168.89.1 #你的网关
因为我安装Linux的时候配置了静态IP,所以这里我不去动它。如下图:
7、修改/etc/hosts
把127.0.0.1改为具体的ip地址,注意最好去掉那些无用的,格式如下:
ip地址 – 主机名 – localhost
8、关闭SeLinux
因为SeLinux对oracle有影响,所以把Secure Linux设成无效,编辑文件/etc/selinux/config :
SELINUX=disabled
当然你也可以用图形界面下的工具 (系统 > 管理 > 安全级别和防火墙),选择SELinux页面并且设为无效。
9、配置Oracle用户的环境变量
登录到oracle用户并且配置环境变量,编辑/home/oracle目录下的.bash_profile文件
vi .bash_profile
增加下面的内容到文件 .bash_profile
# Oracle Settings TMP=/tmp; export TMP TMPDIR=$TMP; export TMPDIR ORACLE_BASE=/u01/app/oracle; export ORACLE_BASE ORACLE_HOME=$ORACLE_BASE/product/10.2.0/db_1; export ORACLE_HOME ORACLE_SID=orcl; export ORACLE_SID ORACLE_TERM=xterm; export ORACLE_TERM PATH=$PATH:$ORACLE_HOME/bin; export PATH LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$ORACLE_HOME/lib; export LD_LIBRARY_PATH CLASSPATH=$ORACLE_HOME/JREORACLE_HOME/jlib:$ORACLE_HOME/rdbms/jlib; export CLASSPATH if [ $USER = "oracle" ]; then if [ $SHELL = "/bin/ksh" ]; then ulimit -p 16384 ulimit -n 65536 else ulimit -u 16384 -n 65536 fi fi
我同样加到文件最下面,如下图:
里面的SID在安装数据库时候如果修改了,安装完后需要回来重新修改SID。修改完用“source .bash_profile”使其生效。
10、修改开机使用文本模式登录
如果没有下面这些步骤,oracle在安装时可能出现问题。可能会出现使用oracle用户启动安装界面的时候报错,无法启动图形化界面。
#vi /etc/inittab
把 id:5:initdefault: 修改为 id:3:initdefault,等oracle安装完成后可以修改回来。
#reboot(重启)
11、添加你的机器oracle用户可以使用图形化界面
在文本模式下,用root登录,然后:
解压
$ unzip linux.x64_11gR2_database_1of2.zip
$ unzip linux.x64_11gR2_database_2of2.zip
# startx
# xhost +# su - oracle
$ export DISPLAY="192.168.89.130:0.0" #此处修改为你的IP地址
$ export LANG=en_US #设置运行语言
$ cd /hqw/databases #进入Oracle安装目录
$ ./runInstaller #开始安装喽
二,安装
1,我安装的是英文版的,过程中没有截图,下次补上。基本上按照步骤向下进行即可。下图是检查依赖包的图,上面有几个失败的我没有理会。
2,下图是10版本的安装图,与11类似。装到最后时,提示运行两个脚本,按照提示在终端执行(使用root权限执行)。
3,安装完成后,恢复默认设置:
恢复语言环境以及版本信息:
#export LC_CTYPE=zh_CN.UTF-8
#vi /etc/redhat-release
Red Hat Enterprise Linux Server release 5.4 (Tikanga)
修改oracle用户修改环境变量:
#vi .bash_profile
修改安装过程中你修改过的SID及安装路径,如果你修改了的话。
修改图形化界面登录:
#vi /etc/inittab
把 id:3:initdefault: 修改为 id:5:initdefault
三,本机连接数据库
启动和停止监听器:
监听器接受客户端的连接请求,并在验证证书后创建数据库连接。要使用 OEM,必须先启动监听器。
$ lsnrctl start
$ lsnrctl stop
启动和停止数据库:
1.启动和停止数据库的最简单方法是从 OEM 控制台启动和停止。要从命令行执行此操作,请在以 oracle 身份登录后使用 SQL*Plus,如下所示:
启动:
$ sqlplus
Enter user-name: / as sysdba
SQL> startup
SQL> exit
停止:
$ sqlplus
Enter user-name: / as sysdba
SQL> shutdown immediate
SQL> exit
数据库操作:
略过。
四,配置远程连接数据库
1,创建用户admin,为用户添加权限
SQL>create user admin identified by nimda;
SQL>grant dba to admin;--授予DBA权限
SQL> grant unlimited tablespace to admin;--授予不限制的表空间
SQL>grant select any table to admin;--授予查询任何表
SQL> grant select any dictionary to admin;--授予 查询 任何字典
2,开启1521端口关闭防火墙或者在配置文件中开启端口。
#service iptables stop
3,解决$ lsnrctl start 报 The listener supports no services错误的问题。
这样启动后远程连接会报错:
oracle ORA-12514:TNS:listener does not currently know of service requested in connect descriptor
问题原因:数据库实例没注册到listener
解决方法一:
在listener.ora里面添加了一行
SID_LIST_LISTENER = (SID_LIST = (SID_DESC = (GLOBAL_DBNAME = orcl) (SID_NAME = orcl) ) )
注:里面的orcl根据你安装的数据库实例名确定,我用此法解决了这个报错。
重启监听
$ lsnrctl stop
$ lsnrctl start
4,windows使用Navicat进行连接
连接成功
后