KVM环境和其他虚拟化或真实生产最大差异主要就是在实施前期准备工作上:

具体在 DB节点 和存储环境 的准备工作上有差异,本文会详细说明。

而剩余基本软件安装和补丁应用部分无差异,若不清楚可以直接参考之前文章:

下面就具体来看这两个方面的准备工作:

1.DB节点准备

为了尽可能减少配置,这里先将之前的db1环境做一些基础配置:

1)新增的100GB磁盘用于 /u01 目录挂载

[root@localhost ~]# pvcreate /dev/vdb
[root@localhost ~]# vgcreate ora /dev/vdb
[root@localhost ~]# lvcreate -l 25599 -n u01 ora
[root@localhost ~]# mkfs.xfs /dev/mapper/ora-u01
[root@localhost ~]# mkdir /u01
[root@localhost ~]# vi /etc/fstab 末尾添加一行:
/dev/mapper/ora-u01 /u01 xfs defaults 0 0
[root@localhost ~]# mount -a
[root@localhost ~]# df -h /u01
Filesystem Size Used Avail Use% Mounted on
/dev/mapper/ora-u01 100G 33M 100G 1% /u01

2)主机名和hosts文件配置

这里初始化先设置为db01xx:

hostnamectl set-hostname db01xx

/etc/hosts配置末尾增加一行:

192.168.1.6 db01xx

3)yum安装Oracle所需的软件包

yum -y install bc binutils compat-libcap1 compat-libstdc+±33 elfutils-libelf elfutils-libelf-devel \
fontconfig-devel glibc glibc-devel ksh libaio libaio-devel libX11 libXau libXi libXtst \
libXrender libXrender-devel libgcc libstdc++ libstdc+±devel libxcb make net-tools nfs-utils python \
python-configshell python-rtslib python-six targetcli smartmontools sysstat chronyvi ntp gcc unixODBC \
gcc-c++ psmisc unzip chrony perl perl-devel policycoreutils-python policycoreutils

4)网络需要添加私有网卡

目前只有桥接网卡,需要添加一个私有网卡,用于集群心跳等用途。步骤如下:

virsh domiflist db1
virsh attach-interface db1 network default
virsh dumpxml db1 > /etc/libvirt/qemu/db1.xml
virsh define /etc/libvirt/qemu/db1.xml --输出如下:
[root@bogon vm-images]# virsh domiflist db1
接口 类型 源 型号 MAC
-------------------------------------------------------
vnet3 bridge br0 virtio 52:54:00:9d:30:17 [root@bogon vm-images]# virsh attach-interface db1 network default
成功附加接口 [root@bogon vm-images]# virsh domiflist db1
接口 类型 源 型号 MAC
-------------------------------------------------------
vnet3 bridge br0 virtio 52:54:00:9d:30:17
vnet4 network default rtl8139 52:54:00:79:88:c6 [root@bogon vm-images]# virsh dumpxml db1 > /etc/libvirt/qemu/db1.xml
[root@bogon vm-images]# virsh define /etc/libvirt/qemu/db1.xml
定义域 db1(从 /etc/libvirt/qemu/db1.xml) --测试重启VM网卡是否依然存在:
[root@bogon vm-images]# virsh shutdown db1
域 db1 被关闭 [root@bogon vm-images]# virsh domiflist db1
接口 类型 源 型号 MAC
-------------------------------------------------------
- bridge br0 virtio 52:54:00:9d:30:17
- network default rtl8139 52:54:00:79:88:c6 [root@bogon vm-images]# virsh start db1
域 db1 已开始 [root@bogon vm-images]# virsh domiflist db1
接口 类型 源 型号 MAC
-------------------------------------------------------
vnet3 bridge br0 virtio 52:54:00:9d:30:17
vnet4 network default rtl8139 52:54:00:79:88:c6

这一步遇到添加网卡重启vm消失的问题,还是记录下过程备忘:

[root@bogon ~]# virsh attach-interface db1 network default
成功附加接口 [root@bogon ~]# virsh attach-interface db1 bridge br0
成功附加接口 [root@bogon ~]# ls -l /etc/libvirt/qemu/db1.xml
-rw-------. 1 root root 4751 1月 9 15:10 /etc/libvirt/qemu/db1.xml --将当前的配置dump并写入到配置xml文件中
[root@bogon ~]# virsh dumpxml db1 > /etc/libvirt/qemu/db1.xml

在虚拟机上查看也会多了对应的网卡,网卡配置文件需要手工配置:

如果添加的网卡不再需要还可以删除:

