在华为欧拉openEuler 22.03 SP2上搞定Oracle 11g R2:一个踩坑无数的可视化安装实录
在华为欧拉openEuler 22.03 SP2上搞定Oracle 11g R2一个踩坑无数的可视化安装实录当国产操作系统遇上传统商业数据库这场跨越技术栈的联姻注定充满挑战。作为在openEuler 22.03 SP2上成功部署Oracle 11g R2的实践者我将以时间线为轴还原整个安装过程中遇到的七个关键深坑及其破解之道。这不是一份标准化的安装手册而是一本血泪交织的排错日记特别适合那些正在国产化替代道路上摸索的同行。1. 环境准备版本选择的蝴蝶效应第一个决策点就埋下了后续80%的隐患。Oracle 11g R2有多个补丁版本官方文档不会告诉你的是11.2.0.4才是与openEuler最兼容的版本。我最初尝试的11.2.0.1版本在安装过程中触发了以下连锁反应图形安装界面频繁崩溃libaio库版本冲突数据库创建后无法启动监听服务通过Oracle Support的隐藏文档发现11.2.0.4版本特别针对较新的Linux内核进行了适配。以下是关键组件版本对照表组件推荐版本不兼容版本后果表现Oracle11.2.0.411.2.0.1安装进度70%卡死openEuler内核5.10.0-60低于5.10系统调用异常libaio0.3.109-13.el7系统默认版本数据库实例创建失败提示获取11.2.0.4安装包时注意区分Base Release和Patchset。需要的是包含完整安装文件的p13390677_112040_Linux-x86-64_1of7.zip和2of7.zip。2. 依赖迷宫当欧拉遇见OracleopenEuler的软件源与CentOS/RHEL存在微妙差异直接使用yum安装依赖就像在雷区跳舞。最棘手的三个依赖问题及其解决方案2.1 libnsl的幽灵依赖系统明明显示已安装libnsl2但Oracle安装程序仍提示缺少libnsl。这是因为Oracle的二进制文件仍依赖旧版命名规范。解决方法是创建符号链接ln -s /usr/lib64/libnsl2.so.1 /usr/lib64/libnsl.so.12.2 libaio的版本陷阱openEuler默认的libaio版本过高需要手动降级安装rpm2cpio libaio-0.3.109-13.el7.x86_64.rpm | cpio -idmv cp ./lib64/libaio.so.1.0.1 /opt/libaio.so.12.3 图形栈的隐秘需求可视化安装需要这些容易被忽略的包yum install xorg-x11-utils xauth libXext libXtst libXi3. Xmanager远程安装的量子纠缠通过公网远程安装时X11转发就像薛定谔的猫——有时工作有时不。经过20多次测试总结出稳定连接的黄金组合SSH服务端配置# /etc/ssh/sshd_config 必须包含 X11Forwarding yes X11UseLocalhost no客户端环境检查# 在服务器端执行 export DISPLAY客户端IP:10.0 xhost 防火墙例外规则iptables -I INPUT -p tcp --dport 6010 -j ACCEPT注意如果使用跳板机环境需要在每级跳板都启用X11转发且DISPLAY变量需要像隧道一样逐级传递。4. 安装70%卡死ins_emagent.mk的死亡凝视当进度条看似顺利走到70%时突然弹出的Error in invoking target agent nmhs就像一盆冷水。这个经典错误的根治方案定位问题文件vi $ORACLE_HOME/sysman/lib/ins_emagent.mk在176行后追加链接参数$(SYSMANBIN)nmhs: $(NMHS_OBJS) $(LINK) $(NMHS_OBJS) -lnnz11 $(LINKOPT) ...深层原因分析Oracle的Enterprise Manager组件需要链接nnz11库openEuler的binutils工具链处理符号依赖的方式与RHEL不同该错误不会立即导致安装失败但会使数据库监控功能完全瘫痪5. 中文环境下的乱码围城在中文locale环境下运行安装程序会遭遇按钮文字显示为方块的尴尬。这不是简单的字体缺失问题而是深层的编码冲突解决方案分三步走临时切换英文环境export LANGen_US.UTF-8安装完成后修复中文显示yum install fonts-chinese数据库字符集配置ALTER DATABASE CHARACTER SET AL32UTF8;6. 用户权限的次元壁Oracle官方建议使用独立的oracle用户安装但openEuler的默认权限模型会导致各种权限不足的灵异事件。必须打破的四个权限壁垒SELinux的隐形墙# /etc/selinux/config SELINUXpermissive文件描述符限制# /etc/security/limits.conf oracle soft nofile 1024 oracle hard nofile 65536内核参数调整# /etc/sysctl.conf kernel.shmall 2097152 kernel.shmmax 2147483648目录所有权问题chown -R oracle:database /home/oracle7. 数据库创建后的幽灵进程安装完成后的喜悦很快被一个诡异现象打破监听进程随机消失。根本原因是openEuler的systemd与Oracle的启动脚本不兼容。终极解决方案创建自定义服务单元# /etc/systemd/system/oracle.service [Unit] DescriptionOracle DB Afternetwork.target [Service] Useroracle EnvironmentORACLE_HOME/home/oracle/app/oracle/product/11.2.0/dbhome_1 ExecStart$ORACLE_HOME/bin/dbstart $ORACLE_HOME替换传统启动方式systemctl enable oracle监控脚本保活*/5 * * * * /home/oracle/check_listener.sh这场持续三天的安装拉锯战最终以成功创建实例告终但最大的收获不是那个闪亮的Installation Complete对话框而是对国产操作系统兼容性边界的深刻认知。当传统商业软件遇上新兴基础软件解决问题的关键往往不在官方文档里而在一次次失败的日志文件中。
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2627797.html
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!