ARTEMIS-145 moving compact command under tools

https://issues.apache.org/jira/browse/ARTEMIS-145
This commit is contained in:
Clebert Suconic 2015-06-26 13:16:09 -04:00
parent 6a59443d2d
commit 33b81c91a6
3 changed files with 24 additions and 24 deletions

View File

@ -31,6 +31,7 @@ import org.apache.activemq.artemis.cli.commands.Kill;
import org.apache.activemq.artemis.cli.commands.Producer; import org.apache.activemq.artemis.cli.commands.Producer;
import org.apache.activemq.artemis.cli.commands.Run; import org.apache.activemq.artemis.cli.commands.Run;
import org.apache.activemq.artemis.cli.commands.Stop; import org.apache.activemq.artemis.cli.commands.Stop;
import org.apache.activemq.artemis.cli.commands.tools.CompactJournal;
import org.apache.activemq.artemis.cli.commands.tools.DecodeJournal; import org.apache.activemq.artemis.cli.commands.tools.DecodeJournal;
import org.apache.activemq.artemis.cli.commands.tools.EncodeJournal; import org.apache.activemq.artemis.cli.commands.tools.EncodeJournal;
import org.apache.activemq.artemis.cli.commands.tools.HelpData; import org.apache.activemq.artemis.cli.commands.tools.HelpData;
@ -101,9 +102,10 @@ public class Artemis
builder.withGroup("data") builder.withGroup("data")
.withDescription("data tools group (print|exp|imp|exp|encode|decode) (example ./artemis data print)"). .withDescription("data tools group (print|exp|imp|exp|encode|decode|compact) (example ./artemis data print)").
withDefaultCommand(HelpData.class).withCommands(PrintData.class, XmlDataExporter.class, withDefaultCommand(HelpData.class).withCommands(PrintData.class, XmlDataExporter.class,
XmlDataImporter.class, DecodeJournal.class, EncodeJournal.class); XmlDataImporter.class, DecodeJournal.class, EncodeJournal.class,
CompactJournal.class);
if (instance != null) if (instance != null)
{ {

View File

@ -14,42 +14,40 @@
* See the License for the specific language governing permissions and * See the License for the specific language governing permissions and
* limitations under the License. * limitations under the License.
*/ */
package org.apache.activemq.artemis.core.journal.impl; package org.apache.activemq.artemis.cli.commands.tools;
import java.io.File; import java.io.File;
import io.airlift.airline.Command;
import org.apache.activemq.artemis.cli.commands.Action;
import org.apache.activemq.artemis.cli.commands.ActionContext;
import org.apache.activemq.artemis.core.config.Configuration;
import org.apache.activemq.artemis.core.journal.IOCriticalErrorListener; import org.apache.activemq.artemis.core.journal.IOCriticalErrorListener;
import org.apache.activemq.artemis.core.journal.impl.JournalImpl;
import org.apache.activemq.artemis.core.journal.impl.NIOSequentialFileFactory;
/** @Command(name = "compact", description = "Compacts the journal of a non running server")
* This is an undocumented class, that will open a journal and force compacting on it. public final class CompactJournal extends DataAbstract implements Action
* <p>
* It may be used under special cases, but it shouldn't be needed under regular circumstances as the
* system should detect the need for compacting. The regular use is to configure min-compact
* parameters.
*/
public final class CompactJournal // NO_UCD
{ {
@Override
public static void main(final String[] arg) public Object execute(ActionContext context) throws Exception
{ {
if (arg.length != 4) super.execute(context);
{
System.err.println("Use: java -cp activemq-core.jar org.apache.activemq.artemis.core.journal.impl.CompactJournal <JournalDirectory> <JournalPrefix> <FileExtension> <FileSize>");
return;
}
try try
{ {
CompactJournal.compactJournal(new File(arg[0]), arg[1], arg[2], 2, Integer.parseInt(arg[3]), null); Configuration configuration = getFileConfiguration();
compactJournal(new File(getJournal()), "activemq-data", "amq", configuration.getJournalMinFiles(), configuration.getJournalFileSize(), null);
compactJournal(new File(getBinding()), "activemq-bindings", "bindings", 2, 1048576, null);
} }
catch (Exception e) catch (Exception e)
{ {
e.printStackTrace(); treatError(e, "data", "compact");
} }
return null;
} }
static void compactJournal(final File directory,
void compactJournal(final File directory,
final String journalPrefix, final String journalPrefix,
final String journalSuffix, final String journalSuffix,
final int minFiles, final int minFiles,

View File

@ -1459,7 +1459,7 @@ public class JournalImpl extends JournalBase implements TestableJournal, Journal
* Note: only synchronized methods on journal are methods responsible for the life-cycle such as * Note: only synchronized methods on journal are methods responsible for the life-cycle such as
* stop, start records will still come as this is being executed * stop, start records will still come as this is being executed
*/ */
protected synchronized void compact() throws Exception public synchronized void compact() throws Exception
{ {
if (compactor != null) if (compactor != null)
{ {