Proxmox VE 8 试装Oracle 23c

作者:田逸(formyz)

Oracle 当前的最新版本是23c,虽然官方网站下载不了它的正式版本,但是却提供了一个性能受限的免费版本"Oracle Database 23.3 Free"(存储容量受限、内存使用受限)。这里就只好用这个免费的版本来做测试,免费的版本能正常部署,那么将来的正式版本的部署也不在话下。

Oracle 23C 提供如下几种安装方式:

  • Docker 容器。通过 docker pull container-registry.oracle.com/database/free:latest,直接从 Oracle Container Registry 拉取容器映像。
  • Oracle VM VirtualBox。将 23c Free 的 .ova 文件导入您的本地 Oracle VM VirtualBox 设置。
  • **包管理器。**配置软件仓库源,用包管理器"dnf/yum"进行在线安装,或者将RPM包下载到兼容性好的操作系统发行版(比如Oracle Linux 8、Rocky 8),再用包管理器(yum或者rpm)进行安装。

Oracle 23c 既然可以在Oracle的虚拟机平台VirtualBox安装,那么将其安装到Proxmox VE(以下简称PVE)也应该不是问题。

准备工作

浏览器登录PVE 8 Web管理后台,创建一个虚拟机,分配好资源,可以不分配硬盘、不使用任何安装介质,一个创建好的虚拟机配置如下图所示。

记下虚拟机的ID号"104",待用。

虚拟机恢复

SSH客户端登录PVE 8 宿主系统Debian 12,用wget或者curl下载VirtualBox镜像文件"Oracle_Database_23c_Free_Developer_Appliance.ova",官方的下载地址为https://download.oracle.com/otn_software/virtualbox/dd/Oracle_Database_23c_Free_Developer_Appliance.ova。这是一个压缩归档文件,用下面的命令进行解包。

|----------------------------------------------------------|
| tar xvf Oracle_Database_23c_Free_Developer_Appliance.ova |

bash 复制代码
tar xvf  Oracle_Database_23c_Free_Developer_Appliance.ova

命令执行完成后,将生成三个文件,两个以"vmdk"为后缀的虚拟机磁盘镜像文件和一个以"ovf"为后缀的文本文件,如下图所示。

三个文件,仅需对两个磁盘镜像文件进行处理。根据以前部署各种版本Oracle的经验,两个镜像磁盘应该是一个系统盘和一个数据盘(猜想)。

继续在命令行执行下列指令,将第一个磁盘镜像进行格式转换。

|-----------------------------------------------------------------------------------------------|
| qm disk import 104 'Oracle Database 23c Free Developer-disk001.vmdk' local-lvm --format qcow2 |

bash 复制代码
qm disk import 104 'Oracle Database 23c Free Developer-disk001.vmdk' local-lvm --format qcow2

解包出来的磁盘镜像文件名中间有空格,执行命令时需要用单引号将其作为一个整体,如果嫌麻烦,可以预先对其重命名,比如简化为"disk001-vmdk"(mv指令)。

数字104为预先创建好的虚拟机的ID号,转换后的格式为qcow2。命令执行过程如下图所示。

重复上述操作,将第二个磁盘镜像"Oracle Database 23c Free Developer-disk001.vmdk"也进行格式转换。操作成功完成后,切换到PVE 8 Web管理后台,在ID为"104"的虚拟机硬件配置里,将增加两块"未使用的磁盘",如下图所示。

鼠标双击上图"未使用磁盘0",将磁盘添加到虚拟机,并使其处于可使用状态,如下图所示。

如法炮制,将另外一个"未使用磁盘1"也添加到虚拟机。添加"未使用磁盘"到虚拟机的另一种方式是命令行,对应的指令如下。

|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| root@pve99:~/oracle# qm set 104 --scsi1 local-lvm:vm-104-disk-1 update VM 104: -scsi1 local-lvm:vm-104-disk-1 root@pve99:~/oracle# qm set 104 --scsi2 local-lvm:vm-104-disk-2 update VM 104: -scsi2 local-lvm:vm-104-disk-2 |

bash 复制代码
root@pve99:~/oracle# qm set 104 --scsi1 local-lvm:vm-104-disk-1

update VM 104: -scsi1 local-lvm:vm-104-disk-1

root@pve99:~/oracle# qm set 104 --scsi2 local-lvm:vm-104-disk-2

update VM 104: -scsi2 local-lvm:vm-104-disk-2

执行上述命令稍微需要注意的是,选项"scsi"编号不要发生冲突。

PVE 8 Web管理后台,修改目标虚拟机系统引导顺序。因为恢复出来的两个磁盘都是30G,不确定哪一个是系统盘,那么就把两块盘都勾选上,其他无关的引导项排除掉,如下图所示。

切换到虚拟机"104"控制台菜单,单击按钮"Start Now"启动虚拟机。

