<!-- Service Engine Configuration --> <engine name="entity-auto" class="org.ofbiz.service.engine.EntityAutoEngine"/> <engine name="group" class="org.ofbiz.service.group.ServiceGroupEngine"/> <engine name="interface" class="org.ofbiz.service.engine.InterfaceEngine"/> <engine name="java" class="org.ofbiz.service.engine.StandardJavaEngine"/> <engine name="simple" class="org.ofbiz.minilang.SimpleServiceEngine"/> <engine name="script" class="org.ofbiz.service.engine.ScriptEngine"/> <!-- Engines that can be replaced by the generic script engine --> <engine name="bsh" class="org.ofbiz.service.engine.BeanShellEngine"/> <engine name="groovy" class="org.ofbiz.service.engine.GroovyEngine"> <parameter name="scriptBaseClass" value="org.ofbiz.service.engine.GroovyBaseScript"/> </engine> <engine name="jacl" class="org.ofbiz.service.engine.BSFEngine"/> <engine name="javascript" class="org.ofbiz.service.engine.ScriptEngine"/> <engine name="jpython" class="org.ofbiz.service.engine.BSFEngine"/> <!-- --> <engine name="route" class="org.ofbiz.service.engine.RouteEngine"/> <engine name="http" class="org.ofbiz.service.engine.HttpEngine"/> <engine name="jms" class="org.ofbiz.service.jms.JmsServiceEngine"/> <engine name="rmi" class="org.ofbiz.service.rmi.RmiServiceEngine"/> <engine name="soap" class="org.ofbiz.service.engine.SOAPClientEngine"/> <engine name="ofbiz-workflow" class="org.ofbiz.workflow.WorkflowEngine"/> <engine name="workflow" class="org.ofbiz.shark.service.SharkServiceEngine"/>
属性名
|
是否必须
|
描述
|
name
|
Y
|
服务引擎的名字,必须唯一
|
class
|
Y
|
GenericEngine接口的实现类
|
<!-- Name of the service to use for authorization --> <authorization service-name="userLogin"/> 服务位置: <service-location name="main-rmi" location="rmi://localhost:1099/RMIDispatcher"/> <service-location name="main-http" location="http://localhost:8080/webtools/control/httpService"/> <service-location name="entity-sync-rmi" location="rmi://localhost:1099/RMIDispatcher"/> <service-location name="entity-sync-http" location="http://localhost:8080/webtools/control/httpService"/> <service-location name="rita-rmi" location="rmi://localhost:1099/RMIDispatcher"/> <service-location name="eedcc-test" location="http://localhost:8080/webtools/control/httpService"/>
<!-- Thread pool configuration (max/min threads, uses to live and time to live) --> <thread-pool send-to-pool="pool" purge-job-days="4" failed-retry-min="3" ttl="18000000" wait-millis="750" jobs="10" min-threads="5" max-threads="15" poll-enabled="true" poll-db-millis="20000"> <run-from-pool name="pool"/> </thread-pool>
属性名
|
是否必须
|
描述
|
Ttl
|
Y
|
每个请求线程的存活时间。达到时间线程将被销毁
|
wait-millis
|
Y
|
每个请求线程在检查通过运行前休眠的时间
|
jobs
|
Y
|
每个请求线程在销毁之前可运行的工作数
|
min-threads
|
Y
|
线程池中保持的请求线程的最小数
|
max-threads
|
Y
|
线程池中将会创建请求线程的最大数
|
poll-enabled | Y | 为‘true’scheduler就会poll数据库来调度工作 |
poll-db-millis | Y | 如果线程池可用,本属性用来定义池化线程运行的频率 |
<service name="createNote" engine="java" location="org.ofbiz.common.CommonServices" invoke="createNote"> <description>Create a new note record</description> <attribute name="partyId" type="String" mode="INOUT" optional="true"/> <attribute name="noteName" type="String" mode="IN" optional="true"/> <attribute name="note" type="String" mode="IN" allow-html="safe"/> <attribute name="noteId" type="String" mode="OUT"/> </service>
属性
|
是否必须
|
说明
|
缺省值
|
name
|
Y
|
服务的唯一名称
|
|
engine
|
Y
|
引擎的名称(在serviceengine.xml中定义)
|
|
location
|
N
|
位置或服务包类的包名
|
|
invoke
|
N
|
服务的方法名
|
|
auth
|
N
|
服务是否要求授权?(true/false)
|
true
|
debug | N | 当调用服务时,是否启动详细调试?(true/false) | true |
default-entity-name | N | 使用自动属性(auto-attribute)的缺省实体 | |
export | N | 这个服务是否允许通过SOAP/HTTP/JMS访问?(true/false) | false |
validate | N | 是否对服务参数的名字和类型进行验证?(true/false) | true |
max-retry | N | 异步调用服务失败时,最大重复次数 | -1(无限次) |
use-transaction | N | 是否使用事务 | true |
require-new-transaction | N | 在使用事务的情况下是否启动新事务 | true |
semaphore | N | 并发调用服务时使用的信号量: none:当多个线程调用服务时,并发执行服务 wait:当多个线程调用服务时,采用排队的方法调用服务 fail:当服务正在被执行时,其他任何试图要调用该服务的线程都将调用失败 |
none |
semaphore-wait-seconds | N | 当sempaphore="wait"时,调用服务的线程要等待的超时时间, 超时调用失败 |
300 |
semaphore-sleep | N | 当sempaphore="wait"时,1毫秒内做几次检查 (检查服务能否被调用) |
300 |
transaction-timeout | N | 该服务的事务超时时间,当该服务启动新事务才有效 | 0 |
属性
|
是否必须
|
描述
|
缺省值
|
name
|
Y
|
这个是属性的名字
|
|
type
|
Y
|
对象的类型(String,java.util.Date)等
|
|
model
|
Y
|
这个参数是输入、输出或输入输出(IN/OUT/INOUT)
|
|
optional
|
N
|
这个参数是否可选?(true/false)
|
false
|
default-value
|
N
|
默认值
|
|
form-label | N | 对应的表单项显示名称 | |
entity-name | N | 对象名 | |
field-name | N | 属性名 | |
string-map-prefix | N | Map类型参数的前缀 | |
string-list-prefix | N | List类型参数的后缀 | |
form-display | N | 是否在表单中显示?(true/false) | true |
<!-- simple condition implementation --> <service name="effectiveDateEcaCondition" engine="java" auth="false" use-transaction="false" location="org.ofbiz.service.ServiceUtil" invoke="genericDateCondition"> <implements service="serviceEcaConditionInterface"/> <attribute name="fromDate" mode="IN" type="java.sql.Timestamp" optional="true"/> <attribute name="thruDate" mode="IN" type="java.sql.Timestamp" optional="true"/> </service>
参考二:applications/accounting/servicedef/services_finaccount.xml
<service name="refundGcPurchase" engine="java" require-new-transaction="true" use-transaction="true" location="org.ofbiz.accounting.payment.GiftCertificateServices" invoke="refundGcPurchase" auth="true"> <description>Creates return for reload on failure</description> <attribute name="orderItem" type="org.ofbiz.entity.GenericValue" mode="IN" optional="false"/> <attribute name="partyId" type="String" mode="IN" optional="false"/> </service>
参考三:framework\service\servicedef\services.xml
<!-- Service Engine Services --> <service name="purgeOldJobs" engine="java" location="org.ofbiz.service.ServiceUtil" invoke="purgeOldJobs" auth="true" use-transaction="false" semaphore="wait"> <description>Cleans out old jobs which have been around longer then what is defined in serviceengine.xml</description> <required-permissions join-type="AND"> <check-permission permission="SERVICE_INVOKE_ANY"/> </required-permissions> <!-- this service has no attributes --> </service>
<!-- Service Engine Configuration --> <engine name="entity-auto" class="org.ofbiz.service.engine.EntityAutoEngine"/> <engine name="group" class="org.ofbiz.service.group.ServiceGroupEngine"/> <engine name="interface" class="org.ofbiz.service.engine.InterfaceEngine"/> <engine name="java" class="org.ofbiz.service.engine.StandardJavaEngine"/> <engine name="simple" class="org.ofbiz.minilang.SimpleServiceEngine"/> <engine name="script" class="org.ofbiz.service.engine.ScriptEngine"/> <!-- Engines that can be replaced by the generic script engine --> <engine name="bsh" class="org.ofbiz.service.engine.BeanShellEngine"/> <engine name="groovy" class="org.ofbiz.service.engine.GroovyEngine"> <parameter name="scriptBaseClass" value="org.ofbiz.service.engine.GroovyBaseScript"/> </engine> <engine name="jacl" class="org.ofbiz.service.engine.BSFEngine"/> <engine name="javascript" class="org.ofbiz.service.engine.ScriptEngine"/> <engine name="jpython" class="org.ofbiz.service.engine.BSFEngine"/> <!-- --> <engine name="route" class="org.ofbiz.service.engine.RouteEngine"/> <engine name="http" class="org.ofbiz.service.engine.HttpEngine"/> <engine name="jms" class="org.ofbiz.service.jms.JmsServiceEngine"/> <engine name="rmi" class="org.ofbiz.service.rmi.RmiServiceEngine"/> <engine name="soap" class="org.ofbiz.service.engine.SOAPClientEngine"/> <engine name="ofbiz-workflow" class="org.ofbiz.workflow.WorkflowEngine"/> <engine name="workflow" class="org.ofbiz.shark.service.SharkServiceEngine"/>
属性名
|
是否必须
|
描述
|
name
|
Y
|
服务引擎的名字,必须唯一
|
class
|
Y
|
GenericEngine接口的实现类
|
<!-- Name of the service to use for authorization --> <authorization service-name="userLogin"/> 服务位置: <service-location name="main-rmi" location="rmi://localhost:1099/RMIDispatcher"/> <service-location name="main-http" location="http://localhost:8080/webtools/control/httpService"/> <service-location name="entity-sync-rmi" location="rmi://localhost:1099/RMIDispatcher"/> <service-location name="entity-sync-http" location="http://localhost:8080/webtools/control/httpService"/> <service-location name="rita-rmi" location="rmi://localhost:1099/RMIDispatcher"/> <service-location name="eedcc-test" location="http://localhost:8080/webtools/control/httpService"/>
<!-- Thread pool configuration (max/min threads, uses to live and time to live) --> <thread-pool send-to-pool="pool" purge-job-days="4" failed-retry-min="3" ttl="18000000" wait-millis="750" jobs="10" min-threads="5" max-threads="15" poll-enabled="true" poll-db-millis="20000"> <run-from-pool name="pool"/> </thread-pool>
属性名
|
是否必须
|
描述
|
Ttl
|
Y
|
每个请求线程的存活时间。达到时间线程将被销毁
|
wait-millis
|
Y
|
每个请求线程在检查通过运行前休眠的时间
|
jobs
|
Y
|
每个请求线程在销毁之前可运行的工作数
|
min-threads
|
Y
|
线程池中保持的请求线程的最小数
|
max-threads
|
Y
|
线程池中将会创建请求线程的最大数
|
poll-enabled | Y | 为‘true’scheduler就会poll数据库来调度工作 |
poll-db-millis | Y | 如果线程池可用,本属性用来定义池化线程运行的频率 |
<service name="createNote" engine="java" location="org.ofbiz.common.CommonServices" invoke="createNote"> <description>Create a new note record</description> <attribute name="partyId" type="String" mode="INOUT" optional="true"/> <attribute name="noteName" type="String" mode="IN" optional="true"/> <attribute name="note" type="String" mode="IN" allow-html="safe"/> <attribute name="noteId" type="String" mode="OUT"/> </service>
属性
|
是否必须
|
说明
|
缺省值
|
name
|
Y
|
服务的唯一名称
|
|
engine
|
Y
|
引擎的名称(在serviceengine.xml中定义)
|
|
location
|
N
|
位置或服务包类的包名
|
|
invoke
|
N
|
服务的方法名
|
|
auth
|
N
|
服务是否要求授权?(true/false)
|
true
|
debug | N | 当调用服务时,是否启动详细调试?(true/false) | true |
default-entity-name | N | 使用自动属性(auto-attribute)的缺省实体 | |
export | N | 这个服务是否允许通过SOAP/HTTP/JMS访问?(true/false) | false |
validate | N | 是否对服务参数的名字和类型进行验证?(true/false) | true |
max-retry | N | 异步调用服务失败时,最大重复次数 | -1(无限次) |
use-transaction | N | 是否使用事务 | true |
require-new-transaction | N | 在使用事务的情况下是否启动新事务 | true |
semaphore | N | 并发调用服务时使用的信号量: none:当多个线程调用服务时,并发执行服务 wait:当多个线程调用服务时,采用排队的方法调用服务 fail:当服务正在被执行时,其他任何试图要调用该服务的线程都将调用失败 |
none |
semaphore-wait-seconds | N | 当sempaphore="wait"时,调用服务的线程要等待的超时时间, 超时调用失败 |
300 |
semaphore-sleep | N | 当sempaphore="wait"时,1毫秒内做几次检查 (检查服务能否被调用) |
300 |
transaction-timeout | N | 该服务的事务超时时间,当该服务启动新事务才有效 | 0 |
属性
|
是否必须
|
描述
|
缺省值
|
name
|
Y
|
这个是属性的名字
|
|
type
|
Y
|
对象的类型(String,java.util.Date)等
|
|
model
|
Y
|
这个参数是输入、输出或输入输出(IN/OUT/INOUT)
|
|
optional
|
N
|
这个参数是否可选?(true/false)
|
false
|
default-value
|
N
|
默认值
|
|
form-label | N | 对应的表单项显示名称 | |
entity-name | N | 对象名 | |
field-name | N | 属性名 | |
string-map-prefix | N | Map类型参数的前缀 | |
string-list-prefix | N | List类型参数的后缀 | |
form-display | N | 是否在表单中显示?(true/false) | true |
<!-- simple condition implementation --> <service name="effectiveDateEcaCondition" engine="java" auth="false" use-transaction="false" location="org.ofbiz.service.ServiceUtil" invoke="genericDateCondition"> <implements service="serviceEcaConditionInterface"/> <attribute name="fromDate" mode="IN" type="java.sql.Timestamp" optional="true"/> <attribute name="thruDate" mode="IN" type="java.sql.Timestamp" optional="true"/> </service>
参考二:applications/accounting/servicedef/services_finaccount.xml
<service name="refundGcPurchase" engine="java" require-new-transaction="true" use-transaction="true" location="org.ofbiz.accounting.payment.GiftCertificateServices" invoke="refundGcPurchase" auth="true"> <description>Creates return for reload on failure</description> <attribute name="orderItem" type="org.ofbiz.entity.GenericValue" mode="IN" optional="false"/> <attribute name="partyId" type="String" mode="IN" optional="false"/> </service>
参考三:framework\service\servicedef\services.xml
<!-- Service Engine Services --> <service name="purgeOldJobs" engine="java" location="org.ofbiz.service.ServiceUtil" invoke="purgeOldJobs" auth="true" use-transaction="false" semaphore="wait"> <description>Cleans out old jobs which have been around longer then what is defined in serviceengine.xml</description> <required-permissions join-type="AND"> <check-permission permission="SERVICE_INVOKE_ANY"/> </required-permissions> <!-- this service has no attributes --> </service>
原文:http://www.cnblogs.com/henrylc/p/6728027.html