首页 > 基础设施 > 正文

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

双色球中奖规则 www.9q9w.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"工具来配置。

责编:pingxiaoli
  • 一些网红主播何以频频僭越法律红线 2018-12-11
  • (Dos sesiones) El pueblo es el creador de la historia y el verdadero héroe, dice presidente chino Spanish.xinhuanet.com 2018-12-11
  • 张涵予加盟《熟味3》跨国寻味 2018-12-10
  • 四件汉白玉螭头回归圆明园 2018-12-10
  • 男子冒充澳商交往多人行骗被抓 现场来6个女友 2018-12-03
  • 2018世界杯进入倒计时  莫斯科举行大型灯光秀 2018-12-03
  • 《中国新说唱》开始全新录制 融合传统文化元素 2018-11-02
  • 大豆自己种,芯片自己造 2018-11-02
  • 对于不听话的人,中国有句古语形容,叫做“有爹生无娘教”。它是什么意思你懂吗?我家的孩子和后人,永远都得听包括我在内的前辈怎么教他们做人,因为他们之所以能为人,是 2018-10-30
  • 连续5个月空气质量优良率达100% "南宁蓝"名副其实 2018-09-14
  • 粮食过剩,就可以给年轻人设计一个轻松的环境,唱唱跳跳轻松就业,大家都会说政府真好 2018-09-14
  • 市委把全国两会精神原汁原味传达到基层 2018-08-22
  • 西班牙一旅游公司官网竟把台湾和香港列为“国家” 2018-08-17
  • “后高考”生活尤需有度 警惕“高考后综合征” 2018-08-17
  • 今年民歌节预计将有8000人前往 周边停车泊位有限 2018-08-05
  • 823| 311| 997| 868| 600| 543| 520| 291| 696| 667|