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

Oracle链接服务器导致SQL Server异常终止

现象

首先该链接服务器是使用 OraOLEDB provider (OLEDB Provider for Oracle)创建的,在使用该链接服务器的SQL语句中出现特殊字符 “--”时,例如,SELECT * FROM OPENQUERY(LINKEDSERVER_OA,‘SELECT * FROM student WHERE name = ''王'' --一些注释’),就会导致SQL Server服务异常终止。

在Windows 系统事件日志中看到“SQL Server (MSSQLSERVER) 服务意外终止,它已执行此操作 X 次”的错误消息。另外SQL Server会生成DUMP文件。

注意,软硬件故障、杀毒软件、安全软件等都会导致SQL Server进程异常终止并生成EXCEPTION_ACCESS_VIOLATION的DUMP。因此一定要通过WinDbg分析DUMP文件,只有看到下面的程序运行堆栈才能确定是链接服务器导致的。

原因

首先这是Oracle的链接服务器提供程序(OraOLEDB Provider)的BUG,当遇到特殊字符“--”时,错误地修改了不属于它的堆内存,如果进程内的堆函数不稳定,为了防止数据损坏,操作系统会自动关闭该进程。 当该链接服务器提供程序配置为“允许进程内”,SQL Server进程将一起关闭。详细请参考微软官方文档:https://learn.microsoft.com/en-US/troubleshoot/sql/database-engine/linked-servers/crashes-run-oracle-linked-server-query。

图片

解决

  1. 去掉SQL语句中的特殊字符,如果是为了注释用的,可以替换成“/**/”;

  2. Oracle官网上下载最新的链接服务器提供程序,https://www.oracle.com/database/technologies/odac-downloads.html;

  3. 禁用该提供程序的“允许进程内”选项(重启SQL Server服务后生效)。链接服务器提供程序进程作为独立的进程运行,被终止时不会导致SQL Server进程的终止,把影响控制在局部。

产品&服务

SQL专家云产品介绍

Moebius多活集群产品介绍

数据库协作运维服务

 北京格瑞趋势科技有限公司是聚焦于数据服务的高新技术企业,成立于2008年,创始团队及核心技术人员来自微软和雅虎。微软数据平台长期合作伙伴,卫宁健康数据平台战略合作伙伴。通过产品+服务双轮驱动的业务模式,14年间累计服务4000+客户,覆盖互联网、市政、交通、电信、医疗、教育、电力、制造业等各个领域。

相关文章:

  • 相机的方向和位置
  • 波特五力分析——AI与思维模型【99】
  • 软件工程之软件项目管理深度解析
  • The 2024 ICPC Kunming Invitational Contest G. Be Positive
  • 人工智能 机器学习期末考试题
  • 8.1.Kubernetes进阶
  • 事务失效的场景
  • 【推荐笔记工具】思源笔记 - 隐私优先的个人知识管理系统,支持 Markdown 排版、块级引用和双向链接
  • Swagger 3.0 中注解详细示例
  • 【计算机网络-传输层】传输层协议-TCP核心机制与可靠性保障
  • ai break down 带有#和t=的路由
  • 《探索React Native社交应用中WebRTC实现低延迟音视频通话的奥秘》
  • 从 Qwen-3 发布看 AI 服务器选型新方向:硬件配置与成本优化策略
  • 大数据狙击金融欺诈——技术如何守护交易安全?
  • 成龙电影中的三菱汽车
  • VUE2课程计划表练习
  • LeetCode 3342.到达最后一个房间的最少时间 II:dijkstra算法(和I一样)
  • Linux 系统无法启动的排查与修复方案
  • C#黑魔法:鸭子类型(Duck Typing)
  • 实现strStr
  • 中俄弘扬正确二战史观:缅怀历史,重拾初心,阻止悲剧重演
  • 数理+AI+工程,上海交大将开首届“笛卡尔班”招生约20名
  • 印对巴军事打击后,巴外交部召见印度驻巴临时代办
  • 我国外汇储备规模连续17个月稳定在3.2万亿美元以上
  • 个人住房公积金贷款利率下调,100万元30年期贷款总利息将减少近5万元
  • “两高”出台司法解释,严打破坏黑土地资源犯罪