16 changed files with 191 additions and 83 deletions
@ -0,0 +1,59 @@ |
|||
/** |
|||
* Copyright © 2016-2018 The Thingsboard Authors |
|||
* |
|||
* Licensed under the Apache License, Version 2.0 (the "License"); |
|||
* you may not use this file except in compliance with the License. |
|||
* You may obtain a copy of the License at |
|||
* |
|||
* http://www.apache.org/licenses/LICENSE-2.0
|
|||
* |
|||
* Unless required by applicable law or agreed to in writing, software |
|||
* distributed under the License is distributed on an "AS IS" BASIS, |
|||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
|||
* See the License for the specific language governing permissions and |
|||
* limitations under the License. |
|||
*/ |
|||
package org.thingsboard.server.service.executors; |
|||
|
|||
import com.google.common.util.concurrent.ListenableFuture; |
|||
import com.google.common.util.concurrent.ListeningExecutorService; |
|||
import com.google.common.util.concurrent.MoreExecutors; |
|||
import org.thingsboard.rule.engine.api.ListeningExecutor; |
|||
|
|||
import javax.annotation.PostConstruct; |
|||
import javax.annotation.PreDestroy; |
|||
import java.util.concurrent.Callable; |
|||
import java.util.concurrent.Executors; |
|||
|
|||
/** |
|||
* Created by igor on 4/13/18. |
|||
*/ |
|||
public abstract class AbstractListeningExecutor implements ListeningExecutor { |
|||
|
|||
private ListeningExecutorService service; |
|||
|
|||
@PostConstruct |
|||
public void init() { |
|||
this.service = MoreExecutors.listeningDecorator(Executors.newFixedThreadPool(getThreadPollSize())); |
|||
} |
|||
|
|||
@PreDestroy |
|||
public void destroy() { |
|||
if (this.service != null) { |
|||
this.service.shutdown(); |
|||
} |
|||
} |
|||
|
|||
@Override |
|||
public <T> ListenableFuture<T> executeAsync(Callable<T> task) { |
|||
return service.submit(task); |
|||
} |
|||
|
|||
@Override |
|||
public void execute(Runnable command) { |
|||
service.execute(command); |
|||
} |
|||
|
|||
protected abstract int getThreadPollSize(); |
|||
|
|||
} |
|||
@ -0,0 +1,32 @@ |
|||
/** |
|||
* Copyright © 2016-2018 The Thingsboard Authors |
|||
* |
|||
* Licensed under the Apache License, Version 2.0 (the "License"); |
|||
* you may not use this file except in compliance with the License. |
|||
* You may obtain a copy of the License at |
|||
* |
|||
* http://www.apache.org/licenses/LICENSE-2.0
|
|||
* |
|||
* Unless required by applicable law or agreed to in writing, software |
|||
* distributed under the License is distributed on an "AS IS" BASIS, |
|||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
|||
* See the License for the specific language governing permissions and |
|||
* limitations under the License. |
|||
*/ |
|||
package org.thingsboard.server.service.executors; |
|||
|
|||
import org.springframework.beans.factory.annotation.Value; |
|||
import org.springframework.stereotype.Component; |
|||
|
|||
@Component |
|||
public class DbCallbackExecutorService extends AbstractListeningExecutor { |
|||
|
|||
@Value("${actors.rule.db_callback_thread_pool_size}") |
|||
private int dbCallbackExecutorThreadPoolSize; |
|||
|
|||
@Override |
|||
protected int getThreadPollSize() { |
|||
return dbCallbackExecutorThreadPoolSize; |
|||
} |
|||
|
|||
} |
|||
File diff suppressed because one or more lines are too long
Loading…
Reference in new issue