当前位置: 首页 > article >正文

在华为欧拉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对话框而是对国产操作系统兼容性边界的深刻认知。当传统商业软件遇上新兴基础软件解决问题的关键往往不在官方文档里而在一次次失败的日志文件中。

相关文章:

在华为欧拉openEuler 22.03 SP2上搞定Oracle 11g R2:一个踩坑无数的可视化安装实录

在华为欧拉openEuler 22.03 SP2上搞定Oracle 11g R2:一个踩坑无数的可视化安装实录 当国产操作系统遇上传统商业数据库,这场跨越技术栈的"联姻"注定充满挑战。作为在openEuler 22.03 SP2上成功部署Oracle 11g R2的实践者,我将以时间…...

不只是定位:教你用开源GNSS/INS平台玩转多传感器融合与抗干扰

不只是定位:开源GNSS/INS平台的多传感器融合与抗干扰实战指南 在自动驾驶、无人机和机器人领域,精准的定位与导航系统是核心竞争力的体现。传统单一GNSS系统在城市峡谷、电磁干扰等复杂环境下表现往往不尽如人意,而单纯依赖惯性导航系统(INS)…...

如何用3分钟完成淘宝淘金币全任务?终极自动化脚本完全指南

如何用3分钟完成淘宝淘金币全任务?终极自动化脚本完全指南 【免费下载链接】taojinbi 淘宝淘金币自动执行脚本,包含蚂蚁森林收取能量,芭芭农场全任务,解放你的双手 项目地址: https://gitcode.com/gh_mirrors/ta/taojinbi …...

如何用Python自动化脚本轻松抢到大麦网演唱会门票:终极指南

如何用Python自动化脚本轻松抢到大麦网演唱会门票:终极指南 【免费下载链接】DamaiHelper 大麦网演唱会演出抢票脚本。 项目地址: https://gitcode.com/gh_mirrors/dama/DamaiHelper 还在为抢不到心仪演唱会门票而烦恼吗?当周杰伦、五月天等热门演…...

告别键盘连击烦恼:KeyboardChatterBlocker 智能解决方案详解

告别键盘连击烦恼:KeyboardChatterBlocker 智能解决方案详解 【免费下载链接】KeyboardChatterBlocker A handy quick tool for blocking mechanical keyboard chatter. 项目地址: https://gitcode.com/gh_mirrors/ke/KeyboardChatterBlocker 你是否曾经在打…...

N_m3u8DL-RE完整教程:跨平台流媒体下载的终极解决方案

N_m3u8DL-RE完整教程:跨平台流媒体下载的终极解决方案 【免费下载链接】N_m3u8DL-RE Cross-Platform, modern and powerful stream downloader for MPD/M3U8/ISM. English/简体中文/繁體中文. 项目地址: https://gitcode.com/GitHub_Trending/nm3/N_m3u8DL-RE …...

百度千帆平台文心4.0 API开通与计费避坑指南:个人开发者如何低成本尝鲜?

百度千帆文心4.0 API低成本接入实战:个人开发者的精打细算指南 当大模型API成为个人开发者的"新基建",如何用最低成本体验最前沿的ERNIE-Bot-4能力?作为经历过完整踩坑流程的实践者,我将分享从申请到调用的全流程避坑策…...

告别AWCC臃肿:500KB轻量级Alienware灯光风扇控制终极方案

告别AWCC臃肿:500KB轻量级Alienware灯光风扇控制终极方案 【免费下载链接】alienfx-tools Alienware systems lights, fans, and power control tools and apps 项目地址: https://gitcode.com/gh_mirrors/al/alienfx-tools 厌倦了Alienware Command Center&…...

在野火征途Pro上跑RT-Thread:手把手教你为自研RISC-V SoC移植操作系统

在野火征途Pro上跑RT-Thread:手把手教你为自研RISC-V SoC移植操作系统 当一块裸板首次点亮LED时,那种成就感就像电子工程师的"Hello World"。但要让这块板子真正活起来,操作系统是不可或缺的灵魂。本文将带你从零开始,在…...

Nginx、Tengine、OpenRestry的http和tcp后端健康检查【20260520-005篇】

