[root@oracle ~]# /u01/app/oraInventory/orainstRoot.sh [root@oracle ~]# /u01/app/oracle/product/12.2.0/dbhome_1/root.sh //执行第二个脚本,遇到提示,一路回车即可!
Web页面访问如下:
接下来使用命令行进行登录访问:
首先需要解决sqlplus命令行方向键不能使用的问题,方法如下:
获取rlwrap软件包
[root@oracle ~]# yum -y install ncurses* readline* //安装软件包所需依赖 [root@oracle ~]# tar zxf rlwrap-0.30.tar.gz.zip -C /usr/src [root@oracle ~]# cd /usr/src/rlwrap-0.30/ [root@oracle rlwrap-0.30]# ./configure && make && make install //使用root身份进行编译安装,安装完成后即可使用! [oracle@oracle ~]$ rlwrap sqlplus "/ as sysdba" SQL*Plus: Release 12.2.0.1.0 Production on 星期二 11月 26 10:51:44 2019 Copyright (c) 1982, 2016, Oracle. All rights reserved. 连接到: Oracle Database 12c Enterprise Edition Release 12.2.0.1.0 - 64bit Production SQL>这样登录到数据库库时,就可以使用方向键了。但是这样每次登录数据库时都需要使用 rlwrap 命令稍嫌麻烦,可以进行一下操作:
[oracle@oracle ~]$ vim /home/oracle/.bash_profile ……………… //在末尾添加以下内容 alias sqlplus='rlwrap sqlplus' alias rman='rlwrap rman' //就是将命令创建别名而已
退出当前oracle用户,重新登录才可使用。
[oracle@oracle ~]$ sqlplus sys/123456 as sysdba //使用命令行登录 SQL*Plus: Release 12.2.0.1.0 Production on 星期二 11月 26 10:57:41 2019 Copyright (c) 1982, 2016, Oracle. All rights reserved. 连接到: Oracle Database 12c Enterprise Edition Release 12.2.0.1.0 - 64bit Production SQL>
或者
[oracle@oracle ~]$ sqlplus /nolog SQL*Plus: Release 12.2.0.1.0 Production on 星期二 11月 26 10:59:10 2019 Copyright (c) 1982, 2016, Oracle. All rights reserved. SQL> conn sys/123456 as sysdba 已连接。 //也可以使用这样方式登录Oracle数据库
二、创建Oracle 12c数据库
如果在安装oracle产品时不创建数据库,那么要使用oracle系统就必须先创建数据库。如果在安装oracle时选择建立数据库,也可以再创建第二个数据库(不过为了使oracle数据库充分利用系统资源,建议一个服务器上只创建一个数据库)。
创建数据库的方法有两种:通过图形化界面,或者采用“CREATE DATABASE”命令,这里说一下图形化界面创建数据库的方法:
[oracle@oracle ~]$ dbca //使用oracle用户创建数据库 //执行这条命令就会弹出图形化界面创建数据库
如果没有弹出窗口,可以参考前面的步骤,以root用户运行“xhost +”命令,再以oracle身份运行“export DISPLAY=:0.0”命令。
弹出的图形化界面如下:
数据库已经创建完成!
三、Oracle 12c数据库的启动与关闭
oracle数据库的启动与关闭是日常工作之一。对于大多数oracle DBA来说,启动和关闭oracle数据库最常用的方式是在命令行方式下执行。
1.启动、关闭Oracle数据库
要启动和关闭数据库,必须具有Oracle管理员权限的用户登录,通常以具有SYSDBA权限的用户登录。
(1)数据库的启动
启动一个数据库需要三个步骤:①启动oracle实例(非装载阶段);②由实例装载数据库(装载阶段);③打开数据库(打开阶段)。
在startup命令中,可以使用不同的选项来控制数据库的不同启动步骤。
1)startup nomount(该命令不常用)
nomount选项仅仅启动一个oracle实例,读取init.ora初始化参数文件、启动后台进程、初始化SGA。当实例启动后,系统将显示一个SGA内存结构和大小的列表,如下:
[oracle@oracle ~]$ sqlplus / as sysdba //以oracle用户登录数据库 SQL*Plus: Release 12.2.0.1.0 Production on 星期二 11月 26 11:18:36 2019 Copyright (c) 1982, 2016, Oracle. All rights reserved. 连接到: Oracle Database 12c Enterprise Edition Release 12.2.0.1.0 - 64bit Production SQL> startup nomount
2)startup mount(某些时候会用到该命令)
startup mount 命令启动实例并且装载数据库,但是没有打开数据库。oracle系统读取控制文件中关于数据文件和重做日志文件的内容,但并不打开该文件。这种打开方式常在数据库维护操作中使用,如对数据文件的更名、改变重做日志及打开归档模式等。在这种打开方式下,除了可以看到SGA系统列表以外,系统还会给出“数据库装载完毕”的提示。
SQL> alter database mount; //由于上面已经执行了startup nomount命令,所以再更改它的状态,就需要使用该命令
3)startup(正常时使用的命令)
startup命令完成启动实例,装载数据库和打开数据库三个步骤。此时,数据库使数据文件和重做日志文件在线,通常还会请求一个或者多个回滚段;系统除了可以看到前面startup mount 方式下的所有提示外,还会给出一个“数据库已经打开”的提示;数据库系统处于正常的工作状态,可以接收用户的请求。
如果采用startup nomount或者startup mount的数据库打开方式,必须采用alter database命令来执行装载或打开数据库的操作。
前面两条命令都执行过了(startup nomount和alter database mount),所以这里再执行下面命令,数据库就可以说是正确启动完成了。如下:
SQL> alter database open;
正常来说,可以直接使用下面一条命令来正常启动数据库,如下:
SQL> startup //在数据库关闭状态下执行该命令,数据库会依次启动、装载、打开。 ORACLE 例程已经启动。 Total System Global Area 1593835520 bytes Fixed Size 8793256 bytes Variable Size 1023411032 bytes Database Buffers 553648128 bytes Redo Buffers 7983104 bytes 数据库装载完毕。 数据库已经打开。
(2)数据库的关闭
对于数据库的关闭,有四种不同的关闭选项。
1)shutdown normal
shutdown normal是shutdown命令的默认选项。也就是说,如果用户发出shutdown命令,即执行shutdown normal命令。
发出该命令后,任何新的连接都将不再允许连接到数据库。在数据库关闭之前,oracle将等待目前连接的所有用户都从数据库中退出后才开始关闭数据库。采用这种方式关闭数据库,在下一次启动时不需要进行任何的实例恢复。但需要注意的是,采用这种方式时,也许关闭一个数据库需要几天或更长的时间。
2)shutdown immediate
shutdown immediate是常用的一种关闭数据库的方式。若即想很快地关闭数据库,又想让数据库“干净”的关闭,则常采用这种方式。
发出该命令后,当前正在被oracle处理的SQL语句立即中断,系统中任何没有提交的事务全部回滚。如果系统中存在一个很长的未提交的事务,那么采用这种方式关闭数据库也需要一段时间(该事务回滚时间)。系统不会等待连接到数据库的所有用户退出系统,而会强行回滚当前所有的活动事务,然后断开所有的连接用户。
3)shutdown transactional
shutdown transactional 命令常用来计划关闭数据库,它会等待当前连接到系统且正在活动的事务执行完毕,运行该命令后,任何新的连接和事务都是不允许的。它所有活动的事务执行完成后,数据库将以和shutdown immediate同样的方式关闭数据库。
4)shutdown abort
shutdown abort是关闭数据库方式的最后选择,是在没有任何办法关闭数据库的情况下不得不采用的方式,一般不要采用。在下列情况出现时可以考虑采用这种方式关闭数据库。
- 数据库处于一种非正常工作状态,不能用shutdown normal或shutdown immediate命令关闭数据库;
- 需要立即关闭数据库;
- 在启动数据库实例时遇到问题。
发出该命令后,所有正在运行的SQL语句将立即中止,所有未提交的事务将不回滚,oracle也不等待目前连接到数据库的用户退出系统;下一次启动数据库时需要实例恢复,因此,下一次启动可能比平时需要更多的时间。
在关闭数据库时最好使用shutdown immediate方式,因为这种方式安全且相对较快。不是万不得已不要使用shutdown abort 方式,因为这种方式会造成数据丢失,并且恢复数据库也需要较长时间。
2.启动、关闭oracle监听进程
当oracle数据库实例启动完成后,为了使客户端用户能连接到oracle实例,DBA还需要在oracle所在的服务器上使用lsnrctl命令启动监听进程。如果数据库实例关闭,一般也要关闭监听进程。
(1)启动监听
启动监听是oracle用户在操作系统下执行的命令,可以直接在lsnrctl后加参数,也可在该命令提示符后进行操作,具体如下:
[oracle@oracle ~]$ lsnrctl //执行该命令 LSNRCTL for Linux: Version 12.2.0.1.0 - Production on 25-9月 -2019 21:59:04 Copyright (c) 1991, 2016, Oracle. All rights reserved. 欢迎来到LSNRCTL, 请键入"help"以获得信息。 LSNRCTL> start //启动监听 启动/u01/app/oracle/product/12.2.0/dbhome_1//bin/tnslsnr: 请稍候... TNSLSNR for Linux: Version 12.2.0.1.0 - Production 系统参数文件为/u01/app/oracle/product/12.2.0/dbhome_1/network/admin/listener.ora 写入/u01/app/oracle/diag/tnslsnr/oracle/listener/alert/log.xml的日志信息 监听: (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=oracle)(PORT=1521))) 监听: (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(KEY=EXTPROC1521))) 正在连接到 (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=oracle)(PORT=1521))) LISTENER 的 STATUS ------------------------ 别名 LISTENER 版本 TNSLSNR for Linux: Version 12.2.0.1.0 - Production 启动日期 25-9月 -2019 21:59:12 正常运行时间 0 天 0 小时 0 分 0 秒 跟踪级别 off 安全性 ON: Local OS Authentication SNMP OFF 监听程序参数文件 /u01/app/oracle/product/12.2.0/dbhome_1/network/admin/listener.ora 监听程序日志文件 /u01/app/oracle/diag/tnslsnr/oracle/listener/alert/log.xml 监听端点概要... (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=oracle)(PORT=1521))) (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(KEY=EXTPROC1521))) 监听程序不支持服务 命令执行成功
也可以直接使用以下命令“来启动监听:
[oracle@oracle ~]$ lsnrctl start //启动监听
(2)关闭监听
[oracle@oracle ~]$ lsnrctl stop //关闭监听 LSNRCTL for Linux: Version 12.2.0.1.0 - Production on 25-9月 -2019 22:00:31 Copyright (c) 1991, 2016, Oracle. All rights reserved. 正在连接到 (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=oracle)(PORT=1521))) 命令执行成功
四、将Oracle数据库设置为开机自启动
[root@oracle ~]# vim /etc/oratab ……………… //修改以下内容 orcl:/u01/app/oracle/product/12.2.0/dbhome_1:Y [root@oracle ~]# vim /etc/rc.local su - oracle -c 'dbstart' //启动数据库 su - oracle -c 'lsnrctl start' //启用监听进程 [root@oracle ~]# chmod +x /etc/rc.d/rc.local //添加执行权限
重启之后,进行验证:
[root@oracle ~]# netstat -anpt | grep 5500 //oracle数据库的监听端口 tcp6 0 0 :::5500 :::* LISTEN 2144/tnslsnr [root@oracle ~]# netstat -anpt | grep 1521 //oracle数据库监听进程 tcp 0 0 192.168.1.1:24251 192.168.1.1:1521 ESTABLISHED 1816/ora_lreg_orcl tcp6 0 0 :::1521 :::* LISTEN 2144/tnslsnr tcp6 0 0 192.168.1.1:1521 192.168.1.1:24251 ESTABLISHED 2144/tnslsnr tcp6 0 0 192.168.1.1:1521 192.168.1.1:24143 TIME_WAIT -