转眼间已经2023年,再有一周就要过年了,在这里先给大家拜个早年,祝大家新的一年万事顺利。

Oracle如今版本号也和年份挂钩,在前段时间的OCW上也宣布发布了beta版本的23c,因为23c是继19c之后的另一个长期支持版本,所以今天就下载安装测试尝尝鲜。

自己的测试环境目前剩余资源有限,就先装个单实例的23c体验下吧:

1.准备系统环境

直接依据db1克隆出一个机器供23c安装使用。
克隆后配置需要的内存8G,修改下主机名db23c、IP地址:192.168.1.23

[root@bogon ~]# virt-clone -o db1 -n 23c --auto-clone
[root@bogon ~]# virsh start db1
[root@bogon ~]# virsh setmem 8192000
[root@bogon ~]# virsh console 23c [root@db01xx ~]# hostnamectl set-hostname db23c
[root@db01xx ~]# vi /etc/hosts
[root@db01xx ~]# vi /etc/sysconfig/network-scripts/ifcfg-eth0
[root@db01xx ~]# vi /etc/sysconfig/network-scripts/ifcfg-ens9
[root@db01xx ~]# reboot

嗯,有虚拟机克隆起来真是太香了!

2.安装介质上传

因为模版中之前没上传23c的介质,所以需要拷贝上传下:

jingyuzhao@jingyuzhao-mac 23c % scp db_home.zip root@192.168.1.23:/u01/media
root@192.168.1.23's password:
db_home.zip 40% 1520MB 11.1MB/s 03:24 ETA

无线网络直接传的,速度不快,但11MB/s的速度还可以接受,就不折腾去连千兆网线了。

3.安装23c软件并创建数据库

1) 安装Oracle用户、组、设置密码

groupadd -g 54321 oinstall
groupadd -g 54322 dba useradd -u 54321 -g oinstall -G dba oracle echo oracle | passwd --stdin oracle

2) 创建$ORACLE_BASE目录并赋予上层目录oracle权限:

mkdir -p /u01/app/oracle
chown -R oracle:oinstall /u01/app

3) 安装好Oracle需要的rpm包

先安装19c需要的rpm包,如果缺少再安装,整理后回填到这里,供下次安装参考。

等23c正式官方文档出来后,再按文档说明安装。

yum -y install oracle-database-preinstall-19c

4)修改配置文件 /etc/security/limits.conf

oracle soft nproc 16384
oracle hard nproc 16384
oracle soft nofile 1024
oracle hard nofile 65536
oracle soft stack 10240
oracle hard stack 32768

5)修改配置文件 /etc/sysctl.conf

增加如下内容:

vm.swappiness = 1
vm.dirty_background_ratio = 3
vm.dirty_ratio = 80
vm.dirty_expire_centisecs = 500
vm.dirty_writeback_centisecs = 100
kernel.shmmni = 4096
kernel.shmall = 1073741824
kernel.shmmax = 4398046511104
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
fs.aio-max-nr = 1048576
fs.file-max = 6815744
kernel.panic_on_oops = 1

然后 sysctl -p 生效。

6)Oracle用户环境变量配置

vi ~/.bash_profile

export ORACLE_BASE=/u01/app/oracle
export ORACLE_HOME=/u01/app/oracle/product/23.0.0/db_1
export ORACLE_SID=demo23
export PATH=$ORACLE_HOME/bin:$PATH

7)Oracle用户解压oracle软件安装包

mkdir -p /u01/app/oracle/product/23.0.0/db_1
cd $ORACLE_HOME
unzip /u01/media/db_home.zip

8)使用图形界面安装数据库软件,dbca建库,netca创建监听

export DISPLAY=192.168.1.9:0.0
./runInstaller

居然遇到错误了。。

[oracle@db23c db_1]$ ./runInstaller
ERROR: Unable to verify the graphical display setup. This application requires X display. Make sure that xdpyinfo exist under PATH variable.
/u01/app/oracle/product/23.0.0/db_1/perl/bin/perl: error while loading shared libraries: libnsl.so.2: cannot open shared object file: No such file or directory

查看发现系统只有 libnsl.so.1 的链接指向:

[oracle@db23c db_1]$ ls -l /lib64/libnsl*
-rwxr-xr-x. 1 root root 115824 Sep 30 2020 /lib64/libnsl-2.17.so
lrwxrwxrwx. 1 root root 23 Jan 9 11:48 /lib64/libnsl.so -> ../../lib64/libnsl.so.1
lrwxrwxrwx. 1 root root 14 Jan 7 00:02 /lib64/libnsl.so.1 -> libnsl-2.17.so