[root@bogon ~]# virsh detach-interface db1 bridge
错误:域有 2 个接口。请使用 --mac 指定要分离的接口。
错误:分离接口失败 [root@bogon ~]# virsh domiflist db1
接口 类型 源 型号 MAC
-------------------------------------------------------
vnet3 bridge br0 virtio 52:54:00:9d:30:17
vnet4 network default rtl8139 52:54:00:1d:aa:2f
vnet5 bridge br0 rtl8139 52:54:00:12:b3:80 [root@bogon ~]# virsh detach-interface db1 bridge --mac 52:54:00:12:b3:80
成功分离接口 [root@bogon ~]# virsh domiflist db1
接口 类型 源 型号 MAC
-------------------------------------------------------
vnet3 bridge br0 virtio 52:54:00:9d:30:17
vnet4 network default rtl8139 52:54:00:1d:aa:2f [root@bogon ~]# virsh detach-interface db1 network
成功分离接口 [root@bogon ~]# virsh domiflist db1
接口 类型 源 型号 MAC
-------------------------------------------------------
vnet3 bridge br0 virtio 52:54:00:9d:30:17 --将当前的配置dump并写入到配置xml文件中
[root@bogon ~]# virsh dumpxml db1 > /etc/libvirt/qemu/db1.xml

现在有个问题是,重启后添加的网卡会消失,虽然做了virsh dumpxml操作,保存到/etc/libvirt/qemu/db1.xml了;

也就是域中的信息没有获取正确的配置信息,看virsh help中尝试使用:

virsh define /etc/libvirt/qemu/db1.xml

[root@bogon vm-images]# virsh define /etc/libvirt/qemu/db1.xml
定义域 db1(从 /etc/libvirt/qemu/db1.xml)

然后再次尝试启停,终于稳定了,看来网上的经验不太完整,导致折腾了半天,以为是啥bug呢;

[root@bogon vm-images]# virsh domiflist db1
接口 类型 源 型号 MAC
-------------------------------------------------------
vnet3 bridge br0 virtio 52:54:00:9d:30:17
vnet4 network default rtl8139 52:54:00:2c:48:57 [root@bogon vm-images]# virsh shutdown db1
域 db1 被关闭 [root@bogon vm-images]# virsh domiflist db1
接口 类型 源 型号 MAC
-------------------------------------------------------
- bridge br0 virtio 52:54:00:9d:30:17
- network default rtl8139 52:54:00:2c:48:57 [root@bogon vm-images]#
[root@bogon vm-images]# virsh start db1
域 db1 已开始 [root@bogon vm-images]# virsh domiflist db1
接口 类型 源 型号 MAC
-------------------------------------------------------
vnet3 bridge br0 virtio 52:54:00:9d:30:17
vnet4 network default rtl8139 52:54:00:2c:48:57

所以最开始是少了一个关键步骤把更改的xml加载到域,也就是说无论增加网卡还是删除网卡,之后都要做这两步才可以保证永久生效:

[root@bogon vm-images]# virsh dumpxml db1 > /etc/libvirt/qemu/db1.xml
[root@bogon vm-images]# virsh define /etc/libvirt/qemu/db1.xml
定义域 db1(从 /etc/libvirt/qemu/db1.xml)

当然,如果觉得命令行不好玩,也可以采用图形方式virt-manager来添加/删除设备。

添加网卡成功后,配置一个IP地址,测试网络和宿主机正常。

遇到网卡变成eth1重启又变成eth0的情况,应该是反复删除导致,测试正常稳定后,再进行下一步。

5)Oracle安装介质

在 /u01/media 目录下上传安装和补丁介质。

mkdir /u01/media

上传GI、DB、OPatch、RU补丁介质。

克隆两台机器:

在上面基础配置做完之后,直接关闭db1,然后基于db1直接克隆出两台机器,用于RAC的两个节点:

virsh shutdown db1

virt-clone --original db1 --name rac1 --auto-clone
virt-clone --original db1 --name rac2 --auto-clone

修改主机名和IP地址,然后配置/etc/hosts内容:

192.168.1.11 db01rac1
192.168.1.12 db01rac2
192.168.1.13 db01rac1-vip
192.168.1.14 db01rac2-vip
192.168.1.15 db01rac-scan

2.存储环境准备

基于vm1直接克隆出一台机器,用于RAC的共享存储(iSCSI模拟)

virt-clone --original vm1 --name storage1 --auto-clone

给vm1添加一块50G的磁盘,采用raw格式。

前面文章提过可以直接修改xml来添加磁盘,这次尝试使用命令的方式添加:

