fix config manager

This commit is contained in:
fjy 2014-03-26 09:42:33 -07:00
parent 183a133ee4
commit aec6457a4d
1 changed files with 28 additions and 25 deletions

View File

@ -63,8 +63,9 @@ public class ConfigManager
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 selectStatement;
private final String insertStatement; private final String configTable;
private volatile String insertStatement;
private volatile ConfigManager.PollingCallable poller; private volatile ConfigManager.PollingCallable poller;
@Inject @Inject
@ -76,19 +77,9 @@ public class ConfigManager
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.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
@ -99,6 +90,17 @@ public class ConfigManager
return; return;
} }
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
);
poller = new PollingCallable(); poller = new PollingCallable();
ScheduledExecutors.scheduleWithFixedDelay( ScheduledExecutors.scheduleWithFixedDelay(
exec, new Duration(0), config.get().getPollDuration().toStandardDuration(), poller exec, new Duration(0), config.get().getPollDuration().toStandardDuration(), poller
@ -116,6 +118,7 @@ public class ConfigManager
return; return;
} }
insertStatement = null;
poller.stop(); poller.stop();
poller = null; poller = null;
@ -196,18 +199,18 @@ public class ConfigManager
public byte[] withHandle(Handle handle) throws Exception public byte[] withHandle(Handle handle) throws Exception
{ {
List<byte[]> matched = handle.createQuery(selectStatement) List<byte[]> matched = handle.createQuery(selectStatement)
.bind("name", key) .bind("name", key)
.map( .map(
new ResultSetMapper<byte[]>() new ResultSetMapper<byte[]>()
{ {
@Override @Override
public byte[] map(int index, ResultSet r, StatementContext ctx) public byte[] map(int index, ResultSet r, StatementContext ctx)
throws SQLException throws SQLException
{ {
return r.getBytes("payload"); return r.getBytes("payload");
} }
} }
).list(); ).list();
if (matched.isEmpty()) { if (matched.isEmpty()) {
return null; return null;
@ -225,7 +228,7 @@ public class ConfigManager
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;
} }