试着创建一个链接试试看(需要root用户权限):

# Usage: ln [OPTION]... [-T] TARGET LINK_NAME   (1st form)
[root@db23c ~]# ln -s /lib64/libnsl-2.17.so /lib64/libnsl.so.2

然后再尝试:

[oracle@db23c db_1]$ ./runInstaller
/u01/app/oracle/product/23.0.0/db_1/perl/bin/perl: /lib64/libcrypt.so.1: version `XCRYPT_2.0' not found (required by /u01/app/oracle/product/23.0.0/db_1/perl/bin/perl)
/u01/app/oracle/product/23.0.0/db_1/perl/bin/perl: /lib64/libc.so.6: version `GLIBC_2.28' not found (required by /u01/app/oracle/product/23.0.0/db_1/perl/bin/perl)

额,看起来不行,库文件很多都不符合23c的要求看起来。当前系统是OEL 7.9,推测23c要适配OEL 8.*才可以,因为目前23c只是beta版,在MOS的Certifications里面还没有相关信息,等正式版出来,大家去参照官方说明即可。

根据经验,步骤都是OK的,就是系统要换新版本的系统,换了OEL 8.7 之后果然一切顺利。

来看下23c的安装启动画面~

开始图形配置23c的安装:

在这一步可以看到,23c这个下一代的长期支持版本,已不再提供non-cdb的选项:

另外注意,在预检查的部分,发现默认除了oinstall和dba组,还有oper组,可以执行脚本修复:

同时还发现还需要安装policycoreutils-python-utils这个rpm包,直接yum安装即可。

[root@db23c db_1]# id oracle
uid=54321(oracle) gid=54321(oinstall) groups=54321(oinstall),54322(dba)
[root@db23c db_1]# /tmp/InstallActions2023-01-13_11-39-14AM/CVU_23_oracle_2023-01-13_11-39-17_17676/runfixup.sh
All Fix-up operations were completed successfully.
[root@db23c db_1]# id oracle
uid=54321(oracle) gid=54321(oinstall) groups=54321(oinstall),54323(oper),54322(dba) [root@db23c db_1]# yum install policycoreutils-python-utils

修复之后,就只剩下swap和kvm-clock两项不符合要求了,这个是我测试环境受限,可以忽略:

最后完成安装:

4.番外:OEL8.7的环境准备

去 edelivery.oracle.com 下载一个OEL 8.7,再次尝试。
发现介质变的好大,OEL 7.9才4G+大小的规模,OEL 8.7居然有12G大小。

1)KVM环境下安装OEL 8.7

virt-install \
--network bridge:br0 \
--name oel8 \
--ram=8192 \
--vcpus=2 \
--disk path=/flash/vm-images/oel8.img,size=20 \
--cdrom /flash/ISO/OracleLinux-R8-U7-Server-x86_64-dvd.iso

2)配置网络

配置网卡时,发现在OEL 8中,配置完熟悉的ifcfg-xxx文件,使用systemctl restart network已经不再有用。

使用 nmcli c reload 重载网络配置才可以生效网卡。

3)virsh console oel8 卡住问题

发现解决 virsh console oel8 卡住问题也和之前在OEL7配置不一样,针对ttyS0的几个文件,在OEL8中都没找到!

--这个/etc/securetty文件原来没有,直接生成了一个新的。
echo ttyS0 >> /etc/securetty --在 `/etc/default/grub` 文件中的 `GRUB_CMDLINE_LINUX` 这一行的最后添加 `console=ttyS0,115200` (引号里面哦)
GRUB_CMDLINE_LINUX="resume=/dev/mapper/ol-swap rd.lvm.lv=ol/root rd.lvm.lv=ol/swap rhgb quiet console=ttyS0,115200" --生成配置文件
[root@bogon system]# grub2-mkconfig -o /boot/grub2/grub.cfg
Generating grub configuration file ...
done --启动对应服务
systemctl status serial-getty@ttyS0
systemctl start serial-getty@ttyS0
systemctl enable serial-getty@ttyS0 --尝试virsh console oel8连接成功:
[root@bogon ~]# virsh console oel8
连接到域 oel8
换码符为 ^] Oracle Linux Server 8.7
Kernel 5.15.0-3.60.5.1.el8uek.x86_64 on an x86_64 bogon login: root
Password:
Last login: Thu Jan 12 23:36:42 from 192.168.1.4