dd if=/dev/zero of=/flash/vm-images/s1-lun1.img bs=1M count=51200
virsh attach-disk storage1 /flash/vm-images/s1-lun1.img vdb virsh dumpxml storage1 > /etc/libvirt/qemu/storage1.xml
virsh define /etc/libvirt/qemu/storage1.xml

这样添加的磁盘重启也不会丢失,可以观察xml变化,是一样的效果。下面是实际操作输出:

[root@bogon vm-images]# dd if=/dev/zero of=/flash/vm-images/s1-lun1.img bs=1M count=51200
记录了51200+0 的读入
记录了51200+0 的写出
53687091200字节(54 GB)已复制,84.4384 秒,636 MB/秒
[root@bogon vm-images]# virsh attach-disk storage1 /flash/vm-images/s1-lun1.img vdb
成功附加磁盘
[root@bogon vm-images]# virsh dumpxml storage1 > /etc/libvirt/qemu/storage1.xml
[root@bogon vm-images]# virsh define /etc/libvirt/qemu/storage1.xml
定义域 storage1(从 /etc/libvirt/qemu/storage1.xml)

这50G 的盘用于RAC的共享存储,计划分配:

OCRDG   3 * 1G
DATADG 30GB
ARCHDG 16GB

这里就可以直接参考之前文章 RHEL7 配置iSCSI模拟环境 来操作:

首先lvm按本次规划来创建:

pvcreate /dev/vdb
vgcreate vg_storage /dev/vdb
lvcreate -L 1g -n lv_lun1 vg_storage
lvcreate -L 1g -n lv_lun2 vg_storage
lvcreate -L 1g -n lv_lun3 vg_storage
lvcreate -L 30g -n lv_lun4 vg_storage
lvcreate -L 16g -n lv_lun5 vg_storage

使用yum安装targetd和targetcli,并配置好服务

yum -y install targetd targetcli
systemctl status targetd
systemctl start targetd
systemctl enable targetd
systemctl list-unit-files|grep targetd

targetcli进入命令行:

cd /backstores/block
create disk1 /dev/mapper/vg_storage-lv_lun1
create disk2 /dev/mapper/vg_storage-lv_lun2
create disk3 /dev/mapper/vg_storage-lv_lun3
create disk4 /dev/mapper/vg_storage-lv_lun4
create disk5 /dev/mapper/vg_storage-lv_lun5

使用targetcli创建iqn和LUN

cd /iscsi
create
cd /iscsi/iqn.2003-01.org.linux-iscsi.storage.x8664:sn.d5fd6c3922b6/tpg1/luns
create /backstores/block/disk1
create /backstores/block/disk2
create /backstores/block/disk3
create /backstores/block/disk4
create /backstores/block/disk5

使用targetcli创建acls

cd /iscsi/iqn.2003-01.org.linux-iscsi.storage.x8664:sn.d5fd6c3922b6/tpg1/acls
create iqn.2003-01.org.linux-iscsi.storage.x8664:sn.d5fd6c3922b6:client cd /iscsi/iqn.2003-01.org.linux-iscsi.storage.x8664:sn.d5fd6c3922b6/tpg1/portals
delete 0.0.0.0 3260
create 192.168.1.10

最终配置好的输出为:

