X-Git-Url: https://git.openstreetmap.org./chef.git/blobdiff_plain/73c1c017c5a76b80243a8b5d736d8dd554618615..7cb4a81dacec7d6c6404241b58bf8340678ab8ab:/cookbooks/planet/files/default/replication-bin/replicate-changesets diff --git a/cookbooks/planet/files/default/replication-bin/replicate-changesets b/cookbooks/planet/files/default/replication-bin/replicate-changesets index ef6a27eb9..9e1615147 100644 --- a/cookbooks/planet/files/default/replication-bin/replicate-changesets +++ b/cookbooks/planet/files/default/replication-bin/replicate-changesets @@ -144,13 +144,13 @@ class Replicator @config = YAML.load(File.read(config)) @state = YAML.load(File.read(@config["state_file"])) @conn = PGconn.connect(@config["db"]) - @now = Time.now.getutc + # get current time from the database rather than the current system + @now = @conn.exec("select now() as now").map { |row| Time.parse(row["now"]) }[0] end def open_changesets last_run = @state["last_run"] last_run = (@now - 60) if last_run.nil? - @state["last_run"] = @now # pretty much all operations on a changeset will modify its closed_at # time (see rails_port's changeset model). so it is probably enough # for us to look at anything that was closed recently, and filter from @@ -199,19 +199,22 @@ class Replicator doc.to_s end + def sequence + @state.key?("sequence") ? @state["sequence"] + 1 : 0 + end + def data_stem - sequence = (@state.key?("sequence") ? @state["sequence"] + 1 : 0) @config["data_dir"] + format("/%03d/%03d/%03d", sequence / 1000000, (sequence / 1000) % 1000, (sequence % 1000)) end - def write_tmp_files! + def write_tmp_files!(changesets) data_file = data_stem + ".osm.gz" tmp_state = @config["state_file"] + ".tmp" tmp_data = data_file + ".tmp" FileUtils.mkdir_p(File.dirname(data_file)) Zlib::GzipWriter.open(tmp_data) do |fh| - fh.write(changeset_dump(open_changesets)) + fh.write(changeset_dump(changesets)) end File.open(tmp_state, "w") do |fh| fh.write(YAML.dump(@state)) @@ -265,9 +268,11 @@ class Replicator # move them into place later, to avoid in-progress # clashes, or people seeing incomplete files. begin + changesets = open_changesets @state["sequence"] = sequence + @state["last_run"] = @now - write_tmp_files! + write_tmp_files!(changesets) move_tmp_files_into_place!