首页 > 基础设施 > 正文

在 Oracle 中如何配置和运行外部存储过程

双色球预测最准确 www.qa2n.com.cn 2018-06-20 10:06:31  来源:搜狐

摘要:Oracle 数据库的外部存储过程特性提供了在 C 语言(或能通过 C 调用的其他语言)中实现代码逻辑然后在数据库中通过 PLSQL 运行的功能。
关键词: Oracle
  概述
 
  Oracle 数据库的外部存储过程特性提供了在 C 语言(或能通过 C 调用的其他语言)中实现代码逻辑然后在数据库中通过 PLSQL 运行的功能。
 
  怎样来做?
 
  首先,C 代码需要编译,然后需要从它创建共享库文件(.so)或动态链接库(DLL)(在使用 Windows 的情况下)。需要在数据库中创建一个 library 对象才能从 PLSQL 代码引用这个共享库文件或 DLL。该 Library 需要通过调用规范发布,使用特殊语法,例如 CREATE OR REPLACE 语句的 IS|AS LANGUAGE 子句?;谎灾?,这只是一个 PLSQL 封装器(也称为外部过程)单元,它告诉什么库需要被调用和库中的哪个函数需要运行。
 
\
 
  Oracle 数据库提供了一个"extproc"代理,来帮助 Oracle 和共享库之间的通信。这个代理装载 library,传递任何(如果有的话)参数到这个 library,运行它并且返回结果到调用会话。
 
  extproc 代理如何配置?
 
  有几个方法可以配置 extproc 代理。
 
  使用默认配置,Oracle 数据库每当调用一个外部存储过程时创建一个代理。
 
  编辑 listener.ora 和 tnsnames.ora 来创建一个监听配置覆盖掉默认的配置。在这种情况下,extproc 在每次调用外部存储过程时由 listener 创建。
 
  当使用多线程 extproc agent 或使用 AGENT IN 语句来定义 library 时,必须使用 listener 创建的代理。Oracle 数据库和 listener 创建的代理都是独立的代理?;谎灾?,Oracle 数据库和 listener 创建的都是独立的代理,如果外部存储过程使用得很多,就会影响性能。这可以通过配置多线程代理来解决(MTA)。
 
  MTA 模式
 
  在 MTA 模式中,可以指定在任何给定时间点运行的 extproc 代理的最大数量。 请求由多线程代理根据负载来进行提取和服务。MTA可以使用"agtctl"工具来配置。


第二十八届CIO班招生
法国布雷斯特商学院MBA班招生
法国布雷斯特商学院硕士班招生
责编:pingxiaoli
  • 创新步伐永不停 “智”检尖兵勇当先 ——“互联网+”助力上海检验检疫通检再提速 2019-03-23
  • 近9亿元大单抢筹创业板 机构集中推荐32只个股 2019-03-23
  • 张洪在湘东走访慰问困难群众 2019-03-22
  • 5.20表白日 看乌鲁木齐情侣们南山花样秀甜蜜 2019-03-22
  • 吃这些隔夜食物 轻得肠胃炎重则致癌 2019-03-21
  • 考试即将结束 家长望眼欲穿【高清组图】【2】 2019-03-21
  • 权健队长多年后重返国家队 四大门神齐聚一门花落谁家? 2019-03-20
  • 从稳中向好发展态势看我国经济良好前景 2019-03-20
  • 网友投诉不文明养犬行为 有关部门加强治理 2019-03-19
  • 广东梅州:以农村信用体系建设促进社会治理显成效 2019-03-19
  • 信心持续攀升预期比较乐观 2019-03-15
  • 发现食品安全问题拨打12331投诉 2019-03-15
  • 《相会中华腾飞时 传世经典颂恩来》诗歌咏诵汇于南开中学举行 2019-03-11
  • 来,给你看看三农最热的六条“新”闻! 2019-03-11
  • 人民网发布2017企业社会责任报告 热衷搭平台成企业履责新特色 2019-02-27
  • 552| 717| 780| 688| 761| 577| 115| 127| 462| 731|