客户端限流 service.

This commit is contained in:
许晓东
2023-01-03 22:01:43 +08:00
parent 7d76632f08
commit 4dbadee0d4
5 changed files with 92 additions and 10 deletions

View File

@@ -0,0 +1,10 @@
package com.xuxd.kafka.console.service;
import com.xuxd.kafka.console.beans.vo.ClientQuotaEntityVO;
import java.util.List;
public interface ClientQuotaService {
List<ClientQuotaEntityVO> getClientQuotaConfigs(String type, String name);
}

View File

@@ -0,0 +1,43 @@
package com.xuxd.kafka.console.service.impl;
import com.xuxd.kafka.console.beans.vo.ClientQuotaEntityVO;
import com.xuxd.kafka.console.service.ClientQuotaService;
import kafka.console.ClientQuotaConsole;
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.lang3.StringUtils;
import org.apache.kafka.common.quota.ClientQuotaEntity;
import org.springframework.stereotype.Service;
import java.util.*;
import java.util.stream.Collectors;
@Slf4j
@Service
public class ClientQuotaServiceImpl implements ClientQuotaService {
private final ClientQuotaConsole clientQuotaConsole;
private final Map<String, String> typeDict = new HashMap<>();
{
typeDict.put("user", ClientQuotaEntity.USER);
typeDict.put("client-id", ClientQuotaEntity.CLIENT_ID);
typeDict.put("ip", ClientQuotaEntity.IP);
}
public ClientQuotaServiceImpl(ClientQuotaConsole clientQuotaConsole) {
this.clientQuotaConsole = clientQuotaConsole;
}
@Override
public List<ClientQuotaEntityVO> getClientQuotaConfigs(String type, String name) {
List<String> entityNames = StringUtils.isNotBlank(name) ? Arrays.asList(name) : Collections.emptyList();
String entityType = typeDict.get(type);
if (StringUtils.isEmpty(entityType)) {
throw new IllegalArgumentException("type不正确" + type);
}
Map<ClientQuotaEntity, Map<String, Object>> clientQuotasConfigs = clientQuotaConsole.getClientQuotasConfigs(Arrays.asList(entityType), entityNames);
return clientQuotasConfigs.entrySet().stream().map(entry -> ClientQuotaEntityVO.from(entry.getKey(), entityType, entry.getValue())).collect(Collectors.toList());
}
}