This is an automated email from the ASF dual-hosted git repository.

baiyangtx pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/amoro.git


The following commit(s) were added to refs/heads/master by this push:
     new 7c43e754b [AMORO-3348] Extract the implementation of OptimizerManager 
(#3437)
7c43e754b is described below

commit 7c43e754b3214626e58bab5d6e2e2113265fdff3
Author: mansonliwh <[email protected]>
AuthorDate: Wed Feb 19 14:28:26 2025 +0800

    [AMORO-3348] Extract the implementation of OptimizerManager (#3437)
    
    [AMORO-3346] Extract the implementation of OptimizerManager
    
    Co-authored-by: baiyangtx <[email protected]>
---
 .../apache/amoro/server/AmoroServiceContainer.java |  18 ++-
 .../amoro/server/DefaultOptimizingService.java     |  70 ++---------
 .../amoro/server/dashboard/DashboardServer.java    |   9 +-
 .../dashboard/controller/OptimizerController.java  |  11 +-
 .../controller/OptimizerGroupController.java       |  19 +--
 .../server/resource/DefaultOptimizerManager.java   | 128 +++++++++++++++++++++
 .../apache/amoro/server/AMSManagerTestBase.java    |   8 ++
 .../apache/amoro/server/AMSServiceTestBase.java    |   2 +-
 .../org/apache/amoro/server/AmsEnvironment.java    |   6 +-
 .../amoro/server/TestDefaultOptimizingService.java |   7 +-
 .../org/apache/amoro/resource/ResourceManager.java |   3 -
 11 files changed, 193 insertions(+), 88 deletions(-)

diff --git 
a/amoro-ams/src/main/java/org/apache/amoro/server/AmoroServiceContainer.java 
b/amoro-ams/src/main/java/org/apache/amoro/server/AmoroServiceContainer.java
index 15c532d5d..899b434fd 100644
--- a/amoro-ams/src/main/java/org/apache/amoro/server/AmoroServiceContainer.java
+++ b/amoro-ams/src/main/java/org/apache/amoro/server/AmoroServiceContainer.java
@@ -42,6 +42,7 @@ import org.apache.amoro.server.persistence.DataSourceFactory;
 import org.apache.amoro.server.persistence.HttpSessionHandlerFactory;
 import org.apache.amoro.server.persistence.SqlSessionFactoryProvider;
 import org.apache.amoro.server.resource.ContainerMetadata;
+import org.apache.amoro.server.resource.DefaultOptimizerManager;
 import org.apache.amoro.server.resource.OptimizerManager;
 import org.apache.amoro.server.resource.ResourceContainers;
 import org.apache.amoro.server.table.DefaultTableManager;
@@ -99,6 +100,7 @@ public class AmoroServiceContainer {
   private DataSource dataSource;
   private CatalogManager catalogManager;
   private TableManager tableManager;
+  private OptimizerManager optimizerManager;
   private TableService tableService;
   private DefaultOptimizingService optimizingService;
   private TerminalManager terminalManager;
@@ -155,10 +157,13 @@ public class AmoroServiceContainer {
 
     catalogManager = new DefaultCatalogManager(serviceConfig);
     tableManager = new DefaultTableManager(serviceConfig, catalogManager);
+    optimizerManager = new DefaultOptimizerManager(serviceConfig);
 
     tableService = new DefaultTableService(serviceConfig, catalogManager);
+
     optimizingService =
-        new DefaultOptimizingService(serviceConfig, catalogManager, 
tableManager, tableService);
+        new DefaultOptimizingService(
+            serviceConfig, catalogManager, tableManager, optimizerManager, 
tableService);
 
     LOG.info("Setting up AMS table executors...");
     AsyncTableExecutors.getInstance().setup(tableService, serviceConfig);
@@ -253,7 +258,12 @@ public class AmoroServiceContainer {
   private void initHttpService() {
     DashboardServer dashboardServer =
         new DashboardServer(
-            serviceConfig, catalogManager, tableManager, optimizingService, 
terminalManager);
+            serviceConfig,
+            catalogManager,
+            tableManager,
+            optimizerManager,
+            optimizingService,
+            terminalManager);
     RestCatalogService restCatalogService = new 
RestCatalogService(catalogManager, tableManager);
 
     httpServer =
@@ -558,7 +568,7 @@ public class AmoroServiceContainer {
   }
 
   @VisibleForTesting
-  public OptimizerManager getOptimizingService() {
-    return this.optimizingService;
+  public OptimizerManager getOptimizerManager() {
+    return this.optimizerManager;
   }
 }
diff --git 
a/amoro-ams/src/main/java/org/apache/amoro/server/DefaultOptimizingService.java 
b/amoro-ams/src/main/java/org/apache/amoro/server/DefaultOptimizingService.java
index a34e06421..9cfb1c21b 100644
--- 
a/amoro-ams/src/main/java/org/apache/amoro/server/DefaultOptimizingService.java
+++ 
b/amoro-ams/src/main/java/org/apache/amoro/server/DefaultOptimizingService.java
@@ -35,7 +35,6 @@ import org.apache.amoro.exception.ObjectNotExistsException;
 import org.apache.amoro.exception.PluginRetryAuthException;
 import org.apache.amoro.exception.TaskNotFoundException;
 import org.apache.amoro.properties.CatalogMetaProperties;
-import org.apache.amoro.resource.Resource;
 import org.apache.amoro.resource.ResourceGroup;
 import org.apache.amoro.server.catalog.CatalogManager;
 import org.apache.amoro.server.optimizing.OptimizingProcess;
@@ -56,7 +55,6 @@ import org.apache.amoro.server.table.RuntimeHandlerChain;
 import org.apache.amoro.server.table.TableRuntime;
 import org.apache.amoro.server.table.TableService;
 import org.apache.amoro.shade.guava32.com.google.common.base.Preconditions;
-import org.apache.amoro.shade.guava32.com.google.common.collect.ImmutableList;
 import 
org.apache.amoro.shade.guava32.com.google.common.util.concurrent.ThreadFactoryBuilder;
 import org.apache.amoro.shade.thrift.org.apache.thrift.TException;
 import org.apache.amoro.table.TableProperties;
@@ -90,7 +88,7 @@ import java.util.stream.Collectors;
  * suspending tasks.
  */
 public class DefaultOptimizingService extends StatedPersistentBase
-    implements OptimizingService.Iface, OptimizerManager, QuotaProvider {
+    implements OptimizingService.Iface, QuotaProvider {
 
   private static final Logger LOG = 
LoggerFactory.getLogger(DefaultOptimizingService.class);
 
@@ -103,6 +101,7 @@ public class DefaultOptimizingService extends 
StatedPersistentBase
   private final Map<String, OptimizerInstance> authOptimizers = new 
ConcurrentHashMap<>();
   private final OptimizerKeeper optimizerKeeper = new OptimizerKeeper();
   private final CatalogManager catalogManager;
+  private final OptimizerManager optimizerManager;
   private final TableService tableService;
   private final MaintainedTableManager tableManager;
   private final RuntimeHandlerChain tableHandlerChain;
@@ -112,6 +111,7 @@ public class DefaultOptimizingService extends 
StatedPersistentBase
       Configurations serviceConfig,
       CatalogManager catalogManager,
       MaintainedTableManager tableManager,
+      OptimizerManager optimizerManager,
       TableService tableService) {
     this.optimizerTouchTimeout =
         serviceConfig.get(AmoroManagementConf.OPTIMIZER_HB_TIMEOUT).toMillis();
@@ -124,6 +124,7 @@ public class DefaultOptimizingService extends 
StatedPersistentBase
     this.tableService = tableService;
     this.catalogManager = catalogManager;
     this.tableManager = tableManager;
+    this.optimizerManager = optimizerManager;
     this.tableHandlerChain = new TableRuntimeHandlerImpl();
     this.planExecutor =
         Executors.newCachedThreadPool(
@@ -317,19 +318,7 @@ public class DefaultOptimizingService extends 
StatedPersistentBase
         .orElseThrow(() -> new PluginRetryAuthException("Optimizer has not 
been authenticated"));
   }
 
-  @Override
-  public List<OptimizerInstance> listOptimizers() {
-    return ImmutableList.copyOf(authOptimizers.values());
-  }
-
-  @Override
-  public List<OptimizerInstance> listOptimizers(String group) {
-    return authOptimizers.values().stream()
-        .filter(optimizer -> optimizer.getGroupName().equals(group))
-        .collect(Collectors.toList());
-  }
-
-  @Override
+  // TODO need to use optimizer manager
   public void deleteOptimizer(String group, String resourceId) {
     List<OptimizerInstance> deleteOptimizers =
         getAs(OptimizerMapper.class, mapper -> 
mapper.selectByResourceId(resourceId));
@@ -340,11 +329,10 @@ public class DefaultOptimizingService extends 
StatedPersistentBase
         });
   }
 
-  @Override
   public void createResourceGroup(ResourceGroup resourceGroup) {
     doAsTransaction(
         () -> {
-          doAs(ResourceMapper.class, mapper -> 
mapper.insertResourceGroup(resourceGroup));
+          optimizerManager.createResourceGroup(resourceGroup);
           OptimizingQueue optimizingQueue =
               new OptimizingQueue(
                   catalogManager,
@@ -357,10 +345,9 @@ public class DefaultOptimizingService extends 
StatedPersistentBase
         });
   }
 
-  @Override
   public void deleteResourceGroup(String groupName) {
     if (canDeleteResourceGroup(groupName)) {
-      doAs(ResourceMapper.class, mapper -> 
mapper.deleteResourceGroup(groupName));
+      optimizerManager.deleteResourceGroup(groupName);
       OptimizingQueue optimizingQueue = 
optimizingQueueByGroup.remove(groupName);
       optimizingQueue.dispose();
     } else {
@@ -371,52 +358,13 @@ public class DefaultOptimizingService extends 
StatedPersistentBase
     }
   }
 
-  @Override
   public void updateResourceGroup(ResourceGroup resourceGroup) {
     Preconditions.checkNotNull(resourceGroup, "The resource group cannot be 
null.");
     Optional.ofNullable(optimizingQueueByGroup.get(resourceGroup.getName()))
         .ifPresent(queue -> queue.updateOptimizerGroup(resourceGroup));
-    doAs(ResourceMapper.class, mapper -> 
mapper.updateResourceGroup(resourceGroup));
-  }
-
-  @Override
-  public void createResource(Resource resource) {
-    doAs(ResourceMapper.class, mapper -> mapper.insertResource(resource));
-  }
-
-  @Override
-  public void deleteResource(String resourceId) {
-    doAs(ResourceMapper.class, mapper -> mapper.deleteResource(resourceId));
+    optimizerManager.updateResourceGroup(resourceGroup);
   }
 
-  @Override
-  public List<ResourceGroup> listResourceGroups() {
-    return getAs(ResourceMapper.class, ResourceMapper::selectResourceGroups);
-  }
-
-  @Override
-  public List<ResourceGroup> listResourceGroups(String containerName) {
-    return getAs(ResourceMapper.class, 
ResourceMapper::selectResourceGroups).stream()
-        .filter(group -> group.getContainer().equals(containerName))
-        .collect(Collectors.toList());
-  }
-
-  @Override
-  public ResourceGroup getResourceGroup(String groupName) {
-    return getAs(ResourceMapper.class, mapper -> 
mapper.selectResourceGroup(groupName));
-  }
-
-  @Override
-  public List<Resource> listResourcesByGroup(String groupName) {
-    return getAs(ResourceMapper.class, mapper -> 
mapper.selectResourcesByGroup(groupName));
-  }
-
-  @Override
-  public Resource getResource(String resourceId) {
-    return getAs(ResourceMapper.class, mapper -> 
mapper.selectResource(resourceId));
-  }
-
-  @Override
   public void dispose() {
     optimizerKeeper.dispose();
     tableHandlerChain.dispose();
@@ -439,7 +387,7 @@ public class DefaultOptimizingService extends 
StatedPersistentBase
         return false;
       }
     }
-    for (OptimizerInstance optimizer : listOptimizers()) {
+    for (OptimizerInstance optimizer : optimizerManager.listOptimizers()) {
       if (optimizer.getGroupName().equals(name)) {
         return false;
       }
diff --git 
a/amoro-ams/src/main/java/org/apache/amoro/server/dashboard/DashboardServer.java
 
b/amoro-ams/src/main/java/org/apache/amoro/server/dashboard/DashboardServer.java
index acb13e55f..6614f2038 100644
--- 
a/amoro-ams/src/main/java/org/apache/amoro/server/dashboard/DashboardServer.java
+++ 
b/amoro-ams/src/main/java/org/apache/amoro/server/dashboard/DashboardServer.java
@@ -51,6 +51,7 @@ import 
org.apache.amoro.server.dashboard.controller.TerminalController;
 import org.apache.amoro.server.dashboard.controller.VersionController;
 import org.apache.amoro.server.dashboard.response.ErrorResponse;
 import org.apache.amoro.server.dashboard.utils.ParamSignatureCalculator;
+import org.apache.amoro.server.resource.OptimizerManager;
 import org.apache.amoro.server.table.TableManager;
 import org.apache.amoro.server.terminal.TerminalManager;
 import org.apache.amoro.shade.guava32.com.google.common.base.Preconditions;
@@ -99,15 +100,17 @@ public class DashboardServer {
       Configurations serviceConfig,
       CatalogManager catalogManager,
       TableManager tableManager,
-      DefaultOptimizingService optimizerManager,
+      OptimizerManager optimizerManager,
+      DefaultOptimizingService optimizingService,
       TerminalManager terminalManager) {
     PlatformFileManager platformFileManager = new PlatformFileManager();
     this.catalogController = new CatalogController(catalogManager, 
platformFileManager);
     this.healthCheckController = new HealthCheckController();
     this.loginController = new LoginController(serviceConfig);
     // TODO: remove table service from OptimizerGroupController
-    this.optimizerGroupController = new OptimizerGroupController(tableManager, 
optimizerManager);
-    this.optimizerController = new OptimizerController(optimizerManager);
+    this.optimizerGroupController =
+        new OptimizerGroupController(tableManager, optimizingService, 
optimizerManager);
+    this.optimizerController = new OptimizerController(optimizingService, 
optimizerManager);
     this.platformFileInfoController = new 
PlatformFileInfoController(platformFileManager);
     this.settingController = new SettingController(serviceConfig, 
optimizerManager);
     ServerTableDescriptor tableDescriptor =
diff --git 
a/amoro-ams/src/main/java/org/apache/amoro/server/dashboard/controller/OptimizerController.java
 
b/amoro-ams/src/main/java/org/apache/amoro/server/dashboard/controller/OptimizerController.java
index 9e34df3ab..55259c5a0 100644
--- 
a/amoro-ams/src/main/java/org/apache/amoro/server/dashboard/controller/OptimizerController.java
+++ 
b/amoro-ams/src/main/java/org/apache/amoro/server/dashboard/controller/OptimizerController.java
@@ -26,6 +26,7 @@ import org.apache.amoro.server.DefaultOptimizingService;
 import org.apache.amoro.server.dashboard.response.OkResponse;
 import org.apache.amoro.server.resource.ContainerMetadata;
 import org.apache.amoro.server.resource.OptimizerInstance;
+import org.apache.amoro.server.resource.OptimizerManager;
 import org.apache.amoro.server.resource.ResourceContainers;
 import org.apache.amoro.shade.guava32.com.google.common.base.Preconditions;
 
@@ -36,9 +37,13 @@ import java.util.stream.Collectors;
 /** The controller that handles optimizer requests. */
 public class OptimizerController {
 
-  private final DefaultOptimizingService optimizerManager;
+  private final OptimizerManager optimizerManager;
 
-  public OptimizerController(DefaultOptimizingService optimizerManager) {
+  private final DefaultOptimizingService optimizingService;
+
+  public OptimizerController(
+      DefaultOptimizingService optimizingService, OptimizerManager 
optimizerManager) {
+    this.optimizingService = optimizingService;
     this.optimizerManager = optimizerManager;
   }
 
@@ -64,7 +69,7 @@ public class OptimizerController {
     resource.getProperties().putAll(optimizerInstances.get(0).getProperties());
     
ResourceContainers.get(resource.getContainerName()).releaseOptimizer(resource);
     optimizerManager.deleteResource(resourceId);
-    optimizerManager.deleteOptimizer(resource.getGroupName(), resourceId);
+    optimizingService.deleteOptimizer(resource.getGroupName(), resourceId);
     ctx.json(OkResponse.of("Success to release optimizer"));
   }
 
diff --git 
a/amoro-ams/src/main/java/org/apache/amoro/server/dashboard/controller/OptimizerGroupController.java
 
b/amoro-ams/src/main/java/org/apache/amoro/server/dashboard/controller/OptimizerGroupController.java
index e8b3a6d5a..bfe36d069 100644
--- 
a/amoro-ams/src/main/java/org/apache/amoro/server/dashboard/controller/OptimizerGroupController.java
+++ 
b/amoro-ams/src/main/java/org/apache/amoro/server/dashboard/controller/OptimizerGroupController.java
@@ -31,6 +31,7 @@ import org.apache.amoro.server.dashboard.response.PageResult;
 import org.apache.amoro.server.optimizing.OptimizingStatus;
 import org.apache.amoro.server.resource.ContainerMetadata;
 import org.apache.amoro.server.resource.OptimizerInstance;
+import org.apache.amoro.server.resource.OptimizerManager;
 import org.apache.amoro.server.resource.ResourceContainers;
 import org.apache.amoro.server.table.TableManager;
 import org.apache.amoro.shade.guava32.com.google.common.base.Preconditions;
@@ -56,11 +57,15 @@ public class OptimizerGroupController {
 
   private static final String ALL_GROUP = "all";
   private final TableManager tableManager;
-  private final DefaultOptimizingService optimizerManager;
+  private final DefaultOptimizingService optimizingService;
+  private final OptimizerManager optimizerManager;
 
   public OptimizerGroupController(
-      TableManager tableManager, DefaultOptimizingService optimizerManager) {
+      TableManager tableManager,
+      DefaultOptimizingService optimizingService,
+      OptimizerManager optimizerManager) {
     this.tableManager = tableManager;
+    this.optimizingService = optimizingService;
     this.optimizerManager = optimizerManager;
   }
 
@@ -205,7 +210,7 @@ public class OptimizerGroupController {
     resource.getProperties().putAll(optimizerInstances.get(0).getProperties());
     
ResourceContainers.get(resource.getContainerName()).releaseOptimizer(resource);
     optimizerManager.deleteResource(resourceId);
-    optimizerManager.deleteOptimizer(resource.getGroupName(), resourceId);
+    optimizingService.deleteOptimizer(resource.getGroupName(), resourceId);
     ctx.json(OkResponse.of("Success to release optimizer"));
   }
 
@@ -263,7 +268,7 @@ public class OptimizerGroupController {
     }
     ResourceGroup.Builder builder = new ResourceGroup.Builder(name, container);
     builder.addProperties(properties);
-    optimizerManager.createResourceGroup(builder.build());
+    optimizingService.createResourceGroup(builder.build());
     ctx.json(OkResponse.of("The optimizer group has been successfully 
created."));
   }
 
@@ -278,21 +283,21 @@ public class OptimizerGroupController {
     Map<String, String> properties = (Map) map.get("properties");
     ResourceGroup.Builder builder = new ResourceGroup.Builder(name, container);
     builder.addProperties(properties);
-    optimizerManager.updateResourceGroup(builder.build());
+    optimizingService.updateResourceGroup(builder.build());
     ctx.json(OkResponse.of("The optimizer group has been successfully 
updated."));
   }
 
   /** delete optimizeGroup url = /optimize/resourceGroups/{resourceGroupName} 
*/
   public void deleteResourceGroup(Context ctx) {
     String name = ctx.pathParam("resourceGroupName");
-    optimizerManager.deleteResourceGroup(name);
+    optimizingService.deleteResourceGroup(name);
     ctx.json(OkResponse.of("The optimizer group has been successfully 
deleted."));
   }
 
   /** check if optimizerGroup can be deleted url = 
/optimize/resourceGroups/delete/check */
   public void deleteCheckResourceGroup(Context ctx) {
     String name = ctx.pathParam("resourceGroupName");
-    ctx.json(OkResponse.of(optimizerManager.canDeleteResourceGroup(name)));
+    ctx.json(OkResponse.of(optimizingService.canDeleteResourceGroup(name)));
   }
 
   /** check if optimizerGroup can be deleted url = /optimize/containers/get */
diff --git 
a/amoro-ams/src/main/java/org/apache/amoro/server/resource/DefaultOptimizerManager.java
 
b/amoro-ams/src/main/java/org/apache/amoro/server/resource/DefaultOptimizerManager.java
new file mode 100644
index 000000000..4a3d89cbc
--- /dev/null
+++ 
b/amoro-ams/src/main/java/org/apache/amoro/server/resource/DefaultOptimizerManager.java
@@ -0,0 +1,128 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements.  See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership.  The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License.  You may obtain a copy of the License at
+ *
+ *     http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.apache.amoro.server.resource;
+
+import org.apache.amoro.config.Configurations;
+import org.apache.amoro.resource.Resource;
+import org.apache.amoro.resource.ResourceGroup;
+import org.apache.amoro.server.persistence.PersistentBase;
+import org.apache.amoro.server.persistence.mapper.OptimizerMapper;
+import org.apache.amoro.server.persistence.mapper.ResourceMapper;
+
+import java.util.List;
+import java.util.stream.Collectors;
+
+/**
+ * DefaultOptimizingService is implementing the OptimizerManager Thrift 
service, which manages the
+ * optimizing tasks for tables. It includes methods for authenticating 
optimizers, polling tasks
+ * from the optimizing queue, acknowledging tasks,and completing tasks. The 
code uses several data
+ * structures, including maps for optimizing queues ,task runtimes, and 
authenticated optimizers.
+ *
+ * <p>The code also includes a TimerTask for detecting and removing expired 
optimizers and
+ * suspending tasks.
+ */
+public class DefaultOptimizerManager extends PersistentBase implements 
OptimizerManager {
+
+  protected final Configurations serverConfiguration;
+
+  public DefaultOptimizerManager(Configurations serverConfiguration) {
+    this.serverConfiguration = serverConfiguration;
+  }
+
+  private void unregisterOptimizer(String token) {
+    doAs(OptimizerMapper.class, mapper -> mapper.deleteOptimizer(token));
+  }
+
+  @Override
+  public List<OptimizerInstance> listOptimizers() {
+    return getAs(OptimizerMapper.class, OptimizerMapper::selectAll);
+  }
+
+  @Override
+  public List<OptimizerInstance> listOptimizers(String group) {
+    List<OptimizerInstance> authOptimizers =
+        getAs(OptimizerMapper.class, OptimizerMapper::selectAll);
+    return authOptimizers.stream()
+        .filter(optimizer -> optimizer.getGroupName().equals(group))
+        .collect(Collectors.toList());
+  }
+
+  @Override
+  public void deleteOptimizer(String group, String resourceId) {
+    List<OptimizerInstance> deleteOptimizers =
+        getAs(OptimizerMapper.class, mapper -> 
mapper.selectByResourceId(resourceId));
+    deleteOptimizers.forEach(
+        optimizer -> {
+          String token = optimizer.getToken();
+          unregisterOptimizer(token);
+        });
+  }
+
+  @Override
+  public void createResourceGroup(ResourceGroup resourceGroup) {
+    doAs(ResourceMapper.class, mapper -> 
mapper.insertResourceGroup(resourceGroup));
+  }
+
+  @Override
+  public void deleteResourceGroup(String groupName) {
+    doAs(ResourceMapper.class, mapper -> 
mapper.deleteResourceGroup(groupName));
+  }
+
+  @Override
+  public void updateResourceGroup(ResourceGroup resourceGroup) {
+    doAs(ResourceMapper.class, mapper -> 
mapper.updateResourceGroup(resourceGroup));
+  }
+
+  @Override
+  public void createResource(Resource resource) {
+    doAs(ResourceMapper.class, mapper -> mapper.insertResource(resource));
+  }
+
+  @Override
+  public void deleteResource(String resourceId) {
+    doAs(ResourceMapper.class, mapper -> mapper.deleteResource(resourceId));
+  }
+
+  @Override
+  public List<ResourceGroup> listResourceGroups() {
+    return getAs(ResourceMapper.class, ResourceMapper::selectResourceGroups);
+  }
+
+  @Override
+  public List<ResourceGroup> listResourceGroups(String containerName) {
+    return getAs(ResourceMapper.class, 
ResourceMapper::selectResourceGroups).stream()
+        .filter(group -> group.getContainer().equals(containerName))
+        .collect(Collectors.toList());
+  }
+
+  @Override
+  public ResourceGroup getResourceGroup(String groupName) {
+    return getAs(ResourceMapper.class, mapper -> 
mapper.selectResourceGroup(groupName));
+  }
+
+  @Override
+  public List<Resource> listResourcesByGroup(String groupName) {
+    return getAs(ResourceMapper.class, mapper -> 
mapper.selectResourcesByGroup(groupName));
+  }
+
+  @Override
+  public Resource getResource(String resourceId) {
+    return getAs(ResourceMapper.class, mapper -> 
mapper.selectResource(resourceId));
+  }
+}
diff --git 
a/amoro-ams/src/test/java/org/apache/amoro/server/AMSManagerTestBase.java 
b/amoro-ams/src/test/java/org/apache/amoro/server/AMSManagerTestBase.java
index da95059bc..e89567c9c 100644
--- a/amoro-ams/src/test/java/org/apache/amoro/server/AMSManagerTestBase.java
+++ b/amoro-ams/src/test/java/org/apache/amoro/server/AMSManagerTestBase.java
@@ -23,6 +23,8 @@ import org.apache.amoro.resource.ResourceGroup;
 import org.apache.amoro.server.catalog.DefaultCatalogManager;
 import org.apache.amoro.server.manager.EventsManager;
 import org.apache.amoro.server.manager.MetricManager;
+import org.apache.amoro.server.resource.DefaultOptimizerManager;
+import org.apache.amoro.server.resource.OptimizerManager;
 import org.apache.amoro.server.table.DefaultTableManager;
 import org.apache.amoro.server.table.DerbyPersistence;
 import org.apache.amoro.server.table.TableManager;
@@ -37,6 +39,7 @@ public abstract class AMSManagerTestBase {
 
   protected static DefaultCatalogManager CATALOG_MANAGER = null;
   protected static DefaultTableManager TABLE_MANAGER = null;
+  protected static DefaultOptimizerManager OPTIMIZER_MANAGER = null;
 
   @BeforeClass
   public static void initTableManger() {
@@ -44,6 +47,7 @@ public abstract class AMSManagerTestBase {
       Configurations configurations = new Configurations();
       CATALOG_MANAGER = new DefaultCatalogManager(configurations);
       TABLE_MANAGER = new DefaultTableManager(configurations, CATALOG_MANAGER);
+      OPTIMIZER_MANAGER = new DefaultOptimizerManager(configurations);
     } catch (Throwable throwable) {
       Assert.fail(throwable.getMessage());
     }
@@ -59,6 +63,10 @@ public abstract class AMSManagerTestBase {
     return TABLE_MANAGER;
   }
 
+  protected OptimizerManager optimizerManager() {
+    return OPTIMIZER_MANAGER;
+  }
+
   protected static ResourceGroup defaultResourceGroup() {
     return new ResourceGroup.Builder("default", "local").build();
   }
diff --git 
a/amoro-ams/src/test/java/org/apache/amoro/server/AMSServiceTestBase.java 
b/amoro-ams/src/test/java/org/apache/amoro/server/AMSServiceTestBase.java
index b1f29861d..ae3ad604e 100644
--- a/amoro-ams/src/test/java/org/apache/amoro/server/AMSServiceTestBase.java
+++ b/amoro-ams/src/test/java/org/apache/amoro/server/AMSServiceTestBase.java
@@ -41,7 +41,7 @@ public abstract class AMSServiceTestBase extends 
AMSManagerTestBase {
       TABLE_SERVICE = new DefaultTableService(new Configurations(), 
CATALOG_MANAGER);
       OPTIMIZING_SERVICE =
           new DefaultOptimizingService(
-              configurations, CATALOG_MANAGER, TABLE_MANAGER, TABLE_SERVICE);
+              configurations, CATALOG_MANAGER, TABLE_MANAGER, 
OPTIMIZER_MANAGER, TABLE_SERVICE);
       
TABLE_SERVICE.addHandlerChain(OPTIMIZING_SERVICE.getTableRuntimeHandler());
       TABLE_SERVICE.initialize();
       try {
diff --git 
a/amoro-ams/src/test/java/org/apache/amoro/server/AmsEnvironment.java 
b/amoro-ams/src/test/java/org/apache/amoro/server/AmsEnvironment.java
index 38d95adb0..1e37a071c 100644
--- a/amoro-ams/src/test/java/org/apache/amoro/server/AmsEnvironment.java
+++ b/amoro-ams/src/test/java/org/apache/amoro/server/AmsEnvironment.java
@@ -283,7 +283,7 @@ public class AmsEnvironment {
     if (optimizingStarted) {
       return;
     }
-    OptimizerManager optimizerManager = 
serviceContainer.getOptimizingService();
+    OptimizerManager optimizerManager = serviceContainer.getOptimizerManager();
     optimizerManager.createResourceGroup(
         new ResourceGroup.Builder("default", "localContainer")
             .addProperty("memory", "1024")
@@ -302,8 +302,8 @@ public class AmsEnvironment {
   }
 
   public void stopOptimizer() {
-    DynFields.UnboundField<DefaultOptimizingService> field =
-        DynFields.builder().hiddenImpl(AmoroServiceContainer.class, 
"optimizingService").build();
+    DynFields.UnboundField<OptimizerManager> field =
+        DynFields.builder().hiddenImpl(AmoroServiceContainer.class, 
"optimizerManager").build();
     field
         .bind(serviceContainer)
         .get()
diff --git 
a/amoro-ams/src/test/java/org/apache/amoro/server/TestDefaultOptimizingService.java
 
b/amoro-ams/src/test/java/org/apache/amoro/server/TestDefaultOptimizingService.java
index a97738ae8..55fac3a49 100644
--- 
a/amoro-ams/src/test/java/org/apache/amoro/server/TestDefaultOptimizingService.java
+++ 
b/amoro-ams/src/test/java/org/apache/amoro/server/TestDefaultOptimizingService.java
@@ -110,7 +110,7 @@ public class TestDefaultOptimizingService extends 
AMSTableTestBase {
         toucher.stop();
         toucher = null;
       }
-      optimizingService()
+      optimizerManager()
           .listOptimizers()
           .forEach(
               optimizer ->
@@ -228,11 +228,12 @@ public class TestDefaultOptimizingService extends 
AMSTableTestBase {
 
   @Test
   public void testTouch() throws InterruptedException {
-    OptimizerInstance optimizer = optimizingService().listOptimizers().get(0);
+    OptimizerInstance optimizer = optimizerManager().listOptimizers().get(0);
     long oldTouchTime = optimizer.getTouchTime();
     Thread.sleep(1);
     optimizingService().touch(token);
-    Assertions.assertTrue(optimizer.getTouchTime() > oldTouchTime);
+    OptimizerInstance optimizerAfterTouched = 
optimizerManager().listOptimizers().get(0);
+    Assertions.assertTrue(optimizerAfterTouched.getTouchTime() > oldTouchTime);
   }
 
   @Test
diff --git 
a/amoro-common/src/main/java/org/apache/amoro/resource/ResourceManager.java 
b/amoro-common/src/main/java/org/apache/amoro/resource/ResourceManager.java
index c03ffc98b..03bf0fae8 100644
--- a/amoro-common/src/main/java/org/apache/amoro/resource/ResourceManager.java
+++ b/amoro-common/src/main/java/org/apache/amoro/resource/ResourceManager.java
@@ -41,7 +41,4 @@ public interface ResourceManager {
   List<Resource> listResourcesByGroup(String groupName);
 
   Resource getResource(String resourceId);
-
-  /** close this resource manager */
-  void dispose();
 }

Reply via email to