Package jetbrains.buildServer.diagnostic
Class MemoryProblemsHealthReport
- java.lang.Object
 - 
- jetbrains.buildServer.serverSide.healthStatus.HealthStatusReport
 - 
- jetbrains.buildServer.diagnostic.MemoryProblemsHealthReport
 
 
 
- 
- All Implemented Interfaces:
 ServerExtension,TeamCityExtension
public class MemoryProblemsHealthReport extends HealthStatusReport
Created by Andrey Titov on 3/13/14. 
- 
- 
Field Summary
Fields Modifier and Type Field Description static ItemCategoryHIGH_GC_OVERHEADstatic ItemCategoryLOW_POOL_SIZEstatic ItemCategoryLOW_TOTAL_MEMORYstatic StringMEMORY_PROBLEMS_HR_TYPE 
- 
Constructor Summary
Constructors Constructor Description MemoryProblemsHealthReport() 
- 
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description booleancanReportItemsFor(HealthStatusScope scope)Check whether the report can produce any items accepted by the specified scope.Collection<ItemCategory>getCategories()Problems categories producing by this problem finder.StringgetDisplayName()User presentable name of the problem finder.StringgetType()booleanremoveError(String poolName)voidreport(HealthStatusScope scope, HealthStatusItemConsumer resultConsumer)When called must report all found problems to result consumer according to the received scope.booleanreportGCOverheadError(double totalGcOverheadThreshold, long maxAvailable)booleanreportLowMemoryProblem(String poolName, long statisticCalculationTimeMinutes, float averageMemoryUsagePercent, long maxSize)- 
Methods inherited from class jetbrains.buildServer.serverSide.healthStatus.HealthStatusReport
equals, hashCode 
 - 
 
 - 
 
- 
- 
Field Detail
- 
MEMORY_PROBLEMS_HR_TYPE
public static final String MEMORY_PROBLEMS_HR_TYPE
- See Also:
 - Constant Field Values
 
 
- 
LOW_POOL_SIZE
public static final ItemCategory LOW_POOL_SIZE
 
- 
LOW_TOTAL_MEMORY
public static final ItemCategory LOW_TOTAL_MEMORY
 
- 
HIGH_GC_OVERHEAD
public static final ItemCategory HIGH_GC_OVERHEAD
 
 - 
 
- 
Method Detail
- 
reportGCOverheadError
public boolean reportGCOverheadError(double totalGcOverheadThreshold, long maxAvailable) 
- 
reportLowMemoryProblem
public boolean reportLowMemoryProblem(@NotNull String poolName, long statisticCalculationTimeMinutes, float averageMemoryUsagePercent, long maxSize) 
- 
removeError
public boolean removeError(String poolName)
 
- 
getType
@NotNull public String getType()
- Specified by:
 getTypein classHealthStatusReport- Returns:
 - unique identifier of the problem finder
 
 
- 
getDisplayName
@NotNull public String getDisplayName()
Description copied from class:HealthStatusReportUser presentable name of the problem finder.- Specified by:
 getDisplayNamein classHealthStatusReport- Returns:
 - name of the problem finder to show in the user interface.
 
 
- 
getCategories
@NotNull public Collection<ItemCategory> getCategories()
Description copied from class:HealthStatusReportProblems categories producing by this problem finder. All problems of 'undeclared' categories will be filtered even if they were consumed.- Specified by:
 getCategoriesin classHealthStatusReport- Returns:
 - Unmodifiable not-empty collection of unique categories producing by this problem finder.
 
 
- 
canReportItemsFor
public boolean canReportItemsFor(HealthStatusScope scope)
Description copied from class:HealthStatusReportCheck whether the report can produce any items accepted by the specified scope.HealthStatusReport.report(HealthStatusScope, HealthStatusItemConsumer)will not be called if this method return false. Implementations should not perform any complex calculations, they are expected to quickly analyzeHealthStatusScopeand return false if it is clear that they can not report any acceptable items. For example, they can return false if they can't produce items with the requested severity (that is accepted byHealthStatusScope.isItemWithSeverityAccepted(ItemSeverity)).- Specified by:
 canReportItemsForin classHealthStatusReport
 
- 
report
public void report(@NotNull HealthStatusScope scope, @NotNull HealthStatusItemConsumer resultConsumer)Description copied from class:HealthStatusReportWhen called must report all found problems to result consumer according to the received scope. Always called with system privileges (in all permissions mode) so no permission checks are required. Note that this method can be called quite often, so long-running implementations should return false fromHealthStatusReport.canReportItemsFor(HealthStatusScope)if it's clear that they can't produce any items for the requested scope. Implementations of this method should always return in a reasonable time. For example, long running computations or network calls should not be made in this method, but rather called in some background thread, their result saved to a cache, and then be read from the cache in this method.- Specified by:
 reportin classHealthStatusReport- Parameters:
 scope- health status coderesultConsumer- health status item consumer
 
 - 
 
 -