观察控制台输出,如果没有意外,Oracle Linux Server 8将正常启动,并且是以Oracle用户无密码登录系统。如果系统正常启动,但又无法登录,如下图所示。

不要慌,按组合键"Ctrl + Alt + F2",输入用户名"root",默认密码"oracle",正常进入系统。乘次机会,修改Oracle Linux Server 的网络地址(默认的地址是192.168.122.1)为自己环境的实际地址,重启网络服务,确保系统能被远程SSH客户端连接。

验证 Oracle 23c 安装的正确性

先来证实前边的猜想"一个系统盘和一个数据盘",命令提示符执行"df -h",果然是如此,系统盘"/dev/sda",数据盘"/dev/sdb1"挂接到目录"/opt/oracle",如下图所示。

进入目录"/opt/oracle",熟悉的目录结构一目了然。

|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [root@localhost ~]# cd /opt/oracle/ [root@localhost oracle]# ll total 4 drwxr-x---. 3 oracle oracle 18 Sep 13 19:34 admin drwxr-x---. 3 oracle oracle 18 Sep 13 19:34 audit drwxr-xr-x. 4 oracle oracle 31 Sep 13 19:34 cfgtoollogs drwxrwxr-x. 25 oracle oracle 4096 Sep 13 19:34 diag drwxr-x---. 3 oracle oracle 18 Sep 13 19:34 oradata drwxrwx---. 4 oracle oracle 78 Sep 13 19:50 oraInventory drwxr-xr-x. 3 oracle oinstall 17 Sep 13 19:31 product drwxr-xr-x. 4 oracle oinstall 32 Sep 13 19:30 userhome |

bash 复制代码
[root@localhost ~]# cd /opt/oracle/

[root@localhost oracle]# ll

total 4

drwxr-x---.  3 oracle oracle     18 Sep 13 19:34 admin

drwxr-x---.  3 oracle oracle     18 Sep 13 19:34 audit

drwxr-xr-x.  4 oracle oracle     31 Sep 13 19:34 cfgtoollogs

drwxrwxr-x. 25 oracle oracle   4096 Sep 13 19:34 diag

drwxr-x---.  3 oracle oracle     18 Sep 13 19:34 oradata

drwxrwx---.  4 oracle oracle     78 Sep 13 19:50 oraInventory

drwxr-xr-x.  3 oracle oinstall   17 Sep 13 19:31 product

drwxr-xr-x.  4 oracle oinstall   32 Sep 13 19:30 userhome

到系统目录"/etc/init.d"下,查看Oracle 23c启动脚本,一共有3个Shell脚本,都以"oracle"命名,如下图所示。

望文生义,手动执行命令"sh oracle-free-23c status",确认一下它是否为Oracle 23c服务(实例及监听器)的启动脚本,执行过程及输出如下。

|----------------------------------------------------------------------------------------------------------------------------------------------------|
| [root@localhost init.d]# sh oracle-free-23c status Status of the Oracle FREE 23c service: LISTENER status: RUNNING FREE Database status: RUNNING |

bash 复制代码
[root@localhost init.d]# sh oracle-free-23c status

Status of the Oracle FREE 23c service:



LISTENER status: RUNNING

FREE Database status:   RUNNING

查看系统进程,有大量以oracle账号启动,以"db_"为前缀运行着的进程(如下图所示),这可初步判断Oracle 实例已经随开机自动启动。

切换到账户oracle,执行下列查看监听器运行情况。

|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [root@localhost init.d]# su - oracle [oracle@localhost ~]$ lsnrctl status LSNRCTL for Linux: Version 23.0.0.0.0 - Production on 21-JAN-2024 04:47:54 Copyright (c) 1991, 2023, Oracle. All rights reserved. Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=localhost)(PORT=1521))) STATUS of the LISTENER ------------------------ Alias LISTENER Version TNSLSNR for Linux: Version 23.0.0.0.0 - Production Start Date 21-JAN-2024 04:32:07 Uptime 0 days 0 hr. 15 min. 47 sec Trace Level off Security ON: Local OS Authentication SNMP OFF Default Service FREE Listener Parameter File /opt/oracle/product/23c/dbhomeFree/network/admin/listener.ora Listener Log File /opt/oracle/diag/tnslsnr/localhost/listener/alert/log.xml Listening Endpoints Summary... (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=localhost)(PORT=1521))) (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(KEY=EXTPROC1521))) Services Summary... Service "0543b3ed61857640e0630100007f0bca" has 1 instance(s). Instance "FREE", status READY, has 1 handler(s) for this service... Service "FREE" has 1 instance(s). Instance "FREE", status READY, has 1 handler(s) for this service... Service "FREEXDB" has 1 instance(s). Instance "FREE", status READY, has 1 handler(s) for this service... Service "freepdb1" has 1 instance(s). Instance "FREE", status READY, has 1 handler(s) for this service... The command completed successfully |

