diff options
Diffstat (limited to 'gerrit-server/src/main/java/com/google/gerrit/server/git/GarbageCollection.java')
-rw-r--r-- | gerrit-server/src/main/java/com/google/gerrit/server/git/GarbageCollection.java | 215 |
1 files changed, 0 insertions, 215 deletions
diff --git a/gerrit-server/src/main/java/com/google/gerrit/server/git/GarbageCollection.java b/gerrit-server/src/main/java/com/google/gerrit/server/git/GarbageCollection.java deleted file mode 100644 index 3bf89c7d78..0000000000 --- a/gerrit-server/src/main/java/com/google/gerrit/server/git/GarbageCollection.java +++ /dev/null @@ -1,215 +0,0 @@ -// Copyright (C) 2012 The Android Open Source Project -// -// Licensed under the Apache License, Version 2.0 (the "License"); -// you may not use this file except in compliance with the License. -// You may obtain a copy of the License at -// -// http://www.apache.org/licenses/LICENSE-2.0 -// -// Unless required by applicable law or agreed to in writing, software -// distributed under the License is distributed on an "AS IS" BASIS, -// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -// See the License for the specific language governing permissions and -// limitations under the License. - -package com.google.gerrit.server.git; - -import com.google.common.collect.Sets; -import com.google.gerrit.common.data.GarbageCollectionResult; -import com.google.gerrit.extensions.events.GarbageCollectorListener; -import com.google.gerrit.extensions.registration.DynamicSet; -import com.google.gerrit.reviewdb.client.Project; -import com.google.gerrit.server.config.GcConfig; -import com.google.gerrit.server.extensions.events.AbstractNoNotifyEvent; -import com.google.inject.Inject; -import java.io.PrintWriter; -import java.util.List; -import java.util.Properties; -import java.util.Set; -import org.eclipse.jgit.api.GarbageCollectCommand; -import org.eclipse.jgit.api.Git; -import org.eclipse.jgit.errors.RepositoryNotFoundException; -import org.eclipse.jgit.lib.Config; -import org.eclipse.jgit.lib.ConfigConstants; -import org.eclipse.jgit.lib.NullProgressMonitor; -import org.eclipse.jgit.lib.Repository; -import org.eclipse.jgit.lib.TextProgressMonitor; -import org.eclipse.jgit.storage.pack.PackConfig; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - -public class GarbageCollection { - private static final Logger log = LoggerFactory.getLogger(GarbageCollection.class); - - public static final String LOG_NAME = "gc_log"; - private static final Logger gcLog = LoggerFactory.getLogger(LOG_NAME); - - private final GitRepositoryManager repoManager; - private final GarbageCollectionQueue gcQueue; - private final GcConfig gcConfig; - private final DynamicSet<GarbageCollectorListener> listeners; - - public interface Factory { - GarbageCollection create(); - } - - @Inject - GarbageCollection( - GitRepositoryManager repoManager, - GarbageCollectionQueue gcQueue, - GcConfig config, - DynamicSet<GarbageCollectorListener> listeners) { - this.repoManager = repoManager; - this.gcQueue = gcQueue; - this.gcConfig = config; - this.listeners = listeners; - } - - public GarbageCollectionResult run(List<Project.NameKey> projectNames) { - return run(projectNames, null); - } - - public GarbageCollectionResult run(List<Project.NameKey> projectNames, PrintWriter writer) { - return run(projectNames, gcConfig.isAggressive(), writer); - } - - public GarbageCollectionResult run( - List<Project.NameKey> projectNames, boolean aggressive, PrintWriter writer) { - GarbageCollectionResult result = new GarbageCollectionResult(); - Set<Project.NameKey> projectsToGc = gcQueue.addAll(projectNames); - for (Project.NameKey projectName : - Sets.difference(Sets.newHashSet(projectNames), projectsToGc)) { - result.addError( - new GarbageCollectionResult.Error( - GarbageCollectionResult.Error.Type.GC_ALREADY_SCHEDULED, projectName)); - } - for (Project.NameKey p : projectsToGc) { - try (Repository repo = repoManager.openRepository(p)) { - logGcConfiguration(p, repo, aggressive); - print(writer, "collecting garbage for \"" + p + "\":\n"); - GarbageCollectCommand gc = Git.wrap(repo).gc(); - gc.setAggressive(aggressive); - logGcInfo(p, "before:", gc.getStatistics()); - gc.setProgressMonitor( - writer != null ? new TextProgressMonitor(writer) : NullProgressMonitor.INSTANCE); - Properties statistics = gc.call(); - logGcInfo(p, "after: ", statistics); - print(writer, "done.\n\n"); - fire(p, statistics); - } catch (RepositoryNotFoundException e) { - logGcError(writer, p, e); - result.addError( - new GarbageCollectionResult.Error( - GarbageCollectionResult.Error.Type.REPOSITORY_NOT_FOUND, p)); - } catch (Exception e) { - logGcError(writer, p, e); - result.addError( - new GarbageCollectionResult.Error(GarbageCollectionResult.Error.Type.GC_FAILED, p)); - } finally { - gcQueue.gcFinished(p); - } - } - return result; - } - - private void fire(Project.NameKey p, Properties statistics) { - if (!listeners.iterator().hasNext()) { - return; - } - Event event = new Event(p, statistics); - for (GarbageCollectorListener l : listeners) { - try { - l.onGarbageCollected(event); - } catch (RuntimeException e) { - log.warn("Failure in GarbageCollectorListener", e); - } - } - } - - private static void logGcInfo(Project.NameKey projectName, String msg) { - logGcInfo(projectName, msg, null); - } - - private static void logGcInfo(Project.NameKey projectName, String msg, Properties statistics) { - StringBuilder b = new StringBuilder(); - b.append("[").append(projectName.get()).append("] "); - b.append(msg); - if (statistics != null) { - b.append(" "); - String s = statistics.toString(); - if (s.startsWith("{") && s.endsWith("}")) { - s = s.substring(1, s.length() - 1); - } - b.append(s); - } - gcLog.info(b.toString()); - } - - private static void logGcConfiguration( - Project.NameKey projectName, Repository repo, boolean aggressive) { - StringBuilder b = new StringBuilder(); - Config cfg = repo.getConfig(); - b.append("gc.aggressive=").append(aggressive).append("; "); - b.append(formatConfigValues(cfg, ConfigConstants.CONFIG_GC_SECTION, null)); - for (String subsection : cfg.getSubsections(ConfigConstants.CONFIG_GC_SECTION)) { - b.append(formatConfigValues(cfg, ConfigConstants.CONFIG_GC_SECTION, subsection)); - } - if (b.length() == 0) { - b.append("no set"); - } - - logGcInfo(projectName, "gc config: " + b.toString()); - logGcInfo(projectName, "pack config: " + (new PackConfig(repo)).toString()); - } - - private static String formatConfigValues(Config config, String section, String subsection) { - StringBuilder b = new StringBuilder(); - Set<String> names = config.getNames(section, subsection); - for (String name : names) { - String value = config.getString(section, subsection, name); - b.append(section); - if (subsection != null) { - b.append(".").append(subsection); - } - b.append("."); - b.append(name).append("=").append(value); - b.append("; "); - } - return b.toString(); - } - - private static void logGcError(PrintWriter writer, Project.NameKey projectName, Exception e) { - print(writer, "failed.\n\n"); - StringBuilder b = new StringBuilder(); - b.append("[").append(projectName.get()).append("]"); - gcLog.error(b.toString(), e); - log.error(b.toString(), e); - } - - private static void print(PrintWriter writer, String message) { - if (writer != null) { - writer.print(message); - } - } - - private static class Event extends AbstractNoNotifyEvent - implements GarbageCollectorListener.Event { - private final Project.NameKey p; - private final Properties statistics; - - Event(Project.NameKey p, Properties statistics) { - this.p = p; - this.statistics = statistics; - } - - @Override - public String getProjectName() { - return p.get(); - } - - @Override - public Properties getStatistics() { - return statistics; - } - } -} |