Centos7.8静默安装企业版Oracle11g和创建实例

1、安装环境准备:

A、系统版本和oracle11g企业版安装软件压缩包:

[root@dbprimary07 ~]# cat /etc/redhat-release 
CentOS Linux release 7.8.2003 (Core)
[root@dbprimary07 ~]# uname -a
Linux dbprimary07 3.10.0-1127.el7.x86_64 #1 SMP Tue Mar 31 23:36:51 UTC 2020 x86_64 x86_64 x86_64 GNU/Linux
 
linux.x64_11gR2_database_1of2.zip
linux.x64_11gR2_database_2of2.zip

B、 HostName修改

hostnamectl set-hostname dbprimary07

C、关闭selinux

sed -i 's#SELINUX=enforcing#SELINUX=disabled#g' /etc/selinux/config

重启系统reboot

D 、配置内核参数

[root@dbprimary07 ~]# cat /etc/sysctl.conf 
# System default settings live in /usr/lib/sysctl.d/00-system.conf.
# To override those settings, enter new settings here, or in an /etc/sysctl.d/<name>.conf file
#
# For more information, see sysctl.conf(5) and sysctl.d(5).
fs.aio-max-nr = 1048576
fs.file-max = 6815744
kernel.shmall = 2097152
kernel.shmmax = 7516192768 #7Gkernel.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 = 1048576

修改后使之生效

/sbin/sysctl -p

E、修改用户权限

root用户

vim  /etc/security/limits.conf
#在末尾添加
oracle soft nproc 2047
oracle hard nproc 16384
oracle soft nofile 1024
oracle hard nofile 65536
oracle soft stack 10240
oracle hard stack 10240

F、在/etc/pam.d/login 文件中,使用文本编辑器或vi命令增加或修改以下内容

session required /lib64/security/pam_limits.so
session required pam_limits.so

G、在/etc/profile 文件中,使用文本编辑器或vi命令增加或修改以下内容

if [ $USER = "oracle" ]; then
   if [ $SHELL = "/bin/ksh" ]; then
       ulimit -p 16384
       ulimit -n 65536
    else
       ulimit -u 16384 -n 65536
   fi
fi

#使之生效:
source /etc/profile

2 安装oracle11g-EE版本主要步骤

2.1创建oracle用户,及用户组
2.2配置oracle用户环境变量
2.3修改安装Oracle软件的响应文件db_install.rsp,静默安装
2.4静默dbca建库,编辑应答文件dbca.rsp
2.5 登陆数据库,测试是否安装成功
2.6 rlwrap安装

具体步骤如下:

2.1创建oracle用户,及用户组

#创建oinstall和dba组

/usr/sbin/groupadd oinstall
/usr/sbin/groupadd dba

#创建Oracle用户:-d /u01/oracle,将用户创建到/u01下,默认是在/home下

useradd -g oinstall -G dba oracle -d /u01/oracle

#设置oracle密码

passwd oracle

#验证创建及所属组是否正确:id oracle
#输出结果如下

uid=1001(oracle) gid=1001(oinstall) groups=1001(oinstall),1002(dba)

2.2配置oracle用户环境变量

su - oracle
vim ~/.bash_profile 
##提示要是不存在/u01/oracle/.bash_profile 文件,可以创建一个系统用户test001,把他的家目录下的隐藏文件复制到/u01/oracle/目录下
[root@dbprimary07 ~]# useradd test001
[root@dbprimary07 ~]# cp /home/test001/.* /u01/oracle/

然后再
su - oracle
vim ~/.bash_profile 
#添加如下内容,注意修改的是oracle用户的环境变量,su - oracle切换用户
export ORACLE_BASE=/u01/oracle/tools/oracle11g
export ORACLE_HOME=$ORACLE_BASE/product/11.2.0/dbhome_1
export ORACLE_SID=orcl
export ORACLE_UNQNAME=orcl
export NLS_LANG=.AL32UTF8
export PATH=${PATH}:${ORACLE_HOME}/bin/:$ORACLE_HOME/lib64

#使配置生效
source ~/.bash_profile

2.3修改安装Oracle软件的响应文件db_install.rsp,静默安装

su - oracle 
创建响应文件配置目录
mkdir  -p /u01/oracle/etc  

