Merge pull request #447 from metamx/fix-configmanager

Move db specific things from ConfigManager into DbConnector
This commit is contained in:
fjy 2014-03-27 16:47:03 -06:00
commit bc4bc277f2
5 changed files with 153 additions and 126 deletions

View File

@ -23,7 +23,6 @@ import com.google.common.base.Supplier;
import com.google.common.base.Throwables; import com.google.common.base.Throwables;
import com.google.common.collect.Maps; import com.google.common.collect.Maps;
import com.google.inject.Inject; import com.google.inject.Inject;
import com.metamx.common.ISE;
import com.metamx.common.concurrent.ScheduledExecutors; import com.metamx.common.concurrent.ScheduledExecutors;
import com.metamx.common.lifecycle.LifecycleStart; import com.metamx.common.lifecycle.LifecycleStart;
import com.metamx.common.lifecycle.LifecycleStop; import com.metamx.common.lifecycle.LifecycleStop;
@ -31,16 +30,8 @@ import com.metamx.common.logger.Logger;
import io.druid.db.DbConnector; import io.druid.db.DbConnector;
import io.druid.db.DbTablesConfig; import io.druid.db.DbTablesConfig;
import org.joda.time.Duration; import org.joda.time.Duration;
import org.skife.jdbi.v2.Handle;
import org.skife.jdbi.v2.IDBI;
import org.skife.jdbi.v2.StatementContext;
import org.skife.jdbi.v2.tweak.HandleCallback;
import org.skife.jdbi.v2.tweak.ResultSetMapper;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Arrays; import java.util.Arrays;
import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.concurrent.Callable; import java.util.concurrent.Callable;
import java.util.concurrent.ConcurrentMap; import java.util.concurrent.ConcurrentMap;
@ -57,38 +48,25 @@ public class ConfigManager
private final Object lock = new Object(); private final Object lock = new Object();
private boolean started = false; private boolean started = false;
private final IDBI dbi; private final DbConnector dbConnector;
private final Supplier<ConfigManagerConfig> config; private final Supplier<ConfigManagerConfig> config;
private final ScheduledExecutorService exec; private final ScheduledExecutorService exec;
private final ConcurrentMap<String, ConfigHolder> watchedConfigs; private final ConcurrentMap<String, ConfigHolder> watchedConfigs;
private final String selectStatement; private final String configTable;
private final String insertStatement;
private volatile ConfigManager.PollingCallable poller; private volatile ConfigManager.PollingCallable poller;
@Inject @Inject
public ConfigManager(IDBI dbi, Supplier<DbTablesConfig> dbTables, Supplier<ConfigManagerConfig> config) public ConfigManager(DbConnector dbConnector, Supplier<DbTablesConfig> dbTables, Supplier<ConfigManagerConfig> config)
{ {
this.dbi = dbi; this.dbConnector = dbConnector;
this.config = config; this.config = config;
this.exec = ScheduledExecutors.fixed(1, "config-manager-%s"); this.exec = ScheduledExecutors.fixed(1, "config-manager-%s");
this.watchedConfigs = Maps.newConcurrentMap(); this.watchedConfigs = Maps.newConcurrentMap();
final String configTable = dbTables.get().getConfigTable(); this.configTable = dbTables.get().getConfigTable();
this.selectStatement = String.format("SELECT payload FROM %s WHERE name = :name", configTable);
this.insertStatement = String.format(
DbConnector.isPostgreSQL(dbi) ?
"BEGIN;\n" +
"LOCK TABLE %1$s IN SHARE ROW EXCLUSIVE MODE;\n" +
"WITH upsert AS (UPDATE %1$s SET payload=:payload WHERE name=:name RETURNING *)\n" +
" INSERT INTO %1$s (name, payload) SELECT :name, :payload WHERE NOT EXISTS (SELECT * FROM upsert)\n;" +
"COMMIT;" :
"INSERT INTO %s (name, payload) VALUES (:name, :payload) ON DUPLICATE KEY UPDATE payload = :payload",
configTable
);
} }
@LifecycleStart @LifecycleStart
@ -127,7 +105,7 @@ public class ConfigManager
{ {
for (Map.Entry<String, ConfigHolder> entry : watchedConfigs.entrySet()) { for (Map.Entry<String, ConfigHolder> entry : watchedConfigs.entrySet()) {
try { try {
if (entry.getValue().swapIfNew(lookup(entry.getKey()))) { if (entry.getValue().swapIfNew(dbConnector.lookup(configTable, "name", "payload", entry.getKey()))) {
log.info("New value for key[%s] seen.", entry.getKey()); log.info("New value for key[%s] seen.", entry.getKey());
} }
} }
@ -159,7 +137,7 @@ public class ConfigManager
// Multiple of these callables can be submitted at the same time, but the callables themselves // Multiple of these callables can be submitted at the same time, but the callables themselves
// are executed serially, so double check that it hasn't already been populated. // are executed serially, so double check that it hasn't already been populated.
if (!watchedConfigs.containsKey(key)) { if (!watchedConfigs.containsKey(key)) {
byte[] value = lookup(key); byte[] value = dbConnector.lookup(configTable, "name", "payload", key);
ConfigHolder<T> holder = new ConfigHolder<T>(value, serde); ConfigHolder<T> holder = new ConfigHolder<T>(value, serde);
watchedConfigs.put(key, holder); watchedConfigs.put(key, holder);
} }
@ -187,45 +165,10 @@ public class ConfigManager
return holder.getReference(); return holder.getReference();
} }
public byte[] lookup(final String key)
{
return dbi.withHandle(
new HandleCallback<byte[]>()
{
@Override
public byte[] withHandle(Handle handle) throws Exception
{
List<byte[]> matched = handle.createQuery(selectStatement)
.bind("name", key)
.map(
new ResultSetMapper<byte[]>()
{
@Override
public byte[] map(int index, ResultSet r, StatementContext ctx)
throws SQLException
{
return r.getBytes("payload");
}
}
).list();
if (matched.isEmpty()) {
return null;
}
if (matched.size() > 1) {
throw new ISE("Error! More than one matching entry[%d] found for [%s]?!", matched.size(), key);
}
return matched.get(0);
}
}
);
}
public <T> boolean set(final String key, final ConfigSerde<T> serde, final T obj) public <T> boolean set(final String key, final ConfigSerde<T> serde, final T obj)
{ {
if (obj == null) { if (obj == null || !started) {
return false; return false;
} }
@ -238,20 +181,7 @@ public class ConfigManager
@Override @Override
public Boolean call() throws Exception public Boolean call() throws Exception
{ {
dbi.withHandle( dbConnector.insertOrUpdate(configTable, "name", "payload", key, newBytes);
new HandleCallback<Void>()
{
@Override
public Void withHandle(Handle handle) throws Exception
{
handle.createStatement(insertStatement)
.bind("name", key)
.bind("payload", newBytes)
.execute();
return null;
}
}
);
final ConfigHolder configHolder = watchedConfigs.get(key); final ConfigHolder configHolder = watchedConfigs.get(key);
if (configHolder != null) { if (configHolder != null) {

View File

@ -21,14 +21,18 @@ package io.druid.db;
import com.google.common.base.Supplier; import com.google.common.base.Supplier;
import com.google.inject.Inject; import com.google.inject.Inject;
import com.metamx.common.ISE;
import com.metamx.common.logger.Logger; import com.metamx.common.logger.Logger;
import org.apache.commons.dbcp.BasicDataSource; import org.apache.commons.dbcp.BasicDataSource;
import org.skife.jdbi.v2.DBI; import org.skife.jdbi.v2.DBI;
import org.skife.jdbi.v2.Handle; import org.skife.jdbi.v2.Handle;
import org.skife.jdbi.v2.IDBI; import org.skife.jdbi.v2.IDBI;
import org.skife.jdbi.v2.StatementContext;
import org.skife.jdbi.v2.tweak.HandleCallback; import org.skife.jdbi.v2.tweak.HandleCallback;
import org.skife.jdbi.v2.tweak.ResultSetMapper;
import javax.sql.DataSource; import javax.sql.DataSource;
import java.sql.ResultSet;
import java.sql.SQLException; import java.sql.SQLException;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
@ -39,58 +43,61 @@ public class DbConnector
{ {
private static final Logger log = new Logger(DbConnector.class); private static final Logger log = new Logger(DbConnector.class);
public static void createSegmentTable(final IDBI dbi, final String segmentTableName) public static void createSegmentTable(final IDBI dbi, final String segmentTableName, boolean isPostgreSQL)
{ {
createTable( createTable(
dbi, dbi,
segmentTableName, segmentTableName,
String.format( String.format(
isPostgreSQL(dbi) ? isPostgreSQL ?
"CREATE TABLE %1$s (id VARCHAR(255) NOT NULL, dataSource VARCHAR(255) NOT NULL, created_date TEXT NOT NULL, start TEXT NOT NULL, \"end\" TEXT NOT NULL, partitioned SMALLINT NOT NULL, version TEXT NOT NULL, used BOOLEAN NOT NULL, payload bytea NOT NULL, PRIMARY KEY (id));" + "CREATE TABLE %1$s (id VARCHAR(255) NOT NULL, dataSource VARCHAR(255) NOT NULL, created_date TEXT NOT NULL, start TEXT NOT NULL, \"end\" TEXT NOT NULL, partitioned SMALLINT NOT NULL, version TEXT NOT NULL, used BOOLEAN NOT NULL, payload bytea NOT NULL, PRIMARY KEY (id));" +
"CREATE INDEX ON %1$s(dataSource);"+ "CREATE INDEX ON %1$s(dataSource);"+
"CREATE INDEX ON %1$s(used);": "CREATE INDEX ON %1$s(used);":
"CREATE table %s (id VARCHAR(255) NOT NULL, dataSource VARCHAR(255) NOT NULL, created_date TINYTEXT NOT NULL, start TINYTEXT NOT NULL, end TINYTEXT NOT NULL, partitioned BOOLEAN NOT NULL, version TINYTEXT NOT NULL, used BOOLEAN NOT NULL, payload LONGTEXT NOT NULL, INDEX(dataSource), INDEX(used), PRIMARY KEY (id))", "CREATE table %s (id VARCHAR(255) NOT NULL, dataSource VARCHAR(255) NOT NULL, created_date TINYTEXT NOT NULL, start TINYTEXT NOT NULL, end TINYTEXT NOT NULL, partitioned BOOLEAN NOT NULL, version TINYTEXT NOT NULL, used BOOLEAN NOT NULL, payload LONGTEXT NOT NULL, INDEX(dataSource), INDEX(used), PRIMARY KEY (id))",
segmentTableName segmentTableName
) ),
isPostgreSQL
); );
} }
public static void createRuleTable(final IDBI dbi, final String ruleTableName) public static void createRuleTable(final IDBI dbi, final String ruleTableName, boolean isPostgreSQL)
{ {
createTable( createTable(
dbi, dbi,
ruleTableName, ruleTableName,
String.format( String.format(
isPostgreSQL(dbi) ? isPostgreSQL ?
"CREATE TABLE %1$s (id VARCHAR(255) NOT NULL, dataSource VARCHAR(255) NOT NULL, version TEXT NOT NULL, payload bytea NOT NULL, PRIMARY KEY (id));"+ "CREATE TABLE %1$s (id VARCHAR(255) NOT NULL, dataSource VARCHAR(255) NOT NULL, version TEXT NOT NULL, payload bytea NOT NULL, PRIMARY KEY (id));"+
"CREATE INDEX ON %1$s(dataSource);": "CREATE INDEX ON %1$s(dataSource);":
"CREATE table %s (id VARCHAR(255) NOT NULL, dataSource VARCHAR(255) NOT NULL, version TINYTEXT NOT NULL, payload LONGTEXT NOT NULL, INDEX(dataSource), PRIMARY KEY (id))", "CREATE table %s (id VARCHAR(255) NOT NULL, dataSource VARCHAR(255) NOT NULL, version TINYTEXT NOT NULL, payload LONGTEXT NOT NULL, INDEX(dataSource), PRIMARY KEY (id))",
ruleTableName ruleTableName
) ),
isPostgreSQL
); );
} }
public static void createConfigTable(final IDBI dbi, final String configTableName) public static void createConfigTable(final IDBI dbi, final String configTableName, boolean isPostgreSQL)
{ {
createTable( createTable(
dbi, dbi,
configTableName, configTableName,
String.format( String.format(
isPostgreSQL(dbi) ? isPostgreSQL ?
"CREATE TABLE %s (name VARCHAR(255) NOT NULL, payload bytea NOT NULL, PRIMARY KEY(name))": "CREATE TABLE %s (name VARCHAR(255) NOT NULL, payload bytea NOT NULL, PRIMARY KEY(name))":
"CREATE table %s (name VARCHAR(255) NOT NULL, payload BLOB NOT NULL, PRIMARY KEY(name))", "CREATE table %s (name VARCHAR(255) NOT NULL, payload BLOB NOT NULL, PRIMARY KEY(name))",
configTableName configTableName
) ),
isPostgreSQL
); );
} }
public static void createTaskTable(final IDBI dbi, final String taskTableName) public static void createTaskTable(final IDBI dbi, final String taskTableName, boolean isPostgreSQL)
{ {
createTable( createTable(
dbi, dbi,
taskTableName, taskTableName,
String.format( String.format(
isPostgreSQL(dbi) ? isPostgreSQL ?
"CREATE TABLE %1$s (\n" "CREATE TABLE %1$s (\n"
+ " id varchar(255) NOT NULL,\n" + " id varchar(255) NOT NULL,\n"
+ " created_date TEXT NOT NULL,\n" + " created_date TEXT NOT NULL,\n"
@ -112,17 +119,18 @@ public class DbConnector
+ " KEY (active, created_date(100))\n" + " KEY (active, created_date(100))\n"
+ ")", + ")",
taskTableName taskTableName
) ),
isPostgreSQL
); );
} }
public static void createTaskLogTable(final IDBI dbi, final String taskLogsTableName) public static void createTaskLogTable(final IDBI dbi, final String taskLogsTableName, boolean isPostgreSQL)
{ {
createTable( createTable(
dbi, dbi,
taskLogsTableName, taskLogsTableName,
String.format( String.format(
isPostgreSQL(dbi) ? isPostgreSQL ?
"CREATE TABLE %1$s (\n" "CREATE TABLE %1$s (\n"
+ " id bigserial NOT NULL,\n" + " id bigserial NOT NULL,\n"
+ " task_id varchar(255) DEFAULT NULL,\n" + " task_id varchar(255) DEFAULT NULL,\n"
@ -138,17 +146,18 @@ public class DbConnector
+ " KEY `task_id` (`task_id`)\n" + " KEY `task_id` (`task_id`)\n"
+ ")", + ")",
taskLogsTableName taskLogsTableName
) ),
isPostgreSQL
); );
} }
public static void createTaskLockTable(final IDBI dbi, final String taskLocksTableName) public static void createTaskLockTable(final IDBI dbi, final String taskLocksTableName, boolean isPostgreSQL)
{ {
createTable( createTable(
dbi, dbi,
taskLocksTableName, taskLocksTableName,
String.format( String.format(
isPostgreSQL(dbi) ? isPostgreSQL ?
"CREATE TABLE %1$s (\n" "CREATE TABLE %1$s (\n"
+ " id bigserial NOT NULL,\n" + " id bigserial NOT NULL,\n"
+ " task_id varchar(255) DEFAULT NULL,\n" + " task_id varchar(255) DEFAULT NULL,\n"
@ -164,14 +173,16 @@ public class DbConnector
+ " KEY `task_id` (`task_id`)\n" + " KEY `task_id` (`task_id`)\n"
+ ")", + ")",
taskLocksTableName taskLocksTableName
) ),
isPostgreSQL
); );
} }
public static void createTable( public static void createTable(
final IDBI dbi, final IDBI dbi,
final String tableName, final String tableName,
final String sql final String sql,
final boolean isPostgreSQL
) )
{ {
try { try {
@ -182,7 +193,7 @@ public class DbConnector
public Void withHandle(Handle handle) throws Exception public Void withHandle(Handle handle) throws Exception
{ {
List<Map<String, Object>> table; List<Map<String, Object>> table;
if ( isPostgreSQL(dbi) ) { if ( isPostgreSQL ) {
table = handle.select(String.format("SELECT tablename FROM pg_catalog.pg_tables WHERE schemaname = 'public' AND tablename LIKE '%s'", tableName)); table = handle.select(String.format("SELECT tablename FROM pg_catalog.pg_tables WHERE schemaname = 'public' AND tablename LIKE '%s'", tableName));
} else { } else {
table = handle.select(String.format("SHOW tables LIKE '%s'", tableName)); table = handle.select(String.format("SHOW tables LIKE '%s'", tableName));
@ -205,6 +216,84 @@ public class DbConnector
} }
} }
public Void insertOrUpdate(
final String tableName,
final String keyColumn,
final String valueColumn,
final String key,
final byte[] value
) throws SQLException
{
final String insertOrUpdateStatement = String.format(
isPostgreSQL ?
"BEGIN;\n" +
"LOCK TABLE %1$s IN SHARE ROW EXCLUSIVE MODE;\n" +
"WITH upsert AS (UPDATE %1$s SET %3$s=:value WHERE %2$s=:key RETURNING *)\n" +
" INSERT INTO %1$s (%2$s, %3$s) SELECT :key, :value WHERE NOT EXISTS (SELECT * FROM upsert)\n;" +
"COMMIT;" :
"INSERT INTO %1$s (%2$s, %3$s) VALUES (:key, :value) ON DUPLICATE KEY UPDATE %3$s = :value",
tableName, keyColumn, valueColumn
);
return dbi.withHandle(
new HandleCallback<Void>()
{
@Override
public Void withHandle(Handle handle) throws Exception
{
handle.createStatement(insertOrUpdateStatement)
.bind("key", key)
.bind("value", value)
.execute();
return null;
}
}
);
}
public byte[] lookup(
final String tableName,
final String keyColumn,
final String valueColumn,
final String key
)
{
final String selectStatement = String.format("SELECT %s FROM %s WHERE %s = :key", valueColumn, tableName, keyColumn);
return dbi.withHandle(
new HandleCallback<byte[]>()
{
@Override
public byte[] withHandle(Handle handle) throws Exception
{
List<byte[]> matched = handle.createQuery(selectStatement)
.bind("key", key)
.map(
new ResultSetMapper<byte[]>()
{
@Override
public byte[] map(int index, ResultSet r, StatementContext ctx)
throws SQLException
{
return r.getBytes(valueColumn);
}
}
).list();
if (matched.isEmpty()) {
return null;
}
if (matched.size() > 1) {
throw new ISE("Error! More than one matching entry[%d] found for [%s]?!", matched.size(), key);
}
return matched.get(0);
}
}
);
}
public static Boolean isPostgreSQL(final IDBI dbi) public static Boolean isPostgreSQL(final IDBI dbi)
{ {
return dbi.withHandle( return dbi.withHandle(
@ -219,7 +308,7 @@ public class DbConnector
); );
} }
public static Boolean isPostgreSQL(final Handle handle) throws SQLException protected static Boolean isPostgreSQL(final Handle handle) throws SQLException
{ {
return handle.getConnection().getMetaData().getDatabaseProductName().contains("PostgreSQL"); return handle.getConnection().getMetaData().getDatabaseProductName().contains("PostgreSQL");
} }
@ -227,6 +316,7 @@ public class DbConnector
private final Supplier<DbConnectorConfig> config; private final Supplier<DbConnectorConfig> config;
private final Supplier<DbTablesConfig> dbTables; private final Supplier<DbTablesConfig> dbTables;
private final DBI dbi; private final DBI dbi;
private boolean isPostgreSQL = false;
@Inject @Inject
public DbConnector(Supplier<DbConnectorConfig> config, Supplier<DbTablesConfig> dbTables) public DbConnector(Supplier<DbConnectorConfig> config, Supplier<DbTablesConfig> dbTables)
@ -242,6 +332,11 @@ public class DbConnector
return dbi; return dbi;
} }
public boolean isPostgreSQL()
{
return isPostgreSQL;
}
private DataSource getDatasource() private DataSource getDatasource()
{ {
DbConnectorConfig connectorConfig = config.get(); DbConnectorConfig connectorConfig = config.get();
@ -249,7 +344,9 @@ public class DbConnector
BasicDataSource dataSource = new BasicDataSource(); BasicDataSource dataSource = new BasicDataSource();
dataSource.setUsername(connectorConfig.getUser()); dataSource.setUsername(connectorConfig.getUser());
dataSource.setPassword(connectorConfig.getPassword()); dataSource.setPassword(connectorConfig.getPassword());
dataSource.setUrl(connectorConfig.getConnectURI()); String uri = connectorConfig.getConnectURI();
isPostgreSQL = uri.startsWith("jdbc:postgresql");
dataSource.setUrl(uri);
if (connectorConfig.isUseValidationQuery()) { if (connectorConfig.isUseValidationQuery()) {
dataSource.setValidationQuery(connectorConfig.getValidationQuery()); dataSource.setValidationQuery(connectorConfig.getValidationQuery());
@ -262,21 +359,21 @@ public class DbConnector
public void createSegmentTable() public void createSegmentTable()
{ {
if (config.get().isCreateTables()) { if (config.get().isCreateTables()) {
createSegmentTable(dbi, dbTables.get().getSegmentsTable()); createSegmentTable(dbi, dbTables.get().getSegmentsTable(), isPostgreSQL);
} }
} }
public void createRulesTable() public void createRulesTable()
{ {
if (config.get().isCreateTables()) { if (config.get().isCreateTables()) {
createRuleTable(dbi, dbTables.get().getRulesTable()); createRuleTable(dbi, dbTables.get().getRulesTable(), isPostgreSQL);
} }
} }
public void createConfigTable() public void createConfigTable()
{ {
if (config.get().isCreateTables()) { if (config.get().isCreateTables()) {
createConfigTable(dbi, dbTables.get().getConfigTable()); createConfigTable(dbi, dbTables.get().getConfigTable(), isPostgreSQL);
} }
} }
@ -284,9 +381,9 @@ public class DbConnector
{ {
if (config.get().isCreateTables()) { if (config.get().isCreateTables()) {
final DbTablesConfig dbTablesConfig = dbTables.get(); final DbTablesConfig dbTablesConfig = dbTables.get();
createTaskTable(dbi, dbTablesConfig.getTasksTable()); createTaskTable(dbi, dbTablesConfig.getTasksTable(), isPostgreSQL);
createTaskLogTable(dbi, dbTablesConfig.getTaskLogTable()); createTaskLogTable(dbi, dbTablesConfig.getTaskLogTable(), isPostgreSQL);
createTaskLockTable(dbi, dbTablesConfig.getTaskLockTable()); createTaskLockTable(dbi, dbTablesConfig.getTaskLockTable(), isPostgreSQL);
} }
} }
} }

View File

@ -66,6 +66,6 @@ public class JacksonConfigManagerModule implements Module
} }
); );
return new ConfigManager(dbConnector.getDBI(), dbTables, config); return new ConfigManager(dbConnector, dbTables, config);
} }
} }

View File

@ -60,24 +60,24 @@ public class IndexerDBCoordinator
private final ObjectMapper jsonMapper; private final ObjectMapper jsonMapper;
private final DbTablesConfig dbTables; private final DbTablesConfig dbTables;
private final IDBI dbi; private final DbConnector dbConnector;
@Inject @Inject
public IndexerDBCoordinator( public IndexerDBCoordinator(
ObjectMapper jsonMapper, ObjectMapper jsonMapper,
DbTablesConfig dbTables, DbTablesConfig dbTables,
IDBI dbi DbConnector dbConnector
) )
{ {
this.jsonMapper = jsonMapper; this.jsonMapper = jsonMapper;
this.dbTables = dbTables; this.dbTables = dbTables;
this.dbi = dbi; this.dbConnector = dbConnector;
} }
public List<DataSegment> getUsedSegmentsForInterval(final String dataSource, final Interval interval) public List<DataSegment> getUsedSegmentsForInterval(final String dataSource, final Interval interval)
throws IOException throws IOException
{ {
final VersionedIntervalTimeline<String, DataSegment> timeline = dbi.withHandle( final VersionedIntervalTimeline<String, DataSegment> timeline = dbConnector.getDBI().withHandle(
new HandleCallback<VersionedIntervalTimeline<String, DataSegment>>() new HandleCallback<VersionedIntervalTimeline<String, DataSegment>>()
{ {
@Override @Override
@ -142,7 +142,7 @@ public class IndexerDBCoordinator
*/ */
public Set<DataSegment> announceHistoricalSegments(final Set<DataSegment> segments) throws IOException public Set<DataSegment> announceHistoricalSegments(final Set<DataSegment> segments) throws IOException
{ {
return dbi.inTransaction( return dbConnector.getDBI().inTransaction(
new TransactionCallback<Set<DataSegment>>() new TransactionCallback<Set<DataSegment>>()
{ {
@Override @Override
@ -180,7 +180,7 @@ public class IndexerDBCoordinator
try { try {
handle.createStatement( handle.createStatement(
String.format( String.format(
DbConnector.isPostgreSQL(handle) ? dbConnector.isPostgreSQL() ?
"INSERT INTO %s (id, dataSource, created_date, start, \"end\", partitioned, version, used, payload) " "INSERT INTO %s (id, dataSource, created_date, start, \"end\", partitioned, version, used, payload) "
+ "VALUES (:id, :dataSource, :created_date, :start, :end, :partitioned, :version, :used, :payload)": + "VALUES (:id, :dataSource, :created_date, :start, :end, :partitioned, :version, :used, :payload)":
"INSERT INTO %s (id, dataSource, created_date, start, end, partitioned, version, used, payload) " "INSERT INTO %s (id, dataSource, created_date, start, end, partitioned, version, used, payload) "
@ -200,8 +200,6 @@ public class IndexerDBCoordinator
.execute(); .execute();
log.info("Published segment [%s] to DB", segment.getIdentifier()); log.info("Published segment [%s] to DB", segment.getIdentifier());
} catch(SQLException e) {
throw new IOException(e);
} catch(Exception e) { } catch(Exception e) {
if (e.getCause() instanceof SQLException && segmentExists(handle, segment)) { if (e.getCause() instanceof SQLException && segmentExists(handle, segment)) {
log.info("Found [%s] in DB, not updating DB", segment.getIdentifier()); log.info("Found [%s] in DB, not updating DB", segment.getIdentifier());
@ -234,7 +232,7 @@ public class IndexerDBCoordinator
public void updateSegmentMetadata(final Set<DataSegment> segments) throws IOException public void updateSegmentMetadata(final Set<DataSegment> segments) throws IOException
{ {
dbi.inTransaction( dbConnector.getDBI().inTransaction(
new TransactionCallback<Void>() new TransactionCallback<Void>()
{ {
@Override @Override
@ -252,7 +250,7 @@ public class IndexerDBCoordinator
public void deleteSegments(final Set<DataSegment> segments) throws IOException public void deleteSegments(final Set<DataSegment> segments) throws IOException
{ {
dbi.inTransaction( dbConnector.getDBI().inTransaction(
new TransactionCallback<Void>() new TransactionCallback<Void>()
{ {
@Override @Override
@ -295,7 +293,7 @@ public class IndexerDBCoordinator
public List<DataSegment> getUnusedSegmentsForInterval(final String dataSource, final Interval interval) public List<DataSegment> getUnusedSegmentsForInterval(final String dataSource, final Interval interval)
{ {
List<DataSegment> matchingSegments = dbi.withHandle( List<DataSegment> matchingSegments = dbConnector.getDBI().withHandle(
new HandleCallback<List<DataSegment>>() new HandleCallback<List<DataSegment>>()
{ {
@Override @Override
@ -303,7 +301,7 @@ public class IndexerDBCoordinator
{ {
return handle.createQuery( return handle.createQuery(
String.format( String.format(
DbConnector.isPostgreSQL(handle)? dbConnector.isPostgreSQL() ?
"SELECT payload FROM %s WHERE dataSource = :dataSource and start >= :start and \"end\" <= :end and used = false": "SELECT payload FROM %s WHERE dataSource = :dataSource and start >= :start and \"end\" <= :end and used = false":
"SELECT payload FROM %s WHERE dataSource = :dataSource and start >= :start and end <= :end and used = false", "SELECT payload FROM %s WHERE dataSource = :dataSource and start >= :start and end <= :end and used = false",
dbTables.getSegmentsTable() dbTables.getSegmentsTable()

View File

@ -74,13 +74,15 @@ public class DatabaseRuleManager
@Override @Override
public Void withHandle(Handle handle) throws Exception public Void withHandle(Handle handle) throws Exception
{ {
List<Map<String, Object>> existing = handle.select( List<Map<String, Object>> existing = handle
.createQuery(
String.format( String.format(
"SELECT id from %s where datasource='%s';", "SELECT id from %s where datasource=:dataSource;",
ruleTable, ruleTable
defaultTier
) )
); )
.bind("dataSource", defaultTier)
.list();
if (!existing.isEmpty()) { if (!existing.isEmpty()) {
return null; return null;