bash 复制代码
[root@localhost init.d]# su - oracle

[oracle@localhost ~]$ lsnrctl status



LSNRCTL for Linux: Version 23.0.0.0.0 - Production on 21-JAN-2024 04:47:54



Copyright (c) 1991, 2023, Oracle.  All rights reserved.



Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=localhost)(PORT=1521)))

STATUS of the LISTENER

------------------------

Alias                     LISTENER

Version                   TNSLSNR for Linux: Version 23.0.0.0.0 - Production

Start Date                21-JAN-2024 04:32:07

Uptime                    0 days 0 hr. 15 min. 47 sec

Trace Level               off

Security                  ON: Local OS Authentication

SNMP                      OFF

Default Service           FREE

Listener Parameter File   /opt/oracle/product/23c/dbhomeFree/network/admin/listener.ora

Listener Log File         /opt/oracle/diag/tnslsnr/localhost/listener/alert/log.xml

Listening Endpoints Summary...

  (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=localhost)(PORT=1521)))

  (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(KEY=EXTPROC1521)))

Services Summary...

Service "0543b3ed61857640e0630100007f0bca" has 1 instance(s).

  Instance "FREE", status READY, has 1 handler(s) for this service...

Service "FREE" has 1 instance(s).

  Instance "FREE", status READY, has 1 handler(s) for this service...

Service "FREEXDB" has 1 instance(s).

  Instance "FREE", status READY, has 1 handler(s) for this service...

Service "freepdb1" has 1 instance(s).

  Instance "FREE", status READY, has 1 handler(s) for this service...

The command completed successfully

从输出可知,监听器是启动了的。

进一步,以Oracle 客户端sqlplus登录,查看实例运行情况。与以前的版本不同的是,Oracle 23c不能用"sqlplus / as sysdba"登录,而是需要用用户名和密码(Oracle 23c免费版本所有账号密码皆为"oracle",包括Oracle Linux Server 8操作系统密码),完整的登录指令及输出如下。

|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [oracle@localhost ~]$ sqlplus sys/oracle as sysdba SQL*Plus: Release 23.0.0.0.0 - Production on Sun Jan 21 04:54:08 2024 Version 23.3.0.23.09 Copyright (c) 1982, 2023, Oracle. All rights reserved. Connected to: Oracle Database 23c Free Release 23.0.0.0.0 - Develop, Learn, and Run for Free Version 23.3.0.23.09 SQL> select count(*) from v$session; COUNT(*) ---------- 65 |

bash 复制代码
[oracle@localhost ~]$ sqlplus sys/oracle as sysdba



SQL*Plus: Release 23.0.0.0.0 - Production on Sun Jan 21 04:54:08 2024

Version 23.3.0.23.09



Copyright (c) 1982, 2023, Oracle.  All rights reserved.





Connected to:

Oracle Database 23c Free Release 23.0.0.0.0 - Develop, Learn, and Run for Free

Version 23.3.0.23.09



SQL> select count(*) from v$session;



  COUNT(*)

----------

        65

实例也是正常启动的。

再切换回操作系统"root"账号,执行命令"/etc/init.d/oracle-free-23c stop"。检查Oracle实例进程、监听器状态及sqlplus登录,Oracle实例进程不存在、监听器状态为不可连接(TNS-12541: Cannot connect. No listener at host localhost port 1521)、及客户端sqlpus不能登录。由此可以准确无误的断定脚本"oracle-free-23c"一定是Oracle 23c服务的启动脚本。

上述过程,同样也验证了Oracle 23c安装的正确性。

相关推荐
CC呢6 分钟前
基于单片机的智能婴儿床监护系统多功能婴儿床摇篮系统
数据库·mongodb
林的快手1 小时前
209.长度最小的子数组
java·数据结构·数据库·python·算法·leetcode
HEU_firejef1 小时前
Redis——缓存预热+缓存雪崩+缓存击穿+缓存穿透
数据库·redis·缓存
KELLENSHAW2 小时前
MySQL45讲 第三十七讲 什么时候会使用内部临时表?——阅读总结
数据库·mysql
SelectDB3 小时前
飞轮科技荣获中国电信星海大数据最佳合作伙伴奖!
大数据·数据库·数据分析
core5123 小时前
flink cdc各种数据库 jar下载地址
mysql·oracle·flink·jar·oceanbase·cdc
小刘鸭!3 小时前
Hbase的特点、特性
大数据·数据库·hbase
凡人的AI工具箱3 小时前
每天40分玩转Django:Django表单集
开发语言·数据库·后端·python·缓存·django
奔跑草-3 小时前
【数据库】SQL应该如何针对数据倾斜问题进行优化
数据库·后端·sql·ubuntu
Elastic 中国社区官方博客4 小时前
如何通过 Kafka 将数据导入 Elasticsearch
大数据·数据库·分布式·elasticsearch·搜索引擎·kafka·全文检索