WebSocketMessageBrokerStats - how to set loggingPeriod

回眸只為那壹抹淺笑 提交于 2020-04-15 10:43:11

问题


How to set loggingPeriod in WebSocketMessageBrokerStats to decrease value (default is 30')

WebSocketMessageBrokerStats is loaded by @Bean in WebSocketMessageBrokerConfigurationSupport

version : Spring 4.2.0.RELEASE

My current Config :

@Configuration
@EnableWebSocketMessageBroker
@EnableScheduling
public class AppWebSocketConfig extends AbstractWebSocketMessageBrokerConfigurer {

    @Override
    public void configureMessageBroker(final MessageBrokerRegistry config) {
        config.enableSimpleBroker("/topic");
    }

    @Override
    public void registerStompEndpoints(final StompEndpointRegistry registry) {
        registry.addEndpoint("/entry")
                .setAllowedOrigins("*")
                .withSockJS()
                .setDisconnectDelay(10000);
    }

}

回答1:




According to the WebSocketMessageBrokerStats javadoc:

This class is declared as a Spring bean by the above configuration with the name "webSocketMessageBrokerStats"

So you can add this to your configuration class:

@Autowired
private WebSocketMessageBrokerStats webSocketMessageBrokerStats;

@PostConstruct
public void init() {
    webSocketMessageBrokerStats.setLoggingPeriod(10 * 1000); // desired time in millis
}



回答2:


If you want to setup the logging period before Spring has put the bean into service, you can use a PostBeanProcessor:

@Bean
public BeanPostProcessor beanPostProcessor() {
    return new BeanPostProcessor() {
        @Override
        public Object postProcessBeforeInitialization(Object bean, String beanName) throws BeansException {
            if (bean instanceof WebSocketMessageBrokerStats) {
                WebSocketMessageBrokerStats webSocketMessageBrokerStats = (WebSocketMessageBrokerStats) bean;
                webSocketMessageBrokerStats.setLoggingPeriod(30 * 1000); // your customization
            }
            return bean;
        }

        @Override
        public Object postProcessAfterInitialization(Object bean, String beanName) throws BeansException {
            return bean;
        }
    };
}

With WebSocketMessageBrokerStats it is not much of a difference to Toyo's way. However if you have a bean which won't let you change a setting after initialization, this way will always work.



来源:https://stackoverflow.com/questions/32865949/websocketmessagebrokerstats-how-to-set-loggingperiod

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!