/iscsi/iqn.20.../tpg1/portals> ls /
o- / [...]
o- backstores [...]
| o- block [Storage Objects: 5]
| | o- disk1 [/dev/mapper/vg_storage-lv_lun1 (1.0GiB) write-thru activated]
| | | o- alua [ALUA Groups: 1]
| | | o- default_tg_pt_gp [ALUA state: Active/optimized]
| | o- disk2 [/dev/mapper/vg_storage-lv_lun2 (1.0GiB) write-thru activated]
| | | o- alua [ALUA Groups: 1]
| | | o- default_tg_pt_gp [ALUA state: Active/optimized]
| | o- disk3 [/dev/mapper/vg_storage-lv_lun3 (1.0GiB) write-thru activated]
| | | o- alua [ALUA Groups: 1]
| | | o- default_tg_pt_gp [ALUA state: Active/optimized]
| | o- disk4 [/dev/mapper/vg_storage-lv_lun4 (30.0GiB) write-thru activated]
| | | o- alua [ALUA Groups: 1]
| | | o- default_tg_pt_gp [ALUA state: Active/optimized]
| | o- disk5 [/dev/mapper/vg_storage-lv_lun5 (16.0GiB) write-thru activated]
| | o- alua [ALUA Groups: 1]
| | o- default_tg_pt_gp [ALUA state: Active/optimized]
| o- fileio [Storage Objects: 0]
| o- pscsi [Storage Objects: 0]
| o- ramdisk [Storage Objects: 0]
o- iscsi [Targets: 1]
| o- iqn.2003-01.org.linux-iscsi.storage.x8664:sn.d5fd6c3922b6 [TPGs: 1]
| o- tpg1 [no-gen-acls, no-auth]
| o- acls [ACLs: 1]
| | o- iqn.2003-01.org.linux-iscsi.storage.x8664:sn.d5fd6c3922b6:client [Mapped LUNs: 5]
| | o- mapped_lun0 [lun0 block/disk1 (rw)]
| | o- mapped_lun1 [lun1 block/disk2 (rw)]
| | o- mapped_lun2 [lun2 block/disk3 (rw)]
| | o- mapped_lun3 [lun3 block/disk4 (rw)]
| | o- mapped_lun4 [lun4 block/disk5 (rw)]
| o- luns [LUNs: 5]
| | o- lun0 [block/disk1 (/dev/mapper/vg_storage-lv_lun1) (default_tg_pt_gp)]
| | o- lun1 [block/disk2 (/dev/mapper/vg_storage-lv_lun2) (default_tg_pt_gp)]
| | o- lun2 [block/disk3 (/dev/mapper/vg_storage-lv_lun3) (default_tg_pt_gp)]
| | o- lun3 [block/disk4 (/dev/mapper/vg_storage-lv_lun4) (default_tg_pt_gp)]
| | o- lun4 [block/disk5 (/dev/mapper/vg_storage-lv_lun5) (default_tg_pt_gp)]
| o- portals [Portals: 1]
| o- 192.168.1.10:3260 [OK]
o- loopback [Targets: 0]
o- vhost [Targets: 0]
/iscsi/iqn.20.../tpg1/portals>

如果系统开了防火墙,将防火墙添加放行tcp 3260端口:

firewall-cmd --permanent --add-port=3260/tcp
firewall-cmd --reload

到此,iSCSI服务端配置完成,需要到客户端配置,这里也就是RAC的2个节点上都要配置:

yum -y install iscsi-initiator-utils

vi /etc/iscsi/initiatorname.iscsi

#InitiatorName=iqn.1988-12.com.oracle:178a747c44
InitiatorName=iqn.2003-01.org.linux-iscsi.storage.x8664:sn.d5fd6c3922b6:client --使用iscsiadm发现可用存储设备并登陆连接
iscsiadm -m discovery -t st -p 192.168.1.10
iscsiadm -m node -T iqn.2003-01.org.linux-iscsi.storage.x8664:sn.d5fd6c3922b6 -p 192.168.1.10 --login

最终RAC两个节点fdisk -l 都可以看到新的5块磁盘:

[root@db01rac1 ~]# fdisk -l /dev/sd*

Disk /dev/sda: 1073 MB, 1073741824 bytes, 2097152 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes Disk /dev/sdb: 1073 MB, 1073741824 bytes, 2097152 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes Disk /dev/sdc: 1073 MB, 1073741824 bytes, 2097152 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes Disk /dev/sdd: 32.2 GB, 32212254720 bytes, 62914560 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes Disk /dev/sde: 17.2 GB, 17179869184 bytes, 33554432 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes

至此,所有准备工作完成。

