AppModule.java 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637
  1. package inject;
  2. import akka.dispatch.ExecutionContexts;
  3. import com.google.inject.AbstractModule;
  4. import com.google.inject.Provides;
  5. import com.google.inject.Singleton;
  6. import com.google.inject.name.Named;
  7. import java.util.concurrent.LinkedBlockingQueue;
  8. import java.util.concurrent.ThreadPoolExecutor;
  9. import java.util.concurrent.TimeUnit;
  10. import play.Configuration;
  11. import play.core.NamedThreadFactory;
  12. import scala.concurrent.ExecutionContext;
  13. public class AppModule extends AbstractModule {
  14. protected void configure() {
  15. }
  16. @Provides @Singleton @Named("dbTpe")
  17. public ThreadPoolExecutor provideThreadPoolExecutor(Configuration configuration) {
  18. int partitionCount = configuration.getInt("db.default.partitionCount");
  19. int maxConnections = partitionCount * configuration.getInt("db.default.maxConnectionsPerPartition");
  20. int minConnections = partitionCount * configuration.getInt("db.default.minConnectionsPerPartition");
  21. return new ThreadPoolExecutor(minConnections, maxConnections,
  22. 0L, TimeUnit.MILLISECONDS,
  23. new LinkedBlockingQueue<>(),
  24. new NamedThreadFactory("dbEc"));
  25. }
  26. @Provides @Singleton @Named("dbEc")
  27. public ExecutionContext provideExecutionContext(@Named("dbTpe") ThreadPoolExecutor tpe) {
  28. return ExecutionContexts.fromExecutorService(tpe);
  29. }
  30. }