refactor: code refactor

This commit is contained in:
chuntaojun 2020-10-14 19:32:22 +08:00
parent ff9f31811e
commit b4e9950b17
3 changed files with 23 additions and 12 deletions

View File

@ -16,6 +16,8 @@
package com.alibaba.nacos.naming.consistency.persistent.impl; package com.alibaba.nacos.naming.consistency.persistent.impl;
import com.alibaba.nacos.api.exception.NacosException;
import com.alibaba.nacos.api.exception.runtime.NacosRuntimeException;
import com.alibaba.nacos.common.utils.StringUtils; import com.alibaba.nacos.common.utils.StringUtils;
import com.alibaba.nacos.core.exception.ErrorCode; import com.alibaba.nacos.core.exception.ErrorCode;
import com.alibaba.nacos.core.exception.KvStorageException; import com.alibaba.nacos.core.exception.KvStorageException;
@ -28,11 +30,13 @@ import com.alibaba.nacos.naming.misc.Loggers;
import java.io.File; import java.io.File;
import java.nio.file.Paths; import java.nio.file.Paths;
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap; import java.util.HashMap;
import java.util.LinkedList;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.ConcurrentHashMap;
import java.util.function.Function;
/** /**
* Kv storage implementation for naming. * Kv storage implementation for naming.
@ -49,12 +53,13 @@ public class NamingKvStorage extends MemoryKvStorage {
public NamingKvStorage(final String baseDir) throws Exception { public NamingKvStorage(final String baseDir) throws Exception {
this.baseDir = baseDir; this.baseDir = baseDir;
baseDirStorage = StorageFactory.createKvStorage(KvStorage.KvType.File, "naming-persistent", baseDir); this.baseDirStorage = StorageFactory.createKvStorage(KvStorage.KvType.File, "naming-persistent", baseDir);
namespaceKvStorage = new ConcurrentHashMap<>(); this.namespaceKvStorage = new ConcurrentHashMap<>(16);
} }
@Override @Override
public byte[] get(byte[] key) throws KvStorageException { public byte[] get(byte[] key) throws KvStorageException {
// First get the data from the memory Cache
byte[] result = super.get(key); byte[] result = super.get(key);
if (null == result) { if (null == result) {
try { try {
@ -171,16 +176,17 @@ public class NamingKvStorage extends MemoryKvStorage {
} }
private List<String> getAllNamespaceDirs() { private List<String> getAllNamespaceDirs() {
List<String> result = new LinkedList<>();
File[] files = new File(baseDir).listFiles(); File[] files = new File(baseDir).listFiles();
List<String> result = Collections.emptyList();
if (null != files) { if (null != files) {
result = new ArrayList<>(files.length);
for (File each : files) { for (File each : files) {
if (each.isDirectory()) { if (each.isDirectory()) {
result.add(each.getName()); result.add(each.getName());
} }
} }
} }
return result; return Collections.unmodifiableList(result);
} }
@Override @Override
@ -208,11 +214,16 @@ public class NamingKvStorage extends MemoryKvStorage {
if (StringUtils.isBlank(namespace)) { if (StringUtils.isBlank(namespace)) {
return baseDirStorage; return baseDirStorage;
} }
if (!namespaceKvStorage.containsKey(namespace)) {
String namespacePath = Paths.get(baseDir, namespace).toString(); Function<String, KvStorage> kvStorageBuilder = key -> {
namespaceKvStorage.putIfAbsent(namespace, try {
StorageFactory.createKvStorage(KvStorage.KvType.File, "naming-persistent", namespacePath)); String namespacePath = Paths.get(baseDir, key).toString();
return StorageFactory.createKvStorage(KvType.File, "naming-persistent", namespacePath);
} catch (Exception e) {
throw new NacosRuntimeException(NacosException.SERVER_ERROR, e);
} }
};
namespaceKvStorage.computeIfAbsent(namespace, kvStorageBuilder);
return namespaceKvStorage.get(namespace); return namespaceKvStorage.get(namespace);
} }
} }

View File

@ -99,7 +99,7 @@ public class RaftConsistencyServiceImpl implements PersistentConsistencyService
} else { } else {
raftCore.signalDelete(key); raftCore.signalDelete(key);
} }
raftCore.unlistenAll(key); raftCore.unListenAll(key);
} catch (Exception e) { } catch (Exception e) {
Loggers.RAFT.error("Raft remove failed.", e); Loggers.RAFT.error("Raft remove failed.", e);
throw new NacosException(NacosException.SERVER_ERROR, "Raft remove failed, key:" + key, e); throw new NacosException(NacosException.SERVER_ERROR, "Raft remove failed, key:" + key, e);

View File

@ -977,7 +977,7 @@ public class RaftCore implements Closeable {
notifier.deregisterListener(key, listener); notifier.deregisterListener(key, listener);
} }
public void unlistenAll(String key) { public void unListenAll(String key) {
notifier.deregisterAllListener(key); notifier.deregisterAllListener(key);
} }