在QEMU-KVM环境下部署Oracle 19.16 RAC的更多相关文章

  1. [原] KVM 环境下MySQL性能对比

    KVM 环境下MySQL性能对比 标签(空格分隔): Cloud2.0 [TOC] 测试目的 对比MySQL在物理机和KVM环境下性能情况 压测标准 压测遵循单一变量原则,所有的对比都是只改变一个变量 ...

  2. win7 IIS7环境下部署PHP 7.0

    最近在本机电脑win7 II7环境下部署PHP 7.0遇到一些问题,将之记录下来 简要步骤如下: 1.到php官网下载php,由于是IIS环境要下载非线程安全的版本,我下载的是7.0.13 2.解压到 ...

  3. Vmware ESX5i 环境下部署Windows Storage Server 2008 R2

    ESX5i 环境下部署Windows Storage Server 2008 R2       Windows Storage Server 2008 这款产品微软早已发布,WSS2008是基于Win ...

  4. 有了SSL证书,如何在IIS环境下部署https?【转载】

    昨天各位小伙伴都很开心的领取了自己的SSL证书,但是大部分小伙伴却不知道如何部署,也许是因为第一次接触SSL这种高端的东西吧,不过个人觉得就是懒懒懒...本来小编也挺懒的,但是答应了各位小伙伴的,那么 ...

  5. Django Windows环境下部署

    环境准备 本文将介绍如何在Windows系统上部署Django web项目,本次部署基于下面的架构: Windows10 64位+Python3.6+Django1.11+Apache2.4+mod_ ...

  6. Django Linux环境下部署CentOS7+Python3+Django+uWSGI+Nginx(含Nginx返回400问题处理、防火墙管理)

    本文将介绍如何在Linux系统上部署Django web项目,本次部署基于下面的架构: CentOS7+ Python3.5 + Django1.11 + uWSGI + Nginx 亲测可行!!按照 ...

  7. 【简书】在阿里云自带的CentOS + LAMP环境下部署一个Laravel项目

    在阿里云自带的CentOS + LAMP环境下部署一个Laravel项目 作者 DonnieZero 关注 2017.07.29 22:02* 字数 2218 阅读 5556评论 3喜欢 1赞赏 1 ...

  8. Windows 环境下安装 Oracle JDK

    本页面中描述了如何在 Window 环境下安装 Oracle JDK. 我们使用的版本是 Window 10,我们需要安装的版本是 Oracle JDK 8u191. 检查当前版本 在进行新的 JDK ...

  9. 有了SSL证书,如何在IIS环境下部署https?

    昨天各位小伙伴都很开心的领取了自己的SSL证书,但是大部分小伙伴却不知道如何部署,也许是因为第一次接触SSL这种高端的东西吧,不过个人觉得就是懒懒懒...本来小编也挺懒的,但是答应了各位小伙伴的,那么 ...

  10. Windows环境下在Oracle VM VirtualBOX下克隆虚拟机镜像(克隆和导入)

    Windows环境下在Oracle VM VirtualBOX下克隆虚拟机镜像: 注:直接复制一个.vdi 虚拟硬盘再挂上去就可以,但Virtualbox居然提示UUID重复,无法使用. 则,可以通过 ...

随机推荐

  1. 13、SpringBoot-配置文件里密码加密

    系列导航 springBoot项目打jar包 1.springboot工程新建(单模块) 2.springboot创建多模块工程 3.springboot连接数据库 4.SpringBoot连接数据库 ...

  2. 【驱动】SPI驱动分析(四)-关键API解析

    关键API 设备树 设备树解析 我们以Firefly 的SPI demo 分析下dts中对spi的描述: /* Firefly SPI demo */ &spi1 { spi_demo: sp ...

  3. B3637-DP【橙】

    这题我用sort的时候大意了,从1开始使用的下标但是用sort时没加1导致排序错误,排了半天错才发现. 另外,这道题我似乎用了一种与网络上搜到了做法截然不同的自己的瞎想出来的做法,我的这个做法需要n^ ...

  4. freeswitch on debian docker

    概述 freeswitch是一款简单好用的VOIP开源软交换平台. 因为centos系统期限的原因,尝试在debian的docker上使用fs. 环境 docker engine:Version 24 ...

  5. C#设计模式12——代理模式的写法

    1. 什么是代理模式? 代理模式是一种结构型设计模式,它允许通过代理对象来控制对真实对象的访问,以提供额外的功能或控制访问权限. 2. 代理模式的作用是什么? 代理模式可以为对象提供保护代理.远程代理 ...

  6. spring--Bean的作用域及应用场景

    这六种Spring Bean的作用域适用于不同的应用场景: Singleton: 在Spring IoC容器中仅存在一个Bean实例,Bean以单例方式存在.无论我们是否在配置文件中显式定义,所有的S ...

  7. 【解决方案】如何使用 Http API 代替 OpenFeign 进行远程服务调用

    目录 前言 一.何为OpenFeign 1.1@FeignClient注解 1.2注意事项 二.常见的Http API 2.1Apache 2.2Okhttp 2.3Hutool 三.RestTemp ...

  8. Redis lua脚本简要学习

    Redis lua脚本简要学习 背景 上周督促客户从Windows平台升级到了Linux平台. redis一周相安无事. 但是这周一突然又出现了卡断和慢的情况. 只能继续进行分析. 分析思路 现场日志 ...

  9. [转帖]Linux性能分析:理解系统平均负载

    Linux系统中,平均负载是指单位时间内,处于可运行状态和不可中断状态的进程数.它不仅包括了正在使用CPU的进程,也包括处于不可打断的睡眠状态的进程-它们是在等待其它系统资源如磁盘 I/O 等的进程. ...

  10. [转帖]使用JAYDEBEAPI同时连接两个不同数据库(ORACLE+MYSQL)的问题

    jaydebeapi 同时连接两种数据库 在使用jaydebeapi只连接一种数据库时,是没问题的,但是如果需要同时连接两种数据库,比如同时连接oracle和mysql 例如以下测试代码:   imp ...