Skip to content

Commit 4ca55a6

Browse files
spkrkasduskis
authored andcommitted
---
yaml --- r: 20837 b: refs/heads/autosynth-iamcredentials c: bd8d2ce h: refs/heads/master i: 20835: ddef6b3
1 parent 9159ba5 commit 4ca55a6

2 files changed

Lines changed: 8 additions & 19 deletions

File tree

  • branches/autosynth-iamcredentials/google-cloud-clients/google-cloud-logging/src/main/java/com/google/cloud/logging

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -162,7 +162,7 @@ refs/heads/pubsub-ordering-keys: 858d4e986a0ba48e08f00d42f51cbdecb175f5d6
162162
refs/tags/v0.75.0: c3673089ae09a897c1b4cf7dfe167fe4f8ab32fb
163163
refs/tags/v0.76.0: 395b016826d3ddf9cb8b34919636df15a4dbd032
164164
refs/tags/v0.77.0: 28a85a77883ccf5d48f297fd0ef3b3dca6ce01f0
165-
refs/heads/autosynth-iamcredentials: 03ba9c91cab9113f30bfc43d185fc87d1b515303
165+
refs/heads/autosynth-iamcredentials: bd8d2cecdfb56b35d41a86697eda279e34f19bcf
166166
refs/heads/release-google-cloud-java-v0.78.0: fae5e980779cf0173a152636b278015b9f60ee55
167167
refs/heads/release-google-cloud-java-v0.81.0: 0352cd0dd11f4fd1fbd1ff16e7a96beaccc7b475
168168
refs/heads/release-google-cloud-java-v0.81.1-SNAPSHOT: 5a74ccb1f12506a3b67b65521881298fde20bd6f

branches/autosynth-iamcredentials/google-cloud-clients/google-cloud-logging/src/main/java/com/google/cloud/logging/LoggingImpl.java

Lines changed: 7 additions & 18 deletions
Original file line numberDiff line numberDiff line change
@@ -70,11 +70,9 @@
7070
import com.google.logging.v2.WriteLogEntriesResponse;
7171
import com.google.protobuf.Empty;
7272
import java.util.ArrayList;
73-
import java.util.Collections;
74-
import java.util.IdentityHashMap;
7573
import java.util.List;
7674
import java.util.Map;
77-
import java.util.Set;
75+
import java.util.concurrent.ConcurrentHashMap;
7876
import java.util.concurrent.ExecutionException;
7977
import java.util.concurrent.TimeUnit;
8078
import java.util.concurrent.TimeoutException;
@@ -83,9 +81,7 @@ class LoggingImpl extends BaseService<LoggingOptions> implements Logging {
8381

8482
private static final int FLUSH_WAIT_TIMEOUT_SECONDS = 6;
8583
private final LoggingRpc rpc;
86-
private final Object writeLock = new Object();
87-
private final Set<ApiFuture<Void>> pendingWrites =
88-
Collections.newSetFromMap(new IdentityHashMap<ApiFuture<Void>, Boolean>());
84+
private final Map<Object, ApiFuture<Void>> pendingWrites = new ConcurrentHashMap<>();
8985

9086
private volatile Synchronicity writeSynchronicity = Synchronicity.ASYNC;
9187
private volatile Severity flushSeverity = null;
@@ -575,9 +571,7 @@ public void flush() {
575571
// BUG(1795): We should force batcher to issue RPC call for buffered messages,
576572
// so the code below doesn't wait uselessly.
577573
ArrayList<ApiFuture<Void>> writesToFlush = new ArrayList<>();
578-
synchronized (writeLock) {
579-
writesToFlush.addAll(pendingWrites);
580-
}
574+
writesToFlush.addAll(pendingWrites.values());
581575

582576
try {
583577
ApiFutures.allAsList(writesToFlush).get(FLUSH_WAIT_TIMEOUT_SECONDS, TimeUnit.SECONDS);
@@ -596,16 +590,13 @@ private void writeLogEntries(Iterable<LogEntry> logEntries, WriteOption... write
596590
case ASYNC:
597591
default:
598592
final ApiFuture<Void> writeFuture = writeAsync(logEntries, writeOptions);
599-
synchronized (writeLock) {
600-
pendingWrites.add(writeFuture);
601-
}
593+
final Object pendingKey = new Object();
594+
pendingWrites.put(pendingKey, writeFuture);
602595
ApiFutures.addCallback(
603596
writeFuture,
604597
new ApiFutureCallback<Void>() {
605598
private void removeFromPending() {
606-
synchronized (writeLock) {
607-
pendingWrites.remove(writeFuture);
608-
}
599+
pendingWrites.remove(pendingKey);
609600
}
610601

611602
@Override
@@ -711,8 +702,6 @@ public void close() throws Exception {
711702

712703
@VisibleForTesting
713704
int getNumPendingWrites() {
714-
synchronized (writeLock) {
715-
return pendingWrites.size();
716-
}
705+
return pendingWrites.size();
717706
}
718707
}

0 commit comments

Comments
 (0)