1
0
Fork 0
mirror of https://git.rwth-aachen.de/acs/public/villas/node/ synced 2025-03-09 00:00:00 +01:00
VILLASnode/etc/loopback.conf

97 lines
2.6 KiB
Text
Raw Permalink Normal View History

/** This is an example for a minimal loopback configuration.
*
* All messages will be sent back to the origin using UDP packets.
*
* You can use this configuration in conjunction with the 'send', 'receive' and 'random'
* utilities as shown below (run all three steps in parallel).
*
* 0. Overview:
*
2017-05-14 10:40:47 +02:00
* villas signal --PIPE--> ./pipe --UDP--> ./node --UDP--> ./pipe
*
* 1. Start server:
*
2017-05-14 10:40:47 +02:00
* $ villas node etc/loopback.conf
*
* 2. Send random data to server:
*
2017-05-14 10:40:47 +02:00
* $ villas signal random -r 10 -v 4 | villas pipe etc/loopback.conf node1
*
* 3. Receive data from server:
*
2017-05-14 10:40:47 +02:00
* $ villas pipe etc/loopback.conf node2
*
* The syntax of this file is similar to JSON.
* A detailed description of the format can be found here:
* http://www.hyperrealm.com/libconfig/libconfig_manual.html#Configuration-Files
*
* @author Steffen Vogel <stvogel@eonerc.rwth-aachen.de>
* @copyright 2017, Institute for Automation of Complex Power Systems, EONERC
2017-04-27 12:56:43 +02:00
* @license GNU General Public License (version 3)
*
* VILLASnode
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* any later version.
*
2017-04-27 12:56:43 +02:00
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
2017-04-27 12:56:43 +02:00
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*********************************************************************************/
2015-05-07 10:06:08 +02:00
2017-05-14 10:40:47 +02:00
2015-05-07 10:06:08 +02:00
stats = 1;
debug = 10;
nodes = {
2015-05-07 10:06:08 +02:00
node1 = {
2015-08-07 01:25:40 +02:00
type = "socket",
layer = "udp",
2016-09-10 22:19:07 -04:00
local = "*:12000", # Local ip:port, use '*' for random port
2015-08-07 01:25:40 +02:00
remote = "127.0.0.1:12001",
2015-08-09 23:58:50 +02:00
netem = {
enabled = false,
2016-09-13 21:21:21 -04:00
delay = 1000000, # In micro seconds!
2015-08-09 23:58:50 +02:00
jitter = 300000,
distribution = "normal"
}
2015-05-07 10:06:08 +02:00
},
node2 = {
2015-08-07 01:25:40 +02:00
type = "socket",
layer = "udp",
2016-09-10 22:19:07 -04:00
local = "*:12001", # Local ip:port, use '*' for random port
remote = "127.0.0.1:12002",
2017-05-14 10:40:47 +02:00
},
node3 = {
type = "socket",
layer = "udp",
local = "*:12002", # Local ip:port, use '*' for random port
remote = "127.0.0.1:12000",
},
loopback = {
type = "socket",
layer = "udp",
local = "*:12003", # Local ip:port, use '*' for random port
remote = "127.0.0.1:12003",
}
};
paths = (
{
2015-05-07 10:06:08 +02:00
in = "node1", # Name of the node we listen to (see above)
2015-08-09 23:58:50 +02:00
out = "node2", # And we loop back to the origin
2017-05-14 10:40:47 +02:00
hooks = (
{
type = "print";
}
)
}
);