summaryrefslogtreecommitdiff
path: root/module/acme/src/main
diff options
context:
space:
mode:
authorTrygve Laugstøl <trygvis@inamo.no>2021-01-25 21:29:12 +0100
committerTrygve Laugstøl <trygvis@inamo.no>2021-01-25 21:29:12 +0100
commit912bc8b903dfa6d438c2469ecdad35c181c71830 (patch)
tree1e6ee9fdcb2b9d488914b80623d68189867533bb /module/acme/src/main
parent92b957036218c03a20ba35c19a70bdf5e2333fd3 (diff)
downloadrules-sandbox-912bc8b903dfa6d438c2469ecdad35c181c71830.tar.gz
rules-sandbox-912bc8b903dfa6d438c2469ecdad35c181c71830.tar.bz2
rules-sandbox-912bc8b903dfa6d438c2469ecdad35c181c71830.tar.xz
rules-sandbox-912bc8b903dfa6d438c2469ecdad35c181c71830.zip
Improving usability, massive refactoring.
* Moving all Drools code into their own modules. This fixes ri-engine to acme dependency. * Now they all inherit from their own parent, should be used by third party code too. * Separating acme planning code into its own module. * Splitting rules code from ri-engine into ri-base. ri-engine is now a pure launcher for modules. * Dumping kogito for the most part, but it seems like the planner still requires that.
Diffstat (limited to 'module/acme/src/main')
-rw-r--r--module/acme/src/main/java/io/trygvis/acme/AcmeAppsMain.java24
-rw-r--r--module/acme/src/main/java/io/trygvis/acme/VpnMain.java41
-rw-r--r--module/acme/src/main/java/io/trygvis/acme/planning/machine/CloudBalance.java48
-rw-r--r--module/acme/src/main/java/io/trygvis/acme/planning/machine/CloudBalancingEasyScoreCalculator.java45
-rw-r--r--module/acme/src/main/java/io/trygvis/acme/planning/machine/CloudComputer.java16
-rw-r--r--module/acme/src/main/java/io/trygvis/acme/planning/machine/CloudPlaningMain.java52
-rw-r--r--module/acme/src/main/java/io/trygvis/acme/planning/machine/CloudPlanner.java22
-rw-r--r--module/acme/src/main/java/io/trygvis/acme/planning/machine/CloudProcess.java48
-rw-r--r--module/acme/src/main/java/io/trygvis/acme/planning/machine/CloudProcessDifficultyComparator.java15
-rw-r--r--module/acme/src/main/java/io/trygvis/acme/planning/machine/ScalewayInstance.java25
-rw-r--r--module/acme/src/main/resources/io/trygvis/acme/planning/machine/solver-config.xml18
11 files changed, 27 insertions, 327 deletions
diff --git a/module/acme/src/main/java/io/trygvis/acme/AcmeAppsMain.java b/module/acme/src/main/java/io/trygvis/acme/AcmeAppsMain.java
index caab325..c65a3b2 100644
--- a/module/acme/src/main/java/io/trygvis/acme/AcmeAppsMain.java
+++ b/module/acme/src/main/java/io/trygvis/acme/AcmeAppsMain.java
@@ -1,18 +1,14 @@
package io.trygvis.acme;
-import io.trygvis.rules.engine.Engine;
-
-import java.io.File;
-import java.io.IOException;
-
public class AcmeAppsMain {
- public static void main(String[] args) throws IOException {
- try (var engine = new Engine(
- "acme-apps",
- "acme.yaml",
- new File("acme-apps"),
- new String[]{"init", "generate"})) {
- engine.io.dump("acme/apps", engine.session.getFactHandles());
- }
- }
+// public static void main(String[] args) throws IOException {
+// try (var engine = new Engine(
+// "acme-apps",
+// new File("acme.yaml"),
+// new File("acme-apps"),
+// new String[]{"init", "generate"},
+// new File[0])) {
+// engine.io.dump(new File("out", "acme/apps.yaml"), engine.session.getFactHandles());
+// }
+// }
}
diff --git a/module/acme/src/main/java/io/trygvis/acme/VpnMain.java b/module/acme/src/main/java/io/trygvis/acme/VpnMain.java
index 1859e2a..cbf962c 100644
--- a/module/acme/src/main/java/io/trygvis/acme/VpnMain.java
+++ b/module/acme/src/main/java/io/trygvis/acme/VpnMain.java
@@ -1,28 +1,21 @@
package io.trygvis.acme;
-import io.trygvis.rules.dns.DnsEntry;
-import io.trygvis.rules.engine.Engine;
-import io.trygvis.rules.machine.Machine;
-import io.trygvis.rules.network.Ipv4Address;
-import io.trygvis.rules.network.Ipv4Cidr;
-
-import java.io.File;
-import java.io.IOException;
-
public class VpnMain {
- public static void main(String[] args) throws IOException {
- try (var engine = new Engine(
- "acme-wireguard",
- "acme.yaml",
- new File("acme-wireguard"),
- new String[]{"init", "generate"})) {
- engine.io.dump("acme/wireguard", engine.session.getFactHandles(), (Object o) ->
- o.getClass().getName().contains("Wg")
- || o instanceof Machine
- || o instanceof DnsEntry
- || o instanceof Ipv4Cidr
- || o instanceof Ipv4Address
- );
- }
- }
+// public static void main(String[] args) throws IOException {
+// try (var engine = new Engine(
+// "acme-wireguard",
+// new File("acme.yaml"),
+// new File("acme-wireguard"),
+// new String[]{"init", "generate"},
+// new File[0])) {
+// var outputFile = new File("out", "acme/wireguard.yaml");
+// engine.io.dump(outputFile, engine.session.getFactHandles(), (Object o) ->
+// o.getClass().getName().contains("Wg")
+// || o instanceof Machine
+// || o instanceof DnsEntry
+// || o instanceof Ipv4Cidr
+// || o instanceof Ipv4Address
+// );
+// }
+// }
}
diff --git a/module/acme/src/main/java/io/trygvis/acme/planning/machine/CloudBalance.java b/module/acme/src/main/java/io/trygvis/acme/planning/machine/CloudBalance.java
deleted file mode 100644
index 7311918..0000000
--- a/module/acme/src/main/java/io/trygvis/acme/planning/machine/CloudBalance.java
+++ /dev/null
@@ -1,48 +0,0 @@
-package io.trygvis.acme.planning.machine;
-
-import org.optaplanner.core.api.domain.solution.PlanningEntityCollectionProperty;
-import org.optaplanner.core.api.domain.solution.PlanningScore;
-import org.optaplanner.core.api.domain.solution.PlanningSolution;
-import org.optaplanner.core.api.domain.solution.ProblemFactCollectionProperty;
-import org.optaplanner.core.api.domain.valuerange.ValueRangeProvider;
-import org.optaplanner.core.api.score.buildin.hardsoft.HardSoftScore;
-
-import java.util.List;
-
-@PlanningSolution
-public class CloudBalance {
-
- private List<CloudComputer> computerList;
-
- private List<CloudProcess> processList;
-
- private HardSoftScore score;
-
- public CloudBalance(List<CloudComputer> computerList, List<CloudProcess> processList) {
- this.computerList = computerList;
- this.processList = processList;
- }
-
- public CloudBalance() {
- }
-
- @ValueRangeProvider(id = "computerRange")
- @ProblemFactCollectionProperty
- public List<CloudComputer> getComputerList() {
- return computerList;
- }
-
- @PlanningEntityCollectionProperty
- public List<CloudProcess> getProcessList() {
- return processList;
- }
-
- @PlanningScore
- public HardSoftScore getScore() {
- return score;
- }
-
- public void setScore(HardSoftScore score) {
- this.score = score;
- }
-}
diff --git a/module/acme/src/main/java/io/trygvis/acme/planning/machine/CloudBalancingEasyScoreCalculator.java b/module/acme/src/main/java/io/trygvis/acme/planning/machine/CloudBalancingEasyScoreCalculator.java
deleted file mode 100644
index 6a14372..0000000
--- a/module/acme/src/main/java/io/trygvis/acme/planning/machine/CloudBalancingEasyScoreCalculator.java
+++ /dev/null
@@ -1,45 +0,0 @@
-package io.trygvis.acme.planning.machine;
-
-import org.optaplanner.core.api.score.buildin.hardsoft.HardSoftScore;
-import org.optaplanner.core.api.score.calculator.EasyScoreCalculator;
-
-public class CloudBalancingEasyScoreCalculator implements EasyScoreCalculator<CloudBalance, HardSoftScore> {
-
- @Override
- public HardSoftScore calculateScore(CloudBalance cloudBalance) {
- int hardScore = 0;
- int softScore = 0;
- for (CloudComputer computer : cloudBalance.getComputerList()) {
- int cpu = 0;
- int memory = 0;
- boolean used = false;
-
- // Calculate usage
- for (CloudProcess process : cloudBalance.getProcessList()) {
- if (computer.equals(process.computer)) {
- cpu += process.requiredCpu;
- memory += process.requiredMemory;
- used = true;
- }
- }
-
- var instance = computer.instance;
-
- // Hard constraints
- int cpuPowerAvailable = instance.cpu - cpu;
- if (cpuPowerAvailable < 0) {
- hardScore += cpuPowerAvailable;
- }
- int memoryAvailable = instance.memory - memory;
- if (memoryAvailable < 0) {
- hardScore += memoryAvailable;
- }
-
- // Soft constraints
- if (used) {
- softScore -= instance.cost;
- }
- }
- return HardSoftScore.of(hardScore, softScore);
- }
-}
diff --git a/module/acme/src/main/java/io/trygvis/acme/planning/machine/CloudComputer.java b/module/acme/src/main/java/io/trygvis/acme/planning/machine/CloudComputer.java
deleted file mode 100644
index aa2087d..0000000
--- a/module/acme/src/main/java/io/trygvis/acme/planning/machine/CloudComputer.java
+++ /dev/null
@@ -1,16 +0,0 @@
-package io.trygvis.acme.planning.machine;
-
-public class CloudComputer {
- public final String host;
- public final ScalewayInstance instance;
-
- public CloudComputer(String host, ScalewayInstance instance) {
- this.host = host;
- this.instance = instance;
- }
-
- @Override
- public String toString() {
- return host;
- }
-}
diff --git a/module/acme/src/main/java/io/trygvis/acme/planning/machine/CloudPlaningMain.java b/module/acme/src/main/java/io/trygvis/acme/planning/machine/CloudPlaningMain.java
deleted file mode 100644
index 60b3fd3..0000000
--- a/module/acme/src/main/java/io/trygvis/acme/planning/machine/CloudPlaningMain.java
+++ /dev/null
@@ -1,52 +0,0 @@
-package io.trygvis.acme.planning.machine;
-
-import org.optaplanner.core.api.solver.SolverFactory;
-
-import java.util.ArrayList;
-
-public class CloudPlaningMain {
- public static final ScalewayInstance Stardust1_s = new ScalewayInstance("Stardust1-s", 0.0025, 1000, 1000);
- public static final ScalewayInstance DEV1_S = new ScalewayInstance("DEV1-S", 0.01, 2000, 2000);
- public static final ScalewayInstance DEV1_M = new ScalewayInstance("DEV1-M", 0.02, 3000, 4000);
- public static final ScalewayInstance DEV1_L = new ScalewayInstance("DEV1-L", 0.04, 4000, 8000);
- public static final ScalewayInstance DEV1_XL = new ScalewayInstance("DEV1-XL", 0.06, 4000, 12000);
-
- public static void main(String[] args) {
- var solverFactory = SolverFactory.<CloudBalance>createFromXmlResource("io/trygvis/acme/planning/machine/solver-config.xml");
- var solver = solverFactory.buildSolver();
-
- var computers = new ArrayList<CloudComputer>();
-
- computers.add(new CloudComputer("acme-1", DEV1_S));
- computers.add(new CloudComputer("acme-2", DEV1_M));
- computers.add(new CloudComputer("acme-3", DEV1_S));
-
- var processes = new ArrayList<CloudProcess>();
-
- processes.add(new CloudProcess("statera", 200, 1000));
- processes.add(new CloudProcess("statera-console", 100, 50));
- processes.add(new CloudProcess("4tune-web", 100, 50));
- processes.add(new CloudProcess("4tune-api", 200, 200));
- processes.add(new CloudProcess("pdb", 500, 500));
- processes.add(new CloudProcess("mdb", 500, 200));
-
- var unsolvedCloudBalance = new CloudBalance(computers, processes);
-
- var solvedCloudBalance = solver.solve(unsolvedCloudBalance);
-
- System.out.println("solvedCloudBalance.getScore() = " + solvedCloudBalance.getScore());
- for (CloudProcess process : solvedCloudBalance.getProcessList()) {
- System.out.println("process.id = " + process.id);
- if (process.computer == null) {
- System.out.println("COMPUTER IS NULL");
- } else {
- System.out.println("process.computer.host = " + process.computer.host);
- }
- }
-
- System.out.println("------------------------------------------------------------------------");
-
-// System.out.println("\nSolved cloudBalance with 400 computers and 1200 processes:\n"
-// + toDisplayString(solvedCloudBalance));
- }
-}
diff --git a/module/acme/src/main/java/io/trygvis/acme/planning/machine/CloudPlanner.java b/module/acme/src/main/java/io/trygvis/acme/planning/machine/CloudPlanner.java
deleted file mode 100644
index c629656..0000000
--- a/module/acme/src/main/java/io/trygvis/acme/planning/machine/CloudPlanner.java
+++ /dev/null
@@ -1,22 +0,0 @@
-package io.trygvis.acme.planning.machine;
-
-import org.optaplanner.core.api.domain.entity.PlanningEntity;
-import org.optaplanner.core.api.domain.variable.PlanningVariable;
-
-@PlanningEntity()
-public class CloudPlanner {
- private int requiredCpuPower;
- private int requiredMemory;
- private int requiredNetworkBandwidth;
-
- private CloudComputer computer;
-
- @PlanningVariable(valueRangeProviderRefs = {"computerRange"})
- public CloudComputer getComputer() {
- return computer;
- }
-
- public void setComputer(CloudComputer computer) {
- this.computer = computer;
- }
-}
diff --git a/module/acme/src/main/java/io/trygvis/acme/planning/machine/CloudProcess.java b/module/acme/src/main/java/io/trygvis/acme/planning/machine/CloudProcess.java
deleted file mode 100644
index 2002903..0000000
--- a/module/acme/src/main/java/io/trygvis/acme/planning/machine/CloudProcess.java
+++ /dev/null
@@ -1,48 +0,0 @@
-package io.trygvis.acme.planning.machine;
-
-import org.apache.commons.lang3.builder.CompareToBuilder;
-import org.optaplanner.core.api.domain.entity.PlanningEntity;
-import org.optaplanner.core.api.domain.variable.PlanningVariable;
-
-import java.util.Comparator;
-
-@PlanningEntity(difficultyComparatorClass = CloudProcessDifficultyComparator.class)
-public class CloudProcess {
- public String id;
- public int requiredCpu;
- public int requiredMemory;
- public int requiredMultiplicand;
-
- @PlanningVariable(
- valueRangeProviderRefs = "computerRange",
- strengthComparatorClass = CloudComputerStrengthComparator.class)
- public CloudComputer computer;
-
- public CloudProcess(String id, int requiredCpu, int requiredMemory) {
- this.id = id;
- this.requiredCpu = requiredCpu;
- this.requiredMemory = requiredMemory;
-
- this.requiredMultiplicand = requiredCpu * requiredMemory;
- }
-
- @SuppressWarnings("unused")
- public CloudProcess() {
- }
-
- public String toString() {
- return id;
- }
-
- public static class CloudComputerStrengthComparator implements Comparator<CloudComputer> {
- public int compare(CloudComputer a, CloudComputer b) {
- var x = a.instance;
- var y = b.instance;
- return new CompareToBuilder()
- .append(x.multiplicand, y.multiplicand)
- .append(y.cost, x.cost) // Descending (but this is debatable)
- .append(x.kind, y.kind)
- .toComparison();
- }
- }
-}
diff --git a/module/acme/src/main/java/io/trygvis/acme/planning/machine/CloudProcessDifficultyComparator.java b/module/acme/src/main/java/io/trygvis/acme/planning/machine/CloudProcessDifficultyComparator.java
deleted file mode 100644
index 658e826..0000000
--- a/module/acme/src/main/java/io/trygvis/acme/planning/machine/CloudProcessDifficultyComparator.java
+++ /dev/null
@@ -1,15 +0,0 @@
-package io.trygvis.acme.planning.machine;
-
-import org.apache.commons.lang3.builder.CompareToBuilder;
-
-import java.util.Comparator;
-
-public class CloudProcessDifficultyComparator implements Comparator<CloudProcess> {
-
- public int compare(CloudProcess a, CloudProcess b) {
- return new CompareToBuilder()
- .append(a.requiredMultiplicand, b.requiredMultiplicand)
- .append(a.id, b.id)
- .toComparison();
- }
-}
diff --git a/module/acme/src/main/java/io/trygvis/acme/planning/machine/ScalewayInstance.java b/module/acme/src/main/java/io/trygvis/acme/planning/machine/ScalewayInstance.java
deleted file mode 100644
index dfdc0e0..0000000
--- a/module/acme/src/main/java/io/trygvis/acme/planning/machine/ScalewayInstance.java
+++ /dev/null
@@ -1,25 +0,0 @@
-package io.trygvis.acme.planning.machine;
-
-public class ScalewayInstance {
- public final String kind;
- // Euros / hour
- public final double cost;
- public final int cpu;
- public final int memory;
-
- public int multiplicand;
-
- public ScalewayInstance(String kind, double cost, int cpu, int memory) {
- this.kind = kind;
- this.cost = cost;
- this.cpu = cpu;
- this.memory = memory;
-
- this.multiplicand = cpu * memory;
- }
-
- @Override
- public String toString() {
- return kind;
- }
-}
diff --git a/module/acme/src/main/resources/io/trygvis/acme/planning/machine/solver-config.xml b/module/acme/src/main/resources/io/trygvis/acme/planning/machine/solver-config.xml
deleted file mode 100644
index 81ae8ed..0000000
--- a/module/acme/src/main/resources/io/trygvis/acme/planning/machine/solver-config.xml
+++ /dev/null
@@ -1,18 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<solver xmlns="https://www.optaplanner.org/xsd/solver" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xsi:schemaLocation="https://www.optaplanner.org/xsd/solver https://www.optaplanner.org/xsd/solver/solver.xsd">
- <!-- Domain model configuration -->
- <solutionClass>io.trygvis.acme.planning.machine.CloudBalance</solutionClass>
- <entityClass>io.trygvis.acme.planning.machine.CloudProcess</entityClass>
-
- <!-- Score configuration -->
- <scoreDirectorFactory>
- <easyScoreCalculatorClass>io.trygvis.acme.planning.machine.CloudBalancingEasyScoreCalculator</easyScoreCalculatorClass>
- <!--<scoreDrl>org/optaplanner/examples/cloudbalancing/solver/cloudBalancingConstraints.drl</scoreDrl>-->
- </scoreDirectorFactory>
-
- <!-- Optimization algorithms configuration -->
- <termination>
- <secondsSpentLimit>3</secondsSpentLimit>
- </termination>
-</solver>