创建oracle安装目录
mkdir  -p  /u01/oracle/tools/oracle11g 
mkdir -p  /u01/oracle/tools/oraInventory
mkdir -p /u01/oracle/tools/oracle11g/product/11.2.0/dbhome_1 
mkdir -p /u01/oracle/tools/oracle11g/oradata 
mkdir -p /u01/oracle/tools/oracle11g/fast_recovery_area

#将下载的压缩文件解压到/u01/oracle目录下,解压完成后/u01/oracle目录下会生成一个database目录
unzip linux.x64_11gR2_database_1of2.zip -d /u01/oracle 
unzip linux.x64_11gR2_database_2of2.zip -d /u01/oracle 

#将/u01/oracle/database/response下dbca.rsp,db_install.rsp,netca.rsp的文件拷贝到/u01/oracle/etc下
cp /u01/oracle/database/response/*  /u01/oracle/etc

#编辑/u01/oracle/etc下的db_install.rsp文件(注意要用oracle用户编辑)
vi /u01/oracle/etc/db_install.rsp

在db_install.rsp中找到要修改的配置

db_install.rsp中配置文件参数如下:

[oracle@dbprimary07 ~]$ cat /u01/oracle/etc/db_install.rsp
oracle.install.responseFileVersion=/oracle/install/rspfmt_dbinstall_response_schema_v11_2_0
oracle.install.option=INSTALL_DB_SWONLY
ORACLE_HOSTNAME=oracle
UNIX_GROUP_NAME=oinstall
INVENTORY_LOCATION=/u01/oracle/tools/oraInventory
SELECTED_LANGUAGES=en,zh_CN,zh_TW
ORACLE_HOME=/u01/oracle/tools/oracle11g/product/11.2.0/dbhome_1 
ORACLE_BASE=/u01/oracle/tools/oracle11g 
oracle.install.db.InstallEdition=EE
oracle.install.db.isCustomInstall=false
oracle.install.db.customComponents=oracle.server:11.2.0.1.0,oracle.sysman.ccr:10.2.7.0.0,oracle.xdk:11.2.0.1.0,oracle.rdbms.oci:11.2.0.1.0,oracle.network:11.2.0.1.0,oracle.network.listener:11.2.0.1.0,oracle.rdbms:11.2.0.1.0,oracle.options:11.2.0.1.0,oracle.rdbms.partitioning:11.2.0.1.0,oracle.oraolap:11.2.0.1.0,oracle.rdbms.dm:11.2.0.1.0,oracle.rdbms.dv:11.2.0.1.0,orcle.rdbms.lbac:11.2.0.1.0,oracle.rdbms.rat:11.2.0.1.0
oracle.install.db.DBA_GROUP=dba
oracle.install.db.OPER_GROUP=oinstall
oracle.install.db.CLUSTER_NODES=
oracle.install.db.config.starterdb.type=
oracle.install.db.config.starterdb.globalDBName=orcl
oracle.install.db.config.starterdb.SID=orcl
oracle.install.db.config.starterdb.characterSet=AL32UTF8
oracle.install.db.config.starterdb.memoryOption=true
oracle.install.db.config.starterdb.memoryLimit=
oracle.install.db.config.starterdb.installExampleSchemas=false
oracle.install.db.config.starterdb.enableSecuritySettings=true
oracle.install.db.config.starterdb.password.ALL=oracle
oracle.install.db.config.starterdb.password.SYS=
oracle.install.db.config.starterdb.password.SYSTEM=
oracle.install.db.config.starterdb.password.SYSMAN=
oracle.install.db.config.starterdb.password.DBSNMP=
oracle.install.db.config.starterdb.control=DB_CONTROL
oracle.install.db.config.starterdb.gridcontrol.gridControlServiceURL=
oracle.install.db.config.starterdb.dbcontrol.enableEmailNotification=false
oracle.install.db.config.starterdb.dbcontrol.emailAddress=
oracle.install.db.config.starterdb.dbcontrol.SMTPServer=
oracle.install.db.config.starterdb.automatedBackup.enable=false
oracle.install.db.config.starterdb.automatedBackup.osuid=
oracle.install.db.config.starterdb.automatedBackup.ospwd=
oracle.install.db.config.starterdb.storageType=
oracle.install.db.config.starterdb.fileSystemStorage.dataLocation=/u01/oracle/tools/oracle11g/oradata
oracle.install.db.config.starterdb.fileSystemStorage.recoveryLocation=/u01/oracle/tools/oracle11g/fast_recovery_area
oracle.install.db.config.asm.diskGroup=
oracle.install.db.config.asm.ASMSNMPPassword=
MYORACLESUPPORT_USERNAME=
MYORACLESUPPORT_PASSWORD=
SECURITY_UPDATES_VIA_MYORACLESUPPORT=
DECLINE_SECURITY_UPDATES= true
PROXY_HOST=
PROXY_PORT=
PROXY_USER=
PROXY_PWD=
[oracle@dbprimary07 ~]$ 

#用db_install.rsp文件开始静默安装oracle软件

su - oracle 
cd /u01/oracle/database
./runInstaller -silent -ignorePrereq -ignoreSysPrereqs -responseFile  /u01/oracle/etc/db_install.rsp

#安装完成,提示Successfully Setup Software.如下:

==========================================================
/u01/oracle/tools/oraInventory/orainstRoot.sh
/u01/oracle/tools/oracle/oracle11g/product/11.2.0/db_1/root.sh
To execute the configuration scripts:
1. Open a terminal window 
2. Log in as "root" 
3. Run the scripts 
4. Return to this window and hit "Enter" key to continue
 
Successfully Setup Software.
==========================================================

#退出oracle 用户,用root用户执行脚本。安装完后会在Successfully Setup Software上方出现执行脚本路径

exit
sh /u01/oracle/tools/oraInventory/orainstRoot.sh
sh /u01/oracle/tools/oracle/oracle11g/product/11.2.0/db_1/root.sh

2.4静默dbca建库,编辑应答文件dbca.rsp

##应答文件dbca.rsp参数如下:

[oracle@dbprimary07 ~]$ cat /u01/oracle/etc/dbca.rsp
[GENERAL]
RESPONSEFILE_VERSION = "11.2.0"
OPERATION_TYPE = "createDatabase"
[CREATEDATABASE]
GDBNAME = "orcl"
SID = "orcl"
TEMPLATENAME = "General_Purpose.dbc"
SYSPASSWORD = "oracle"
SYSTEMPASSWORD = "oracle"
[createTemplateFromDB]
SOURCEDB = "myhost:1521:orcl"
SYSDBAUSERNAME = "system"
TEMPLATENAME = "My Copy TEMPLATE"
[createCloneTemplate]
SOURCEDB = "orcl"
TEMPLATENAME = "My Clone TEMPLATE"
[DELETEDATABASE]
SOURCEDB = "orcl"
[generateScripts]
TEMPLATENAME = "New Database"
GDBNAME = "orcl11.us.oracle.com"
[CONFIGUREDATABASE]
[ADDINSTANCE]
DB_UNIQUE_NAME = "orcl11g.us.oracle.com"
NODELIST=
SYSDBAUSERNAME = "sys"
[DELETEINSTANCE]
DB_UNIQUE_NAME = "orcl11g.us.oracle.com"
INSTANCENAME = "orcl11g"
SYSDBAUSERNAME = "sys"

# 执行:

$ORACLE_HOME/bin/dbca -silent -responseFile /u01/oracle/etc/dbca.rsp

[oracle@dbprimary07 ~]$ $ORACLE_HOME/bin/dbca -silent -responseFile /u01/oracle/etc/dbca.rsp
Copying database files
1% complete
3% complete
11% complete
18% complete
37% complete
Creating and starting Oracle instance
40% complete
45% complete
50% complete
55% complete
56% complete
60% complete
62% complete
Completing Database Creation
66% complete
70% complete
73% complete
85% complete
96% complete
100% complete
Look at the log file "/u01/oracle/tools/oracle11g/cfgtoollogs/dbca/orcl/orcl1.log" for further details.

#若实例创建错误,删除实例命令

$ORACLE_HOME/bin/dbca -silent -deleteDatabase -sourcedb orcl

#设置Oracle开机启动

vi /etc/oratab

orcl:/u01/oracle/tools/oracle11g/product/11.2.0/dbhome_1:Y  # //把“N”改成“Y”

2.5.登陆数据库

su - oracle
sqlplus / as sysdba
或者下面 
sqlplus system/oracle as sysdba
sqlplus sys/oracle as sysdba
#system代表系统账户
#oracle代表密码

# 启动oracle实例
SQL> startup
不挂载启动oracle实例
SQL> startup nomount;
# 关闭oracle实例
SQL> shutdown immediate;

2.6 rlwrap安装

#安装过程如下:

yum install ncurses-devel readline-devel  -y
tar -zxvf rlwrap-0.42.tar.gz 
cd rlwrap-0.42/
./configure
make &&make install 

3.安装过程中可能遇到的报错

The Oracle system identifier(SID) "orcl" already exists. Specify another SID

解决办法:
1、删除u01/admin下的orcl文件
2、删除u01/oradata下的orcl文件夹
3、用root用户以远程登录模式编辑/etc/oratab,删除或者注释掉最后一行orcl。

[oracle@dbprimary07 ~]$ tail -1 /etc/oratab 
orcl:/u01/oracle/tools/oracle11g/product/11.2.0/dbhome_1:N    

4.登录oracle11g实例简单应用

4.1查看数据库实例和创建时间

SQL> select name,created  from v$database;

NAME
--------------------
CREATED
---------------
ORCL
09-OCT-24

SQL> set line 100
SQL> select name,created  from v$database;

NAME                        CREATED
--------------------------- ---------------
ORCL                        09-OCT-24

4.2查看数据库版本

SQL> select * from v$version;

BANNER
----------------------------------------------------------------------------------------------------
Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production
PL/SQL Release 11.2.0.1.0 - Production
CORE    11.2.0.1.0      Production
TNS for Linux: Version 11.2.0.1.0 - Production
NLSRTL Version 11.2.0.1.0 - Production

4.3查看服务名

SELECT name FROM dba_services; (需要dba权限)
SELECT name FROM v$services;(查看V$SERVICES视图,这个视图不需要DBA权限)

SQL> SELECT name FROM dba_services; 

NAME
----------------------------------------------------------------------------------------------------
SYS$BACKGROUND
SYS$USERS
uni_dg1
orclXDB
orcl

SQL> SELECT name FROM v$services;

NAME
----------------------------------------------------------------------------------------------------
orclXDB
uni_dg1
SYS$BACKGROUND
SYS$USERS

4.4查看当前数据库服务名

SQL> SELECT instance_name FROM v$instance;

INSTANCE_NAME
------------------------------------------------
orcl

4.5查看所有Oracle数据库实例的服务名

SQL> select instance_name FROM v$instance WHERE instance_name IS NOT NULL;

INSTANCE_NAME
------------------------------------------------
orcl

4.6查看字符集:

SELECT * FROM NLS_DATABASE_PARAMETERS p where p.PARAMETER='NLS_CHARACTERSET';
SELECT USERENV('language') FROM DUAL;

4.7查看数据库名称和创建时间:

SQL> select name,created  from v$database;

NAME      CREATED
--------- ------------------
ORCL      17-SEP-24

4.8创建数据库和拥有该库all权限的用户

#创建数据库表空间

create tablespace mytestdb01 datafile '/u01/oracle/tools/oracle11g/oradata/mytestdb01' size 10m autoextend on;
#说明:末尾带autoextend on参数表示当表空间大小不够用时会自动扩容,所有建议加上autoextend on参数。

#查看mytestdb01表空间
SQL> set line 200
SQL> select * from v$tablespace where NAME='MYTESTDB01';

       TS# NAME                                                                                       INCLUDED_ BIGFILE   FLASHBACK ENCRYPT_I
---------- ------------------------------------------------------------------------------------------ --------- --------- --------- ---------
         6 MYTESTDB01                                                                                 YES       NO        YES

SQL>

#创建用户zhangsan拥有库mytestdb01权限

SQL> 
SQL> create user zhangsan identified by pass123321 default tablespace mytestdb01 quota 3m on users;

User created.
SQL> grant all privileges to zhangsan;

Grant succeeded.

#当前采用zhangsan/pass123321登录

查看当前登录用户

[oracle@dbprimary07 etc]$ sqlplus  zhangsan/pass123321

SQL> SELECT USER FROM DUAL;

USER
--------------------------------------------------------------------------------
ZHANGSAN
SQL> show user;
USER is "ZHANGSAN"

##创建测试表和插入测试数据

#创建测试表:
CREATE TABLE employees (
    employee_id NUMBER PRIMARY KEY,
    first_name VARCHAR2(50),
    last_name VARCHAR2(50),
    hire_date DATE,
    salary NUMBER
);

插入数据:
INSERT INTO employees (employee_id, first_name, last_name, hire_date, salary)
VALUES (1, 'John', 'Doe', '01-Jan-2021', 001);
commit;

查看表数据:
select * from employees  

查看用户zhangsan下所拥有的表以及表对应的行数:

SQL> SELECT table_name, num_rows  FROM all_tables WHERE owner = 'ZHANGSAN';

TABLE_NAME
--------------------------------------------------------------------------------
  NUM_ROWS
----------
EMPLOYEES

4.9查看表空间是否开启自动

SQL> set line 400

SQL> select file_name,tablespace_name,autoextensible from dba_data_files;

FILE_NAME
----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
TABLESPACE_NAME                                                                            AUTOEXTEN
------------------------------------------------------------------------------------------ ---------
/u01/oracle/tools/oracle11g/oradata/orcl/users01.dbf
USERS                                                                                      YES

/u01/oracle/tools/oracle11g/oradata/orcl/undotbs01.dbf
UNDOTBS1                                                                                   YES

/u01/oracle/tools/oracle11g/oradata/orcl/sysaux01.dbf
SYSAUX                                                                                     YES


FILE_NAME
----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
TABLESPACE_NAME                                                                            AUTOEXTEN
------------------------------------------------------------------------------------------ ---------
/u01/oracle/tools/oracle11g/oradata/orcl/system01.dbf
SYSTEM                                                                                     YES

/u01/oracle/tools/oracle11g/oradata/mytestdb01
MYTESTDB01                                                                                 NO

5.0数据库表空间使用情况查看

select upper(f.tablespace_name) "TS-name",
 d.tot_grootte_mb "TS-bytes(m)",
 d.tot_grootte_mb - f.total_bytes "TS-used (m)",
 f.total_bytes "TS-free(m)",
 to_char(round((d.tot_grootte_mb - f.total_bytes) / d.tot_grootte_mb * 100,
 2),
 '990.99') "TS-per"
 from (select tablespace_name,
 round(sum(bytes) / (1024 * 1024), 2) total_bytes,
 round(max(bytes) / (1024 * 1024), 2) max_bytes
 from sys.dba_free_space
 group by tablespace_name) f, 
 (select dd.tablespace_name,
 round(sum(dd.bytes) / (1024 * 1024), 2) tot_grootte_mb
 from sys.dba_data_files dd
 group by dd.tablespace_name) d
where d.tablespace_name = f.tablespace_name
order by 5 desc;
SQL> select upper(f.tablespace_name) "TS-name",
  2   d.tot_grootte_mb "TS-bytes(m)",
  3   d.tot_grootte_mb - f.total_bytes "TS-used (m)",
  4   f.total_bytes "TS-free(m)",
  5   to_char(round((d.tot_grootte_mb - f.total_bytes) / d.tot_grootte_mb * 100,
  6   2),
  7   '990.99') "TS-per"
  8   from (select tablespace_name,
  9   round(sum(bytes) / (1024 * 1024), 2) total_bytes,
 10   round(max(bytes) / (1024 * 1024), 2) max_bytes
 11   from sys.dba_free_space
 12   group by tablespace_name) f, 
 13   (select dd.tablespace_name,
 14   round(sum(dd.bytes) / (1024 * 1024), 2) tot_grootte_mb
 15   from sys.dba_data_files dd
 16   group by dd.tablespace_name) d
 17  where d.tablespace_name = f.tablespace_name
 18  order by 5 desc;

TS-name                                                                                    TS-bytes(m) TS-used (m) TS-free(m) TS-per
------------------------------------------------------------------------------------------ ----------- ----------- ---------- ---------------------
SYSTEM                                                                                             670      667.19       2.81   99.58
SYSAUX                                                                                             470      446.06      23.94   94.91
USERS                                                                                                5        1.31       3.69   26.20
UNDOTBS1                                                                                            30        5.69      24.31   18.97
MYTESTDB01                                                                                          10        1.12       8.88   11.20

以上就是oracle11g 企业版静默安装过程以及简单的sql操作应用过程,希望能够帮助到oracle用户初学者,笔者技术水平有限,如有不当之处欢迎指证。

posted @ 2024-11-07 11:17  勤奋的蓝猫  阅读(16)  评论(0编辑  收藏  举报