ZhyliaievD commented on code in PR #12835:
URL: https://github.com/apache/cloudstack/pull/12835#discussion_r3056578166
##########
plugins/network-elements/nsx/src/main/java/org/apache/cloudstack/service/NsxApiClient.java:
##########
@@ -676,27 +689,62 @@ public void
createNsxLbServerPool(List<NsxLoadBalancerMember> memberList, String
}
}
+ private Optional<LBPool> getNsxLbServerPool(LbPools lbPools, String
lbServerPoolName) {
+ try {
+ return Optional.ofNullable(lbPools.get(lbServerPoolName));
+ } catch (NotFound e) {
+ logger.debug("Server Pool not found: {}", lbServerPoolName);
+ return Optional.empty();
+ }
+ }
+
+ private boolean hasSamePoolMembers(List<LBPoolMember> existingMembers,
List<LBPoolMember> membersUpdate) {
+ Set<String> existingMembersSet = existingMembers.stream()
+ .map(this::buildPoolMemberKey)
+ .collect(toSet());
+ Set<String> updateMembersSet = membersUpdate.stream()
+ .map(this::buildPoolMemberKey)
+ .collect(toSet());
+
+ return existingMembersSet.size() == updateMembersSet.size()
+ && existingMembersSet.containsAll(updateMembersSet);
+ }
+
+ private String buildPoolMemberKey(LBPoolMember member) {
+ return member.getIpAddress() + ':' + member.getPort() + ':' +
member.getDisplayName();
+ }
+
private String getLbActiveMonitorPath(String lbServerPoolName, String
port, String protocol) {
LbMonitorProfiles lbActiveMonitor = (LbMonitorProfiles)
nsxService.apply(LbMonitorProfiles.class);
String lbMonitorProfileId =
getActiveMonitorProfileName(lbServerPoolName, port, protocol);
- if ("TCP".equals(protocol.toUpperCase(Locale.ROOT))) {
- LBTcpMonitorProfile lbTcpMonitorProfile = new
LBTcpMonitorProfile.Builder(TCP_MONITOR_PROFILE)
- .setDisplayName(lbMonitorProfileId)
- .setMonitorPort(Long.parseLong(port))
- .build();
- lbActiveMonitor.patch(lbMonitorProfileId, lbTcpMonitorProfile);
- } else if ("UDP".equals(protocol.toUpperCase(Locale.ROOT))) {
- LBIcmpMonitorProfile icmpMonitorProfile = new
LBIcmpMonitorProfile.Builder(ICMP_MONITOR_PROFILE)
- .setDisplayName(lbMonitorProfileId)
- .build();
- lbActiveMonitor.patch(lbMonitorProfileId, icmpMonitorProfile);
+ Optional<Structure> monitorProfile =
getMonitorProfile(lbActiveMonitor, lbMonitorProfileId);
+ if (monitorProfile.isEmpty()) {
+ if ("TCP".equals(protocol.toUpperCase(Locale.ROOT))) {
+ LBTcpMonitorProfile lbTcpMonitorProfile = new
LBTcpMonitorProfile.Builder(TCP_MONITOR_PROFILE)
+ .setDisplayName(lbMonitorProfileId)
+ .setMonitorPort(Long.parseLong(port))
+ .build();
+ lbActiveMonitor.patch(lbMonitorProfileId, lbTcpMonitorProfile);
+ } else if ("UDP".equals(protocol.toUpperCase(Locale.ROOT))) {
+ LBIcmpMonitorProfile icmpMonitorProfile = new
LBIcmpMonitorProfile.Builder(ICMP_MONITOR_PROFILE)
+ .setDisplayName(lbMonitorProfileId)
+ .build();
+ lbActiveMonitor.patch(lbMonitorProfileId, icmpMonitorProfile);
+ }
+ monitorProfile = getMonitorProfile(lbActiveMonitor,
lbMonitorProfileId);
Review Comment:
extracted to `patchMonitoringProfile`. Thanks
--
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.
To unsubscribe, e-mail: [email protected]
For queries about this service, please contact Infrastructure at:
[email protected]