最近一些版本的openssh和openssl都爆出了比较严重的漏洞,但是oracle数据库尤其是rac升级ssh和ssl其实是有一定风险的,这里就借助我的ocm环境,做一次ssh升级的演示及排坑。
1 升级ssh
这里从群里拖了一套ssh的rpm包在线直接升级:
这里可以看到openssh版本已经升级到了9.4p1,openssl已经是1.1.1v。
更新完成过后,首先集群的状态是正常的(截图略)。
2 问题
似乎直接在集群运行状态下升级ssh没出现啥问题,这里就开始做另外一件事情,通过opatchauto升级数据库,目标版本是19.16,结果:
检查日志发现:
2023-09-17 21:59:06,270 info [1] oracle.dbsysmodel.driver.sdk.util.osysutility - output message :::
2023-09-17 21:59:13,200 warning [1] oracle.dbsysmodel.driver.sdk.util.osysutility - failed:
verifying '/tmp/' ...failed (prvf-7546)
verifying shared storage accessibility:/u01/app/19.3.0/grid/crs/install ...passed
verification of shared storage accessibility was unsuccessful.
checks did not pass for the following nodes:
host04
这里看到检查remote节点/tmp目录时出现了问题,这里需要说明一下,在rac集群rolling方式升级的时候,是会调用cvu(cluster verification utility)来验证集群各节点情况,而相关文件就会存放在/tmp文件夹下:
这里也说一下我这里为什么选择19.16做测试:1. 这个是我手上生产使用且稳定的版本;2. 该版本是适配了openssh_8版本了的(cluvfy fails pre-checks upgrade 19c gi from 12c - openssh_8 (doc id 2929286.1))。因此这个版本可以最大限度减少一些问题的产生,然而问题依旧。
3 如何解决
这里其实就是这么个问题(按照ins-06006 gi runinstaller fails if openssh is upgraded to 8.x (doc id 2555697.1)):
[root@host03 ~]# scp host04:"'/root/test'" ./
(root@host04) password:
scp: '/root/test': no such file or directory
## openssh 8.x
[root@host03 ~]# scp -t host04:"'/root/test'" ./
(root@host04) password:
## the file transfers will be successful.
## openssh 9.x
[root@host03 ~]# scp -t host04:"'/root/test'" ./
(root@host04) password:
scp: '/root/test': no such file or directory
[root@host03 ~]# scp -t -o host04:"'/root/test'" ./
(root@host04) password:
test 100% 0 0.0kb/s 00:00
因此在使用适用于openssh 8.x的m6米乐安卓版下载的解决方案处理问题的时候,仍然会出现无法执行cvu的问题。
通过man scp的方式检查-t和-o参数的解释:
-o use the legacy scp protocol for file transfers instead of the sftp protocol. forcing the use of
the scp protocol may be necessary for servers that do not implement sftp, for backwards-compati‐
bility for particular filename wildcard patterns and for expanding paths with a `~' prefix for
older sftp servers.
-t disable strict filename checking. by default when copying files from a remote host to a local
directory scp checks that the received filenames match those requested on the command-line to
prevent the remote end from sending unexpected or unwanted files. because of differences in how
various operating systems and shells interpret filename wildcards, these checks may cause wanted
files to be rejected. this option disables these checks at the expense of fully trusting that
the server will not send unexpected filenames.
-t是关闭严格的文件名检查,防止来自各种操作系统的远程端和shell解释文件名通配符,这些检查可能会导致所需文件被拒绝。
-o则是不使用sftp而是scp协议来传输文件,对于特定文件名通配符模式具有兼容性。
因此这里在openssh 8.xm6米乐安卓版下载的解决方案的基础上还需要增加-o的参数,完成m6米乐安卓版下载的解决方案如下:
# rename the original scp.
mv /usr/bin/scp /usr/bin/scp.orig
# create a new file .
vi /usr/bin/scp
# add the below line to the new created file .
/usr/bin/scp.orig -t -o $*
# change the file permission.
chmod 555 /usr/bin/scp
# begin operation(sush as installation, opatch(auto), cvu and so on)
# after operation
mv /usr/bin/scp.orig /usr/bin/scp
处理过后opatchauto可以正常运行:
总结
本期讲解的是升级openssh至9.x后rac在升级版本时需要注意的一些问题。
老规矩,知道写了些啥。