aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLeif Åstrand <leif@vaadin.com>2019-07-29 12:07:40 +0300
committerZhe Sun <31067185+ZheSun88@users.noreply.github.com>2019-08-08 10:16:07 +0300
commitb1cadbb2f24168ceb476891d0a1934cb85688fda (patch)
treed4691623909426c26b60707d03260bacbab7df7d
parent6cd0a45e514ee37193f1db46ccf56e89a3c7a065 (diff)
downloadvaadin-framework-b1cadbb2f24168ceb476891d0a1934cb85688fda.tar.gz
vaadin-framework-b1cadbb2f24168ceb476891d0a1934cb85688fda.zip
Prevent excessive getLogger() calls from markAsDirty() (#11664)
Fixes #10339
-rw-r--r--server/src/main/java/com/vaadin/ui/ConnectorTracker.java39
1 files changed, 24 insertions, 15 deletions
diff --git a/server/src/main/java/com/vaadin/ui/ConnectorTracker.java b/server/src/main/java/com/vaadin/ui/ConnectorTracker.java
index 2903337b1c..b2cb185e0a 100644
--- a/server/src/main/java/com/vaadin/ui/ConnectorTracker.java
+++ b/server/src/main/java/com/vaadin/ui/ConnectorTracker.java
@@ -70,6 +70,15 @@ import elemental.json.JsonObject;
*
*/
public class ConnectorTracker implements Serializable {
+ /**
+ * Cache whether FINE messages are loggable. This is done to avoid
+ * excessively calling getLogger() which might be slightly slow in some
+ * specific environments. Please note that we're not caching the logger
+ * instance itself because of
+ * https://github.com/vaadin/framework/issues/2092.
+ */
+ private static final boolean fineLogging = getLogger()
+ .isLoggable(Level.FINE);
private final Map<String, ClientConnector> connectorIdToConnector = new HashMap<>();
private final Set<ClientConnector> dirtyConnectors = new HashSet<>();
@@ -138,7 +147,7 @@ public class ConnectorTracker implements Serializable {
if (previouslyRegistered == null) {
connectorIdToConnector.put(connectorId, connector);
uninitializedConnectors.add(connector);
- if (getLogger().isLoggable(Level.FINE)) {
+ if (fineLogging) {
getLogger().log(Level.FINE, "Registered {0} ({1})",
new Object[] { connector.getClass().getSimpleName(),
connectorId });
@@ -191,7 +200,7 @@ public class ConnectorTracker implements Serializable {
} else if (unregisteredConnectors.add(connector)) {
// Client side knows about the connector, track it for a while if it
// becomes reattached
- if (getLogger().isLoggable(Level.FINE)) {
+ if (fineLogging) {
getLogger().log(Level.FINE, "Unregistered {0} ({1})",
new Object[] { connector.getClass().getSimpleName(),
connectorId });
@@ -339,7 +348,7 @@ public class ConnectorTracker implements Serializable {
assert isRemovalSentToClient(connector) : "Connector "
+ connector + " (id = " + connector.getConnectorId()
+ ") is no longer visible to the client, but no corresponding hierarchy change was sent.";
- if (getLogger().isLoggable(Level.FINE)) {
+ if (fineLogging) {
getLogger().log(Level.FINE,
"cleanConnectorMap removed state for {0} as it is not visible",
getConnectorAndParentInfo(connector));
@@ -524,11 +533,9 @@ public class ConnectorTracker implements Serializable {
"A connector should not be marked as dirty while a response is being written.");
}
- if (getLogger().isLoggable(Level.FINE)) {
- if (!isDirty(connector)) {
- getLogger().log(Level.FINE, "{0} is now dirty",
- getConnectorAndParentInfo(connector));
- }
+ if (fineLogging && !isDirty(connector)) {
+ getLogger().log(Level.FINE, "{0} is now dirty",
+ getConnectorAndParentInfo(connector));
}
if (!isDirty(connector)) {
@@ -545,11 +552,9 @@ public class ConnectorTracker implements Serializable {
* The connector that should be marked clean.
*/
public void markClean(ClientConnector connector) {
- if (getLogger().isLoggable(Level.FINE)) {
- if (dirtyConnectors.contains(connector)) {
- getLogger().log(Level.FINE, "{0} is no longer dirty",
- getConnectorAndParentInfo(connector));
- }
+ if (fineLogging && dirtyConnectors.contains(connector)) {
+ getLogger().log(Level.FINE, "{0} is no longer dirty",
+ getConnectorAndParentInfo(connector));
}
dirtyConnectors.remove(connector);
@@ -601,7 +606,9 @@ public class ConnectorTracker implements Serializable {
*/
public void markAllConnectorsDirty() {
markConnectorsDirtyRecursively(uI);
- getLogger().fine("All connectors are now dirty");
+ if (fineLogging) {
+ getLogger().fine("All connectors are now dirty");
+ }
}
/**
@@ -609,7 +616,9 @@ public class ConnectorTracker implements Serializable {
*/
public void markAllConnectorsClean() {
dirtyConnectors.clear();
- getLogger().fine("All connectors are now clean");
+ if (fineLogging) {
+ getLogger().fine("All connectors are now clean");
+ }
}
/**