文章目录 ✅ 一、核心能力概览(按产品维度) ✅ 二、HTTP 健康检查配置示例(三者对比) ▪️ Nginx(被动式,基础可靠) ▪️ Tengine(主动式,开箱即用) ▪️ OpenResty(Lua 主动式,高度可控) ✅ 三、TCP 健康检查配置示例 ▪️ Tengine(最简洁) ▪️ OpenResty(TC…...

逆向实战:用WT-JS_DEBUG_V1.8.3快速定位并导出AES加密参数到Python

逆向工程实战:从浏览器到Python的AES加密参数高效迁移指南 在数据采集和接口分析领域,遇到前端加密是再常见不过的挑战。特别是当网站采用AES加密时,如何快速提取关键参数并复用到Python脚本中,成为许多开发者头疼的问题。本文将…...

告别桌面混乱!用Utools的「本地文件启动」功能,5分钟打造你的专属文件启动器

告别桌面混乱!用Utools的「本地文件启动」功能,5分钟打造你的专属文件启动器 每次打开电脑,看到满屏的文件图标和杂乱无章的文件夹,是不是感觉工作效率瞬间降了一半?作为一名长期与文件打交道的专业人士,我…...

Nginx、Tengine、OpenRestry的http和tcp后端健康检查【20260520-004篇】

文章目录 企业级生产环境 Nginx/Tengine/OpenResty 健康检查 完整部署+配置+压测+故障演练+验收交付文档 一、环境基线与生产规范 1. 版本选型(生产强制) 2. 生产统一参数规范(全局通用) 3. 生产前置约束 二、三大组件 生产完整配置 2.1 开源Nginx 生产配置(仅被动检查,无…...

别光顾着写EXP:复盘BUUCTF warmup_csaw_2016,聊聊PWN题里的‘信息泄露’与安全编程

从CTF漏洞利用到安全编程:深入解析信息泄露与防御实践 引言 在网络安全竞赛和实际系统安全中,信息泄露往往成为攻击者突破防御的第一块敲门砖。2016年CSAW CTF的warmup题目虽然看似简单,却完美展示了这类漏洞的典型模式——程序不仅存在栈溢出…...

OpenSpec 介绍与使用:让 AI 编程从“聊天驱动”变成“规格驱动”

一、为什么需要 OpenSpec? AI 编程工具越来越强,但很多人在使用 AI 写代码时会遇到一个问题:需求都在聊天记录里,代码越写越快,但上下文越来越乱,最终很难判断 AI 实现的到底是不是最初想要的东西。 OpenSp…...

Sunshine游戏串流完整指南:5分钟搭建你的个人游戏云

Sunshine游戏串流完整指南:5分钟搭建你的个人游戏云 【免费下载链接】Sunshine Self-hosted game stream host for Moonlight. 项目地址: https://gitcode.com/GitHub_Trending/su/Sunshine 还在为无法在客厅大屏上畅玩书房电脑里的3A大作而烦恼吗&#xff1…...

碧蓝航线Alas脚本:解放双手的终极自动化解决方案

碧蓝航线Alas脚本:解放双手的终极自动化解决方案 【免费下载链接】AzurLaneAutoScript Azur Lane bot (CN/EN/JP/TW) 碧蓝航线脚本 | 无缝委托科研,全自动大世界 项目地址: https://gitcode.com/gh_mirrors/az/AzurLaneAutoScript 你是否厌倦了每…...

学习规划需要定期调整吗?

在当今竞争激烈的教育环境中,学习规划对于学生的成长和发展起着至关重要的作用。作为一名在学习规划领域深耕十年的专家,我见证了无数学生在学习规划的指引下取得优异成绩,也看到了一些学生因为规划不合理而走了不少弯路。那么,学…...

Android Studio中文界面完整汉化指南:三步打造母语开发环境

Android Studio中文界面完整汉化指南:三步打造母语开发环境 【免费下载链接】AndroidStudioChineseLanguagePack AndroidStudio中文插件(官方修改版本) 项目地址: https://gitcode.com/gh_mirrors/an/AndroidStudioChineseLanguagePack 还在为And…...

RGB无人机图像实现野火温度预测与分割技术解析

1. 项目概述:RGB无人机图像实现野火温度预测与分割 在野火监测领域,无人机搭载热成像传感器已成为主流方案,但高昂的硬件成本和有限的续航能力始终是规模化部署的瓶颈。我们团队开发的SAM-TIFF框架突破性地实现了仅用普通RGB摄像头就能完成两…...

Keil嵌入式开发中malloc返回NULL的解决方案

1. 问题现象与背景解析在嵌入式开发中使用Keil工具链时,不少开发者遇到过这样的困境:明明调用了标准的malloc函数申请内存,却总是收到NULL返回值。这个问题看似简单,却直接导致程序功能异常,特别是在动态内存管理场景下…...

如何用5分钟将B站视频变成文字稿:bili2text终极指南

如何用5分钟将B站视频变成文字稿:bili2text终极指南 【免费下载链接】bili2text Bilibili视频转文字,一步到位,输入链接即可使用 项目地址: https://gitcode.com/gh_mirrors/bi/bili2text 你是否曾经为了整理B站视频笔记而反复暂停、回…...

XUnity自动翻译器:打破游戏语言障碍的终极解决方案

XUnity自动翻译器:打破游戏语言障碍的终极解决方案 【免费下载链接】XUnity.AutoTranslator 项目地址: https://gitcode.com/gh_mirrors/xu/XUnity.AutoTranslator 还在为看不懂外语游戏而烦恼吗?XUnity自动翻译器就是你需要的答案!这…...

ARM PMU性能监控机制与微架构事件解析

1. ARM PMU性能监控体系深度解析性能监控单元(PMU)是现代处理器中用于统计硬件事件的关键模块,它如同处理器的"听诊器",能够精确捕捉微架构层面的各类行为。在ARMv8/v9架构中,PMU通过事件计数器机制实现对指令流水线、缓存子系统、…...

告别环境冲突:用Conda+Docker在Win10上丝滑搭建MMDetection双环境(附CUDA 11.1/PyTorch 1.8配置)

深度学习环境工程化实践:Conda与Docker双方案打造MMDetection高效工作流 在Windows系统上搭建深度学习开发环境,就像在雷区跳舞——CUDA版本冲突、Python依赖不兼容、系统环境污染等问题随时可能引爆。以MMDetection为例,这个强大的目标检测工…...

Win10混合现实模拟器初体验:除了测试,还能怎么玩?

Win10混合现实模拟器:从测试工具到创意游乐场的5种玩法 当你第一次打开Win10混合现实模拟器,看到那个漂浮的手柄模型和空荡荡的虚拟空间时,是否也产生过"就这?"的疑问?这个被多数教程简单带过的内置工具&…...

C++ vector动态数组:从原理到实战的完整指南

1. 项目概述:为什么我们需要动态数组?在C的世界里,如果你是从C语言转过来的,或者刚开始接触系统级的编程,第一个让你感到“束手束脚”的,很可能就是数组。C风格的数组,大小必须在编译时确定&…...

手把手教你用VSCode+OpenOCD实时查看HPM6750外设寄存器(附SVD文件配置)

手把手教你用VSCodeOpenOCD实时监控HPM6750寄存器状态 调试嵌入式系统时,最令人头疼的莫过于面对一个"黑箱"——明明程序在跑,却看不到硬件寄存器的实时状态。这种盲目操作就像蒙着眼睛修车,效率低下且容易出错。本文将彻底解决这个…...

基于XCKU060 FPGA的高速数据采集卡硬件架构与开发实践

1. 项目概述与核心价值最近在做一个高速数据采集与实时处理的项目,对市面上的FPGA加速卡做了一圈调研和测试。其中,青翼这款基于XCKU060 FPGA的4路SFP光纤数据处理板卡(型号PCIE734)给我留下了挺深的印象。它本质上是一张插在服务…...

硬件入门 + 单片机基础(第17天)云端物模型自定义

一、阿里云后台配置(添加 3 个标准属性)1. 进入物模型编辑页物联网平台 → 对应产品 → 功能定义 → 编辑物模型2. 逐个添加属性温度功能类型:设备属性功能名称:温度标识符:Temperature数据类型:浮点型&…...