Add a command for dumping Redis command stats.
This commit is contained in:
		
							parent
							
								
									1a57d4fe11
								
							
						
					
					
						commit
						019ffdaf12
					
				|  | @ -155,6 +155,7 @@ import org.whispersystems.textsecuregcm.websocket.ProvisioningConnectListener; | |||
| import org.whispersystems.textsecuregcm.websocket.WebSocketAccountAuthenticator; | ||||
| import org.whispersystems.textsecuregcm.workers.CertificateCommand; | ||||
| import org.whispersystems.textsecuregcm.workers.DeleteUserCommand; | ||||
| import org.whispersystems.textsecuregcm.workers.GetRedisCommandStatsCommand; | ||||
| import org.whispersystems.textsecuregcm.workers.GetRedisSlowlogCommand; | ||||
| import org.whispersystems.textsecuregcm.workers.VacuumCommand; | ||||
| import org.whispersystems.textsecuregcm.workers.ZkParamsCommand; | ||||
|  | @ -191,6 +192,7 @@ public class WhisperServerService extends Application<WhisperServerConfiguration | |||
|     bootstrap.addCommand(new CertificateCommand()); | ||||
|     bootstrap.addCommand(new ZkParamsCommand()); | ||||
|     bootstrap.addCommand(new GetRedisSlowlogCommand()); | ||||
|     bootstrap.addCommand(new GetRedisCommandStatsCommand()); | ||||
| 
 | ||||
|     bootstrap.addBundle(new NameableMigrationsBundle<WhisperServerConfiguration>("accountdb", "accountsdb.xml") { | ||||
|       @Override | ||||
|  |  | |||
|  | @ -0,0 +1,35 @@ | |||
| package org.whispersystems.textsecuregcm.workers; | ||||
| 
 | ||||
| import io.dropwizard.cli.ConfiguredCommand; | ||||
| import io.dropwizard.setup.Bootstrap; | ||||
| import net.sourceforge.argparse4j.inf.Namespace; | ||||
| import org.whispersystems.textsecuregcm.WhisperServerConfiguration; | ||||
| import org.whispersystems.textsecuregcm.redis.FaultTolerantRedisCluster; | ||||
| 
 | ||||
| import java.util.List; | ||||
| 
 | ||||
| public class GetRedisCommandStatsCommand extends ConfiguredCommand<WhisperServerConfiguration> { | ||||
| 
 | ||||
|     public GetRedisCommandStatsCommand() { | ||||
|         super("rediscommandstats", "Dump Redis command stats"); | ||||
|     } | ||||
| 
 | ||||
|     @Override | ||||
|     protected void run(final Bootstrap<WhisperServerConfiguration> bootstrap, final Namespace namespace, final WhisperServerConfiguration config) throws Exception { | ||||
|         final FaultTolerantRedisCluster cacheCluster         = new FaultTolerantRedisCluster("main_cache_cluster", config.getCacheClusterConfiguration()); | ||||
|         final FaultTolerantRedisCluster messagesCacheCluster = new FaultTolerantRedisCluster("messages_cluster", config.getMessageCacheConfiguration().getRedisClusterConfiguration()); | ||||
|         final FaultTolerantRedisCluster metricsCluster       = new FaultTolerantRedisCluster("metrics_cluster", config.getMetricsClusterConfiguration()); | ||||
| 
 | ||||
|         for (final FaultTolerantRedisCluster cluster : List.of(cacheCluster, messagesCacheCluster, metricsCluster)) { | ||||
|             cluster.useCluster(connection -> connection.sync() | ||||
|                     .masters() | ||||
|                     .commands() | ||||
|                     .info("commandstats") | ||||
|                     .asMap() | ||||
|                     .forEach((node, commandStats) -> { | ||||
|                         System.out.format("# %s - %s\n\n", cluster.getName(), node.getUri()); | ||||
|                         System.out.println(commandStats); | ||||
|                     })); | ||||
|         } | ||||
|     } | ||||
| } | ||||
		Loading…
	
		Reference in New Issue
	
	 Jon Chambers
						Jon Chambers