4)克隆oel8

和文章开头时的示例类似,来配置主机名db23c、IP地址:192.168.1.23

[root@bogon ~]# virt-clone -o oel8 -n 23c --auto-clone
[root@bogon ~]# virsh start 23c
[root@bogon ~]# virsh console 23c [root@db01xx ~]# hostnamectl set-hostname db23c
[root@db01xx ~]# vi /etc/hosts
[root@db01xx ~]# vi /etc/sysconfig/network-scripts/ifcfg-ens3
[root@db01xx ~]# nmcli c reload
[root@db01xx ~]# nmcli c up ens3
[root@db01xx ~]# reboot

这次不用raw,试着添加一个动态增长的磁盘:

[root@bogon ~]# qemu-img create -f qcow2 -o preallocation=falloc /flash/vm-images/23c-lun1.qcow2 100G
Formatting '/flash/vm-images/23c-lun1.qcow2', fmt=qcow2 size=107374182400 encryption=off cluster_size=65536 preallocation='falloc' lazy_refcounts=off
[root@bogon ~]#
[root@bogon ~]# virsh attach-disk 23c /flash/vm-images/23c-lun1.qcow2 sdb
成功附加磁盘

然后登录到VM中,进行lvm配置操作,最终分好两个目录 /u01 和 /oradata

[root@db23c ~]# pvcreate /dev/sdb
[root@db23c ~]# vgcreate ora /dev/sdb
[root@db23c ~]# lvcreate -L 50G -n u01 ora
[root@db23c ~]# lvcreate -l 12803 -n oradata ora
[root@db23c ~]# mkfs.xfs /dev/mapper/ora-u01
[root@db23c ~]# mkfs.xfs /dev/mapper/ora-oradata
[root@db23c ~]# mkdir /u01
[root@db23c ~]# mkdir /oradata
[root@db23c ~]# vi /etc/fstab --末尾添加两行:
/dev/mapper/ora-u01 /u01 xfs defaults 0 0
/dev/mapper/ora-oradata /oradata xfs defaults 0 0
[root@db23c ~]# mount -a
[root@db23c ~]# df -h
Filesystem Size Used Avail Use% Mounted on
devtmpfs 3.9G 0 3.9G 0% /dev
tmpfs 3.9G 0 3.9G 0% /dev/shm
tmpfs 3.9G 8.5M 3.9G 1% /run
tmpfs 3.9G 0 3.9G 0% /sys/fs/cgroup
/dev/mapper/ol-root 17G 2.0G 16G 12% /
/dev/sda1 1014M 245M 770M 25% /boot
tmpfs 794M 0 794M 0% /run/user/0
/dev/mapper/ora-u01 50G 390M 50G 1% /u01
/dev/mapper/ora-oradata 50G 390M 50G 1% /oradata
[root@db23c ~]# chown oracle:oinstall /oradata

至此,新的基础环境准备就绪,回到文章开头,开始体验安装23c数据库吧~

Linux平台Oracle 23c单实例 安装部署配置 快速参考的更多相关文章

  1. Linux平台oracle 11g单实例 安装部署配置 快速参考

    1.重建主机的Oracle用户 组 统一规范 uid gid 以保证共享存储挂接或其他需求的权限规范 userdel -r oracle groupadd -g 7 oinstall groupadd ...

  2. Linux平台oracle 11g单实例 + ASM存储 安装部署 快速参考

    操作环境:Citrix虚拟化环境中申请一个Linux6.4主机(模板)目标:创建单机11g + ASM存储 数据库 1. 主机准备 2. 创建ORACLE 用户和组成员 3. 创建以下目录并赋予对应权 ...

  3. Linux平台Oracle 12.1.0.2 单实例安装部署

    主题:Linux平台Oracle 12.1.0.2 单实例安装部署 环境:RHEL 6.5 + Oracle 12.1.0.2 需求:安装部署OEM 13.2需要Oracle 12.1.0.2版本作为 ...

  4. Oracle 11g 单实例安装文档

    这里介绍在Red Hat Enterprise Linux Server release 5.7 (Tikanga)下安装ORACLE 11.2.0.1.0的过程,本文仅仅是为了写这样安装指导文档而整 ...

  5. Oracle 12c 单实例安装

    准备工作 实验环境:Redhat 6.6   Oracle 12c 12.2.0.1 1.官网下载 https://www.oracle.com/technetwork/database/enterp ...

  6. Linux平台Oracle多个实例启动说明

    环境说明:oracle实例1的SID为orcl(为默认启动的实例),第二个实例的SID为orcl2 启动步骤:  1)启动数据库实例完成后,启动数据库监听服务 #lsnrctl   start 2)切 ...

  7. Linux平台Oracle多个实例启动

    如何在Linux系统中启动多个Oracle实例?相信很多Oracle的初学者都会碰到这一类问题,下面我简单介绍一下. 1.切换Oracle用户: # su oracle 2.切换到Oracle目录下: ...

  8. 在 Oracle Linux 6.5 上安装 Oracle 11g 单实例数据库

    Checking the Hardware Requirements 系统必须满足下面最小的硬件要求 Memory Requirements Minimum: 1 GB of RAMRecommend ...

  9. Linux平台达梦数据库V7单实例安装方式之图形方式

    一 前言 我们在学习任何一个应用时,了解它的最初步骤通常是学会如何进行安装配置,后序才去关心如何使用,学习达梦数据库也是如此,而达梦数据库的安装提供了多种方式,接下来会一一介绍每种安装方式,达梦数据库 ...

  10. Oracle 11g 单实例静默安装实战记录(linux)

    oracle 11g 单实例静默安装 AUTHOR:Oracle_Ran 环境规划: OS Version : Red Hat Enterprise Linux Server release 6.7 ...

