use of services.moleculer.service.Name in project moleculer-java by moleculer-java.
the class CommonUtils method nameOf.
public static final String nameOf(Object object, boolean addQuotes) {
Class<?> c = object.getClass();
Version v = c.getAnnotation(Version.class);
String version = null;
if (v != null) {
version = v.value();
if (version != null) {
version = version.trim();
if (version.isEmpty()) {
version = null;
}
}
if (version != null) {
try {
Double.parseDouble(version);
version = 'v' + version;
} catch (Exception ignored) {
}
}
}
Name n = c.getAnnotation(Name.class);
String name = null;
if (n != null) {
name = n.value();
if (name != null) {
name = name.trim();
}
}
if (name == null || name.isEmpty()) {
name = c.getName();
int i = Math.max(name.lastIndexOf('.'), name.lastIndexOf('$'));
if (i > -1) {
name = name.substring(i + 1);
}
name = Character.toLowerCase(name.charAt(0)) + name.substring(1);
}
if (version != null) {
name = version + '.' + name;
}
if (addQuotes && name.indexOf(' ') == -1) {
name = "\"" + name + "\"";
}
return name;
}
use of services.moleculer.service.Name in project moleculer-java by moleculer-java.
the class CircuitBreakerTest method testSimpleCall.
@Test
public void testSimpleCall() throws Exception {
br.createService(new Service("math") {
@Name("add")
public Action add = ctx -> {
return ctx.params.get("a", 0) + ctx.params.get("b", 0);
};
});
// cb.setEnabled(true);
long start = System.currentTimeMillis();
for (int i = 0; i < 50; i++) {
int rsp = br.call("math.add", "a", i, "b", 1).waitFor().asInteger();
assertEquals(i + 1, rsp);
}
assertTrue(System.currentTimeMillis() - start < 50);
}
use of services.moleculer.service.Name in project moleculer-java by moleculer-java.
the class CommonUtils method nameOf.
public static final String nameOf(String prefix, Field field) {
Name n = field.getAnnotation(Name.class);
String name = null;
if (n != null) {
name = n.value();
if (name != null) {
name = name.trim();
}
}
if (name == null || name.isEmpty()) {
name = field.getName();
}
if (name.indexOf('.') == -1) {
return prefix + '.' + name;
}
return name;
}
use of services.moleculer.service.Name in project moleculer-java by moleculer-java.
the class Sample method main.
public static void main(String[] args) throws Exception {
System.out.println("START");
try {
ServiceBrokerConfig cfg = new ServiceBrokerConfig();
// RedisTransporter t = new RedisTransporter();
// t.setDebug(false);
// cfg.setTransporter(t);
ServiceBroker broker = new ServiceBroker(cfg);
MathService math = new MathService();
broker.createService(math);
broker.start();
broker.use(new Middleware() {
@Override
public Action install(Action action, Tree config) {
if (config.get("name", "?").equals("v1.math.test")) {
return new Action() {
@Override
public Object handler(Context ctx) throws Exception {
Object original = action.handler(ctx);
Object replaced = System.currentTimeMillis();
broker.getLogger().info("Middleware invoked! Replacing " + original + " to " + replaced);
return replaced;
}
};
}
return null;
}
});
broker.waitForServices("v1.math").then(ok -> {
for (int i = 0; i < 2; i++) {
broker.call("v1.math.add", "a", 3, "b", 5).then(in -> {
broker.getLogger(Sample.class).info("Result: " + in);
}).catchError(err -> {
broker.getLogger(Sample.class).error("Error: " + err);
});
}
System.out.println("FIRST CALL ->3");
broker.call("service2.test", new Tree(), CallOptions.retryCount(3)).catchError(cause -> {
cause.printStackTrace();
});
});
((DefaultContextFactory) broker.getConfig().getContextFactory()).setMaxCallLevel(3);
Thread.sleep(1000);
broker.createService(new Service2Service());
Thread.sleep(1000);
broker.createService(new Service3Service());
Thread.sleep(60000);
} catch (Exception e) {
e.printStackTrace();
}
System.out.println("STOP");
}
use of services.moleculer.service.Name in project moleculer-java by moleculer-java.
the class DefaultCircuitBreaker method callWithBreaker.
// --- CALL SERVICE WITH BREAKER FUNCTION ---
protected Promise callWithBreaker(String name, Tree params, CallOptions.Options opts, int remaining, Context parent) {
EndpointKey endpointKey = null;
ErrorCounter errorCounter = null;
try {
// Get the first recommended Endpoint and Error Counter
String targetID = opts == null ? null : opts.nodeID;
ActionEndpoint action = (ActionEndpoint) serviceRegistry.getAction(name, targetID);
String nodeID = action.getNodeID();
endpointKey = new EndpointKey(nodeID, name);
errorCounter = errorCounters.get(endpointKey);
// Check availability of the Endpoint (if endpoint isn't targetted)
if (targetID == null) {
LinkedHashSet<String> nodeIDs = new LinkedHashSet<>(maxSameNodes * 2);
int sameNodeCounter = 0;
long now;
if (errorCounter == null) {
now = 0;
} else {
now = System.currentTimeMillis();
}
for (int i = 0; i < maxTries; i++) {
if (errorCounter == null || errorCounter.isAvailable(now)) {
// Endpoint is available
break;
}
// Store nodeID
if (!nodeIDs.add(nodeID)) {
sameNodeCounter++;
if (sameNodeCounter >= maxSameNodes) {
// The "maxSameNodes" limit is reached
break;
}
}
// Try to choose another endpoint
action = (ActionEndpoint) serviceRegistry.getAction(name, targetID);
nodeID = action.getNodeID();
endpointKey = new EndpointKey(nodeID, name);
errorCounter = errorCounters.get(endpointKey);
}
}
// Create new Context
Context ctx = contextFactory.create(name, params, opts, parent);
// Invoke Endpoint
final ErrorCounter currentCounter = errorCounter;
final EndpointKey currentKey = endpointKey;
return Promise.resolve(action.handler(ctx)).then(rsp -> {
// Reset error counter
if (currentCounter != null) {
currentCounter.reset();
}
// Return response
return rsp;
}).catchError(cause -> {
// Increment error counter
increment(currentCounter, currentKey, cause, System.currentTimeMillis());
// Return with error
if (remaining < 1) {
return cause;
}
// Retry
return retryWithBreaker(cause, name, params, opts, remaining, parent);
});
} catch (Throwable cause) {
// Increment error counter
increment(errorCounter, endpointKey, cause, System.currentTimeMillis());
// Reject
if (remaining < 1) {
return Promise.reject(cause);
}
// Retry
return retryWithBreaker(cause, name, params, opts, remaining, parent);
}
}
Aggregations