Spring , duboo 注意事项

 1、dubbo 注解和xml配置注意事项

@Service(version = "1.0.0")

----------------------------------------------------

<dubbo:service version="1.0.0" interface="com.artbulb.search.rpc.MultiEnterService" ref="multiEnterServiceImplLocal" /> 

 

 <bean id="multiEnterServiceImplLocal"

class="com.artbulb.search.rpc.impl.MultiEnterSearchServiceImpl"

parent="eClient">

<property name="batchpageSize" value="${es.batchSize}"></property>

</bean>

 

这种情况,使用注解,property  属性是注入不进去的。使用xml配置没问题

2,spring 继承

 <bean id="multiEnterServiceImplLocal"

class="com.artbulb.search.rpc.impl.MultiEnterSearchServiceImpl"

parent="eClient">

<property name="batchpageSize" value="${es.batchSize}"></property>

</bean>

 <bean id="multiEnterServiceImplLocal2"

class="com.artbulb.search.rpc.impl.MultiEnterSearchServiceImpl"

parent="eClient">

<property name="batchpageSize" value="${es.batchSize}"></property>

</bean>

一个子类会实例化一个父类,多个子类会实例化多个父类。

3.spring 使用注解@Service 遇到有父类的情况?

同配置文件一样,一个子类会实例化一个父类对象。即使父类对象没用使用注解表明,也会被spring强行注入

 

4.dubbo 服务调试

客户端和服务端分别打开一个eclipse 调试,再同一个eclipse调试不行。

 

 5.spring Scheduled 定时器执行

@Scheduled(cron="0 */23 * * * ?") 每23分钟执行一次,整点执行一次。

6.spring Scheduled 定时器执行

@Scheduled(cron="0 */23 * * * ?") 每23分钟执行一次,整点执行一次。

@Scheduled(cron="* */23 * * * ?") 每23分钟执行一次,整点不执行。

7.Spring使用定时器任务时,并行串行

问题描述: 

在使用Sping 3的 Quartz定时器定时执行时,发现一个问题: 

对于某些执行频率非常高的作业(例如5秒执行一次),但是每次任务的执行时间又比较长(可能超过5秒)。如果要求前一次任务执行结束前,下一次任务不能被触发。Quartz的默认配置将不能满足这个情况,即:每次定时器都会准时每5秒执行一次,不管前一次有没有执行完毕。 

如果要满足上面的要求,只要在 配置 org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean 类的时候,显示的设置它的 concurrent=false 即可。这样任务便会以串行的方式执行,只有当前一次任务执行完毕,后一次任务才会触发。

如果用spring task 没配置 <task:scheduler id="taskScheduler" pool-size="42"/> ,默认是单线程处理。

猜你喜欢

转载自m635674608.iteye.com/blog/2253294
今日推荐