我们使用Apache Solr(3.1.0)来索引为多个站点编写的大量文章.我们有一个主/从设置(底部的复制配置),其中服务器1索引文章,服务器2复制索引.奴隶应该每隔60秒轮询主人,但相反,我们/replication几乎每次都能看到10到75个连续的呼叫.
每个Solr核心(${solr.core.name}在从配置中)代表不同的站点./replication我最看到的电话与最大的网站有关.其中一个核心每分钟只有1个呼叫,并且在调用update?commit=true几次之后我已经能够在那里重现它,所以这让我认为它与主机执行的提交量有关.
所以我的问题是,如何阻止Solr奴隶复制索引几十次并迫使它每分钟复制一次?我尝试过使用commitReserveDurationmaster配置中的参数,但我真的没有看到任何区别.
主复制配置:
<requestHandler name="/replication" class="solr.ReplicationHandler" >
<lst name="master">
<str name="replicateAfter">commit</str>
<str name="replicateAfter">startup</str>
</lst>
</requestHandler>
Run Code Online (Sandbox Code Playgroud)
slave replication config:
<requestHandler name="/replication" class="solr.ReplicationHandler" >
<lst name="slave">
<str name="masterUrl">http://${solr.master.server}/search/${solr.core.name}/replication</str>
<str name="pollInterval">00:00:60</str>
</lst>
</requestHandler>
Run Code Online (Sandbox Code Playgroud) 我有一个包含请求和响应元素的wsdl:
<xsd:element name="someRequest" type="ns:SomeRequest"/>
<xsd:element name="someResponse" type="ns:SomeResponse"/>
Run Code Online (Sandbox Code Playgroud)
这个wsdl导入了一些xsd,其中包含这些complexTypes:
<xsd:complexType name="SomeRequest">
...
</xsd:complexType>
<xsd:complexType name="SomeResponse">
...
</xsd:complexType>
Run Code Online (Sandbox Code Playgroud)
我想针对这个wsdl验证一个xml,但我无法让它工作.我基本上使用http://actimem.com/java/jaxb-validation/#Marshalling_Validation上描述的方法,通过编组对象并设置Schema和EventHandler.
如果我将Schema设置为xsd,它将无法验证,因为xsd中没有元素.这很合乎逻辑,我对其他工具也一样.当我使用wsdl作为Schema时,由于内联文档,我收到此错误:
s4s-elt-character: Non-whitespace characters are not allowed in schema elements other than 'xs:appinfo' and 'xs:documentation'.
Run Code Online (Sandbox Code Playgroud)
有没有办法让这个验证?
由于我正在使用设置工作流来处理现有项目(目前使用Xmlbeans而不是JAXB),因此我必须使用一些约束:
我尝试过转换模式以手动添加元素,但我找不到在现有Schema对象上执行此操作的方法.如果我通过DOM操作执行此操作,我将新模式作为String对象获取,它不会解析为Schema,因为无法找到导入的xsd.
如果我将jar中的xsd复制到项目中,我可以对它们进行转换并使验证成功,但我并不喜欢这个解决方案.如果没有别的办法,我会回过头来看,但我想找到一种解决方案,在重复使用这种方法时,尽可能少的工作,并且最不容易出错.其他开发人员将使用此代码和1验证方法,而无需额外的工作步骤将是完美的.
我之前遇到了基本上这个问题,然后也找不到解决方案.但之前,complexType不是根元素,我可以将它包装到其他对象中,直到我找到一个在xsd中表示为元素的对象.