小编Ivo*_*ken的帖子

Apache Solr:Slave每次轮询时复制10次以上(过多的提交?)

我们使用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)

java replication solr master-slave

18
推荐指数
1
解决办法
727
查看次数

仅对复杂类型的模式进行Jaxb验证

我有一个包含请求和响应元素的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),因此我必须使用一些约束:

  • 这些模式不是由我们制作的,无法编辑,因此删除文档或添加元素不是一种选择.
  • 由于重复和可能的人为错误,我宁愿从1个地方加载xsd.Xsd存储在一个单独的项目中,该项目构建我们在项目中作为依赖项包含的jar.包含xjc生成的类的jar也包含模式.
  • xsd包含大量导入.
  • 由于命名空间和类加载冲突,我无法使用xjc生成的ObjectFactory.多个xsd具有相同的命名空间但实际上是不同的,这导致错误的ObjectFactory加载到使用多个xsd的通用项目中的问题.

我尝试过转换模式以手动添加元素,但我找不到在现有Schema对象上执行此操作的方法.如果我通过DOM操作执行此操作,我将新模式作为String对象获取,它不会解析为Schema,因为无法找到导入的xsd.

如果我将jar中的xsd复制到项目中,我可以对它们进行转换并使验证成功,但我并不喜欢这个解决方案.如果没有别的办法,我会回过头来看,但我想找到一种解决方案,在重复使用这种方法时,尽可能少的工作,并且最不容易出错.其他开发人员将使用此代码和1验证方法,而无需额外的工作步骤将是完美的.

我之前遇到了基本上这个问题,然后也找不到解决方案.但之前,complexType不是根元素,我可以将它包装到其他对象中,直到我找到一个在xsd中表示为元素的对象.

java jaxb xml-validation

8
推荐指数
1
解决办法
1111
查看次数

标签 统计

java ×2

jaxb ×1

master-slave ×1

replication ×1

solr ×1

xml-validation ×1