|  | @@ -1,6 +1,8 @@
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  package io.helidon.benchmark.nima.models;
 |  |  package io.helidon.benchmark.nima.models;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +import java.util.HashMap;
 | 
											
												
													
														|  | 
 |  | +import java.util.Map;
 | 
											
												
													
														|  |  import java.util.concurrent.locks.ReentrantLock;
 |  |  import java.util.concurrent.locks.ReentrantLock;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  import io.vertx.core.Vertx;
 |  |  import io.vertx.core.Vertx;
 | 
											
										
											
												
													
														|  | @@ -12,38 +14,38 @@ import io.vertx.sqlclient.RowSet;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  class PgClientConnectionPool implements AutoCloseable {
 |  |  class PgClientConnectionPool implements AutoCloseable {
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -    private final int size;
 |  | 
 | 
											
												
													
														|  |      private final Vertx vertx;
 |  |      private final Vertx vertx;
 | 
											
												
													
														|  |      private final PgConnectOptions options;
 |  |      private final PgConnectOptions options;
 | 
											
												
													
														|  | -    private final PgClientConnection[] connections;
 |  | 
 | 
											
												
													
														|  |      private final ReentrantLock lock = new ReentrantLock();
 |  |      private final ReentrantLock lock = new ReentrantLock();
 | 
											
												
													
														|  | 
 |  | +    private final Map<String, PgClientConnection> connectionMap = new HashMap<>();
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -    public PgClientConnectionPool(Vertx vertx, int size, PgConnectOptions options) {
 |  | 
 | 
											
												
													
														|  | -        this.size = size;
 |  | 
 | 
											
												
													
														|  | 
 |  | +    public PgClientConnectionPool(Vertx vertx, PgConnectOptions options) {
 | 
											
												
													
														|  |          this.vertx = vertx;
 |  |          this.vertx = vertx;
 | 
											
												
													
														|  |          this.options = options;
 |  |          this.options = options;
 | 
											
												
													
														|  | -        this.connections = new PgClientConnection[size];
 |  | 
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      public PgClientConnection clientConnection() {
 |  |      public PgClientConnection clientConnection() {
 | 
											
												
													
														|  | -        int bucket = Thread.currentThread().hashCode() % size;
 |  | 
 | 
											
												
													
														|  | -        if (connections[bucket] == null) {
 |  | 
 | 
											
												
													
														|  | 
 |  | +        String carrierThread = carrierThread();
 | 
											
												
													
														|  | 
 |  | +        PgClientConnection connection = connectionMap.get(carrierThread);
 | 
											
												
													
														|  | 
 |  | +        if (connection == null) {
 | 
											
												
													
														|  |              try {
 |  |              try {
 | 
											
												
													
														|  |                  lock.lock();
 |  |                  lock.lock();
 | 
											
												
													
														|  | -                if (connections[bucket] == null) {
 |  | 
 | 
											
												
													
														|  | -                    connect(bucket);
 |  | 
 | 
											
												
													
														|  | 
 |  | +                connection = connectionMap.get(carrierThread);
 | 
											
												
													
														|  | 
 |  | +                if (connection == null) {
 | 
											
												
													
														|  | 
 |  | +                    connection = newConnection();
 | 
											
												
													
														|  | 
 |  | +                    connectionMap.put(carrierThread, connection);
 | 
											
												
													
														|  |                  }
 |  |                  }
 | 
											
												
													
														|  |              } finally {
 |  |              } finally {
 | 
											
												
													
														|  |                  lock.unlock();
 |  |                  lock.unlock();
 | 
											
												
													
														|  |              }
 |  |              }
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  | -        return connections[bucket];
 |  | 
 | 
											
												
													
														|  | 
 |  | +        return connection;
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      @Override
 |  |      @Override
 | 
											
												
													
														|  |      public void close() {
 |  |      public void close() {
 | 
											
												
													
														|  |          try {
 |  |          try {
 | 
											
												
													
														|  | -            for (PgClientConnection connection : connections) {
 |  | 
 | 
											
												
													
														|  | 
 |  | +            for (PgClientConnection connection : connectionMap.values()) {
 | 
											
												
													
														|  |                  connection.close();
 |  |                  connection.close();
 | 
											
												
													
														|  |              }
 |  |              }
 | 
											
												
													
														|  |          } catch (Exception e) {
 |  |          } catch (Exception e) {
 | 
											
										
											
												
													
														|  | @@ -51,20 +53,25 @@ class PgClientConnectionPool implements AutoCloseable {
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -    private void connect(int bucket) {
 |  | 
 | 
											
												
													
														|  | 
 |  | +    private PgClientConnection newConnection() {
 | 
											
												
													
														|  |          try {
 |  |          try {
 | 
											
												
													
														|  |              PgConnection conn = PgConnection.connect(vertx, options)
 |  |              PgConnection conn = PgConnection.connect(vertx, options)
 | 
											
												
													
														|  |                      .toCompletionStage().toCompletableFuture().get();
 |  |                      .toCompletionStage().toCompletableFuture().get();
 | 
											
												
													
														|  |              PgClientConnection clientConn = new PgClientConnection(conn);
 |  |              PgClientConnection clientConn = new PgClientConnection(conn);
 | 
											
												
													
														|  |              clientConn.prepare();
 |  |              clientConn.prepare();
 | 
											
												
													
														|  | -            connections[bucket] = clientConn;
 |  | 
 | 
											
												
													
														|  | 
 |  | +            return clientConn;
 | 
											
												
													
														|  |          } catch (Exception e) {
 |  |          } catch (Exception e) {
 | 
											
												
													
														|  |              throw new RuntimeException(e);
 |  |              throw new RuntimeException(e);
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +    static String carrierThread() {
 | 
											
												
													
														|  | 
 |  | +        String threadName = Thread.currentThread().toString();
 | 
											
												
													
														|  | 
 |  | +        return threadName.substring(threadName.indexOf('@') + 1);
 | 
											
												
													
														|  | 
 |  | +    }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |      public static class PgClientConnection implements AutoCloseable {
 |  |      public static class PgClientConnection implements AutoCloseable {
 | 
											
												
													
														|  | -        private static final int UPDATE_QUERIES = 500;
 |  | 
 | 
											
												
													
														|  | 
 |  | +        static final int UPDATE_QUERIES = 500;
 | 
											
												
													
														|  |          private static String SELECT_WORLD = "SELECT id, randomnumber from WORLD where id=$1";
 |  |          private static String SELECT_WORLD = "SELECT id, randomnumber from WORLD where id=$1";
 | 
											
												
													
														|  |          private static String SELECT_FORTUNE = "SELECT id, message from FORTUNE";
 |  |          private static String SELECT_FORTUNE = "SELECT id, message from FORTUNE";
 | 
											
												
													
														|  |  
 |  |  
 |