diff --git a/api/src/main/java/com/alibaba/nacos/api/common/Constants.java b/api/src/main/java/com/alibaba/nacos/api/common/Constants.java index ac9e434e3..60572850b 100644 --- a/api/src/main/java/com/alibaba/nacos/api/common/Constants.java +++ b/api/src/main/java/com/alibaba/nacos/api/common/Constants.java @@ -162,5 +162,7 @@ public class Constants { public static final String NULL_STRING = "null"; public static final String NUMBER_PATTERN = "^\\d+$"; + + public static final String ANY_PATTERN = ".*"; } diff --git a/console/src/main/resources/static/console-fe/src/locales/en-US.js b/console/src/main/resources/static/console-fe/src/locales/en-US.js index 111db3f97..f1315f082 100644 --- a/console/src/main/resources/static/console-fe/src/locales/en-US.js +++ b/console/src/main/resources/static/console-fe/src/locales/en-US.js @@ -97,6 +97,7 @@ const I18N_CONF = { pubNoData: 'No results found.', columnServiceName: 'Service Name', groupName: 'Group Name', + groupNamePlaceholder: 'Enter Group Name', columnClusterCount: 'Cluster Count', columnIpCount: 'Instance Count', columnHealthyInstanceCount: 'Healthy Instance Count', diff --git a/console/src/main/resources/static/console-fe/src/locales/zh-CN.js b/console/src/main/resources/static/console-fe/src/locales/zh-CN.js index e46795482..9218da10a 100644 --- a/console/src/main/resources/static/console-fe/src/locales/zh-CN.js +++ b/console/src/main/resources/static/console-fe/src/locales/zh-CN.js @@ -96,7 +96,8 @@ const I18N_CONF = { query: '查询', pubNoData: '没有数据', columnServiceName: '服务名', - groupName: '分组', + groupName: '分组名称', + groupNamePlaceholder: '请输入分组名称', columnClusterCount: '集群数目', columnIpCount: '实例数', columnHealthyInstanceCount: '健康实例数', diff --git a/console/src/main/resources/static/console-fe/src/pages/ServiceManagement/ServiceList/ServiceList.js b/console/src/main/resources/static/console-fe/src/pages/ServiceManagement/ServiceList/ServiceList.js index bd38442e0..642130fda 100644 --- a/console/src/main/resources/static/console-fe/src/pages/ServiceManagement/ServiceList/ServiceList.js +++ b/console/src/main/resources/static/console-fe/src/pages/ServiceManagement/ServiceList/ServiceList.js @@ -56,8 +56,11 @@ class ServiceList extends React.Component { total: 0, pageSize: 10, currentPage: 1, - keyword: '', dataSource: [], + search: { + serviceName: '', + groupName: '', + }, hasIpCount: !(localStorage.getItem('hasIpCount') === 'false'), }; this.field = new Field(this); @@ -78,13 +81,14 @@ class ServiceList extends React.Component { } queryServiceList() { - const { currentPage, pageSize, keyword, withInstances = false, hasIpCount } = this.state; + const { currentPage, pageSize, search, withInstances = false, hasIpCount } = this.state; const parameter = [ `hasIpCount=${hasIpCount}`, `withInstances=${withInstances}`, `pageNo=${currentPage}`, `pageSize=${pageSize}`, - `keyword=${keyword}`, + `serviceNameParam=${search.serviceName}`, + `groupNameParam=${search.groupName}`, ]; request({ url: `v1/ns/catalog/services?${parameter.join('&')}`, @@ -164,6 +168,8 @@ class ServiceList extends React.Component { serviceList, serviceName, serviceNamePlaceholder, + groupName, + groupNamePlaceholder, hiddenEmptyService, query, create, @@ -172,7 +178,7 @@ class ServiceList extends React.Component { sampleCode, deleteAction, } = locale; - const { keyword, nowNamespaceName, nowNamespaceId, hasIpCount } = this.state; + const { search, nowNamespaceName, nowNamespaceId, hasIpCount } = this.state; const { init, getValue } = this.field; this.init = init; this.getValue = getValue; @@ -214,8 +220,19 @@ class ServiceList extends React.Component { this.setState({ keyword })} + value={search.serviceName} + onChange={serviceName => this.setState({ search: { ...search, serviceName } })} + onPressEnter={() => + this.setState({ currentPage: 1 }, () => this.queryServiceList()) + } + /> + + + this.setState({ search: { ...search, groupName } })} onPressEnter={() => this.setState({ currentPage: 1 }, () => this.queryServiceList()) } diff --git a/naming/src/main/java/com/alibaba/nacos/naming/controllers/CatalogController.java b/naming/src/main/java/com/alibaba/nacos/naming/controllers/CatalogController.java index 4ebe8a835..6d47e67e5 100644 --- a/naming/src/main/java/com/alibaba/nacos/naming/controllers/CatalogController.java +++ b/naming/src/main/java/com/alibaba/nacos/naming/controllers/CatalogController.java @@ -150,10 +150,13 @@ public class CatalogController { List serviceDetailInfoList = new ArrayList<>(); int pageNo = Integer.parseInt(WebUtils.required(request, "pageNo")); int pageSize = Integer.parseInt(WebUtils.required(request, "pageSize")); - String keyword = WebUtils.optional(request, "keyword", StringUtils.EMPTY); + String serviceName = WebUtils.optional(request, "serviceNameParam", StringUtils.EMPTY); + String groupName = WebUtils.optional(request, "groupNameParam", StringUtils.EMPTY); + String param = StringUtils.isBlank(serviceName) && StringUtils.isBlank(groupName) ? + StringUtils.EMPTY : NamingUtils.getGroupedName(serviceName, groupName); List serviceList = new ArrayList<>(8); - serviceManager.getPagedService(namespaceId, pageNo, pageSize, keyword, StringUtils.EMPTY, serviceList, false); + serviceManager.getPagedService(namespaceId, pageNo, pageSize, param, StringUtils.EMPTY, serviceList, false); for (Service service : serviceList) { ServiceDetailInfo serviceDetailInfo = new ServiceDetailInfo(); @@ -257,12 +260,16 @@ public class CatalogController { int page = Integer.parseInt(WebUtils.required(request, "pageNo")); int pageSize = Integer.parseInt(WebUtils.required(request, "pageSize")); - String keyword = WebUtils.optional(request, "keyword", StringUtils.EMPTY); + String serviceName = WebUtils.optional(request, "serviceNameParam", StringUtils.EMPTY); + String groupName = WebUtils.optional(request, "groupNameParam", StringUtils.EMPTY); + String param = StringUtils.isBlank(serviceName) && StringUtils.isBlank(groupName) ? + StringUtils.EMPTY : NamingUtils.getGroupedName(serviceName, groupName); + String containedInstance = WebUtils.optional(request, "instance", StringUtils.EMPTY); boolean hasIpCount = Boolean.parseBoolean(WebUtils.optional(request, "hasIpCount", "false")); List services = new ArrayList<>(); - int total = serviceManager.getPagedService(namespaceId, page - 1, pageSize, keyword, containedInstance, services, hasIpCount); + int total = serviceManager.getPagedService(namespaceId, page - 1, pageSize, param, containedInstance, services, hasIpCount); if (CollectionUtils.isEmpty(services)) { result.put("serviceList", Collections.emptyList()); diff --git a/naming/src/main/java/com/alibaba/nacos/naming/controllers/ServiceController.java b/naming/src/main/java/com/alibaba/nacos/naming/controllers/ServiceController.java index b5dc8bad7..28870a624 100644 --- a/naming/src/main/java/com/alibaba/nacos/naming/controllers/ServiceController.java +++ b/naming/src/main/java/com/alibaba/nacos/naming/controllers/ServiceController.java @@ -269,10 +269,10 @@ public class ServiceController { Map> services = new HashMap<>(16); if (StringUtils.isNotBlank(namespaceId)) { - services.put(namespaceId, serviceManager.searchServices(namespaceId, ".*" + expr + ".*")); + services.put(namespaceId, serviceManager.searchServices(namespaceId, Constants.ANY_PATTERN + expr + Constants.ANY_PATTERN)); } else { for (String namespace : serviceManager.getAllNamespaces()) { - services.put(namespace, serviceManager.searchServices(namespace, ".*" + expr + ".*")); + services.put(namespace, serviceManager.searchServices(namespace, Constants.ANY_PATTERN + expr + Constants.ANY_PATTERN)); } } diff --git a/naming/src/main/java/com/alibaba/nacos/naming/core/ServiceManager.java b/naming/src/main/java/com/alibaba/nacos/naming/core/ServiceManager.java index 8029b6785..fc0ca3334 100644 --- a/naming/src/main/java/com/alibaba/nacos/naming/core/ServiceManager.java +++ b/naming/src/main/java/com/alibaba/nacos/naming/core/ServiceManager.java @@ -674,7 +674,7 @@ public class ServiceManager implements RecordListener { return serviceMap.get(namespaceId); } - public int getPagedService(String namespaceId, int startPage, int pageSize, String keyword, String containedInstance, List serviceList, boolean hasIpCount) { + public int getPagedService(String namespaceId, int startPage, int pageSize, String param, String containedInstance, List serviceList, boolean hasIpCount) { List matchList; @@ -682,8 +682,12 @@ public class ServiceManager implements RecordListener { return 0; } - if (StringUtils.isNotBlank(keyword)) { - matchList = searchServices(namespaceId, ".*" + keyword + ".*"); + if (StringUtils.isNotBlank(param)) { + StringJoiner regex = new StringJoiner(Constants.SERVICE_INFO_SPLITER); + for (String s : param.split(Constants.SERVICE_INFO_SPLITER)) { + regex.add(StringUtils.isBlank(s) ? Constants.ANY_PATTERN : Constants.ANY_PATTERN + s + Constants.ANY_PATTERN); + } + matchList = searchServices(namespaceId, regex.toString()); } else { matchList = new ArrayList<>(chooseServiceMap(namespaceId).values()); }