随机推荐

  1. 如何从零开始构建 API ?

    假设你请承包商从零开始建造一座房子,你肯定期望他们交付最高质量的房子.他们必须通过检查.遵守安全规范并遵循项目中约定的要求.因为建房子可容不得走捷径.如果承包商经常走捷径,他们的声誉会受到影响,从而失 ...

  2. 深度学习应用篇-计算机视觉-图像分类[2]:LeNet、AlexNet、VGG、GoogleNet、DarkNet模型结构、实现、模型特点详细介绍

    深度学习应用篇-计算机视觉-图像分类[2]:LeNet.AlexNet.VGG.GoogleNet.DarkNet模型结构.实现.模型特点详细介绍 1.LeNet(1998) LeNet是最早的卷积神 ...

  3. 【技术积累】Python中的NumPy库【二】

    NumPy库的主要类有哪些? NumPy库的主要类包括: ndarray:N维数组对象,是NumPy最重要的类之一.它是Python中数组的基本数据结构,可以进行高效的数学计算和数据处理操作. ufu ...

  4. Rust 声明式宏中的 Metavariables 有哪些

    Metavariables 官方文档确实写得很好,但是缺少一些风味,容易催眠‍ 还是直接看例子更爽一些,通常我们可以从示例代码中之间看出官方文档要表达的意思,而且很多时候我们可以直接在示例代码的基础上 ...

  5. Pinot2的无人机传感器和摄像头

    目录 1. 引言 2. 技术原理及概念 2.1 基本概念解释 2.2 技术原理介绍 2.3 相关技术比较 无人机传感器和摄像头在Pinot 2中得到广泛应用,其目的是为Pinot 2提供全面的传感器和 ...

  6. 一文了解Go语言的匿名函数

    1. 引言 无论是在Go语言还是其他编程语言中,匿名函数都扮演着重要的角色.在本文中,我们将详细介绍Go语言中匿名函数的概念和使用方法,同时也提供一些考虑因素,从而帮助在匿名函数和命名函数间做出选择. ...

  7. Mysql基础篇(二)之函数和约束

    一. 函数 Mysql中的函数主要分为四类:字符串函数.数值函数.日期函数.流程函数 1. 字符串函数 常用函数如下: 函数 功能 CONCAT(S1, S2, ......Sn) 字符串拼接,将S1 ...

  8. [Java基础]String,StringBuffer,StringBuilder的区别

    String 和 StringBuffer/StringBuilder应该分开来看 java.lang.String源码中的注释说明 java.lang.StringBuffer源码中的注释说明 ja ...

  9. 深入探索 Django Rest Framework

    这篇文章会详细介绍Django REST Framework的核心组成部分,包括Serializers.ViewSets.Routers.权限和认证系统以及测试和调试工具.文章从基础开始,逐步深入,旨 ...

  10. 如何在Spring Boot中记录用户系统操作流程?

    在现代Web应用程序中,记录用户系统操作流程对于监控用户行为.进行故障排查.安全审计等方面都是非常重要的.在本篇博客中,我们将介绍如何在Spring Boot中使用AOP(面向切面编程)和日志框架来实 ...