Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Logging service #52

Open
wants to merge 90 commits into
base: master
Choose a base branch
from
Open
Changes from 1 commit
Commits
Show all changes
90 commits
Select commit Hold shift + click to select a range
a75f4e4
Non-working ICMP ping
MasterSushiChef Nov 2, 2018
4fc6eab
Installed net-ping
MasterSushiChef Oct 28, 2018
ddee361
Added DevicePing protobuf message and 'icmp' field in PingTimes
MasterSushiChef Oct 28, 2018
26edfb7
Changed device ping function
MasterSushiChef Nov 2, 2018
d3d2f12
Not working tests
MasterSushiChef Nov 9, 2018
340b1a3
Implemented ICMP pinging of devices
MasterSushiChef Nov 18, 2018
786275f
Removed semicolon in Dockerfile.test and readded list field in PingTi…
MasterSushiChef Nov 19, 2018
039da78
Copy raw-socket instead of gphoto2
MasterSushiChef Nov 19, 2018
6a44da7
Start of logging service
MasterSushiChef Dec 7, 2018
15d2cf8
Rough outline of logging service
MasterSushiChef Dec 7, 2018
9c1f83b
added capability to log data from api pings
MasterSushiChef Jan 27, 2019
ad8367a
updated fields for service constructor and influx database
MasterSushiChef Jan 27, 2019
91de9ea
Updated tests
MasterSushiChef Feb 1, 2019
8db8233
Connected InfluxDB and Grafana
MasterSushiChef Feb 18, 2019
cdeee53
Logging service files
MasterSushiChef Feb 18, 2019
ef3947b
Deleted old L O G S service
MasterSushiChef Feb 18, 2019
bd73c55
Ping data displaying in grafana
MasterSushiChef Feb 24, 2019
00b6c52
Merge branch 'master' of https://github.com/uavaustin/orchestra into …
MasterSushiChef Feb 24, 2019
870fa71
fix merge conflicts with pong
MasterSushiChef Feb 24, 2019
8b99b45
Added functionality to get telemetry uptime
MasterSushiChef Mar 11, 2019
f64c027
Added telemetry status to database
MasterSushiChef Mar 29, 2019
1047f75
Added 'ONLINE' and 'OFFLINE' statuses for telemetry service
MasterSushiChef Apr 5, 2019
0bdc5be
gitignore
MasterSushiChef Apr 5, 2019
feee525
Updated alpine version so libsll1.1 can install
MasterSushiChef Apr 7, 2019
4bd9fde
Added env variables to Dockerfile
MasterSushiChef Apr 7, 2019
94a7de1
Added lumberjack to orchestra make
MasterSushiChef Apr 7, 2019
647e155
Added function and endpoint to get connection state of the plane
MasterSushiChef Apr 7, 2019
03164fe
Changed name of variables in lumberjack Makefile
MasterSushiChef Apr 12, 2019
69541ce
Added additional env variables to start-service
MasterSushiChef Apr 12, 2019
f99b201
-Implemented ability to get status of plane telemetry through length …
MasterSushiChef Apr 12, 2019
d3b5c06
Add function to get lenght of task queue
MasterSushiChef Apr 14, 2019
b324aed
lumberjack now depends on forward-interop and pong
MasterSushiChef Apr 14, 2019
5f68d54
Added port variable
MasterSushiChef Apr 14, 2019
a9822d6
Includes grafana json file
MasterSushiChef Apr 19, 2019
6d1460d
grafana config (?)
MasterSushiChef Apr 21, 2019
1fbcae1
delete useless grafana files
MasterSushiChef Apr 26, 2019
2f718c7
Add Grafana provisioning files
oldmud0 Apr 28, 2019
c67abc0
Tests for lumberjack
MasterSushiChef Apr 29, 2019
33daa65
Merge branch 'logging-service' of https://github.com/uavaustin/orches…
MasterSushiChef Apr 29, 2019
4ffe00e
Minor style fixes in lumberjack
oldmud0 Apr 29, 2019
26f77b9
Update package.json
MasterSushiChef Apr 30, 2019
b403780
Delete package-lock.json
MasterSushiChef Apr 30, 2019
c26f936
Update docker compose
MasterSushiChef Apr 30, 2019
be25727
Delete router.js
MasterSushiChef Apr 30, 2019
6f48b4b
Remove package-lock.json
MasterSushiChef Apr 30, 2019
e758295
Merge branch 'logging-service' of https://github.com/uavaustin/orches…
MasterSushiChef Apr 30, 2019
49a2d75
Small features added and fixes
MasterSushiChef Apr 30, 2019
05e038a
Add lumberjack to Travis CI
oldmud0 Apr 30, 2019
625475e
eslint file
MasterSushiChef May 3, 2019
3b43921
Merge branch 'logging-service' of https://github.com/uavaustin/orches…
MasterSushiChef May 3, 2019
97687b6
Remove task queue
MasterSushiChef May 3, 2019
4da1cd0
Removed task queue function from telemetry
MasterSushiChef May 3, 2019
b91279f
Remove Grafana provisioning files
oldmud0 May 3, 2019
a3abb83
Remove .DS_Store
oldmud0 May 3, 2019
6d57057
Plane telemetry task
MasterSushiChef May 3, 2019
6e62325
Updated to include task intervals across tests and services
MasterSushiChef May 3, 2019
c526960
Merge branch 'logging-service' of https://github.com/uavaustin/orches…
MasterSushiChef May 3, 2019
3f4f318
Fixed timing problems with tests
MasterSushiChef May 10, 2019
6f0eac9
Add babelrc file
MasterSushiChef May 10, 2019
8ffb903
Added plane telemetry task
MasterSushiChef May 12, 2019
5f0d1c0
Tests for plane telemetry
MasterSushiChef May 12, 2019
8ff243b
fix for plane telemetry
MasterSushiChef May 12, 2019
314bbbc
Merge branch 'master' of https://github.com/uavaustin/orchestra into …
MasterSushiChef May 13, 2019
f9b98a8
Merge fixes
MasterSushiChef May 13, 2019
748ef2e
Lumberjack: DRY the code a bit
oldmud0 Jun 5, 2019
eafd29c
Lumberjack: Address PR review
oldmud0 Jun 9, 2019
ab06a87
Fixed '' host issue, container start up timing
MasterSushiChef Jun 13, 2019
3df8f60
Assign statuses to 1 or 0
MasterSushiChef Jul 10, 2019
854c5cf
comment
MasterSushiChef Sep 29, 2019
283a819
update interop-server image
MasterSushiChef Sep 29, 2019
1e3fd5d
line length
MasterSushiChef Sep 29, 2019
badc160
literally a space
MasterSushiChef Oct 2, 2019
d15f838
stop and remove influxdb container after testing
MasterSushiChef Oct 20, 2019
d096959
didn't catch a space
MasterSushiChef Oct 20, 2019
53478a8
Merge pull request #67 from uavaustin/logging-test-fix
MasterSushiChef Oct 20, 2019
f37be96
Adds the code that clear all InfluxDB database.
vinaxue Oct 23, 2019
1a83d55
Changes the mode of the files back to 644
vinaxue Oct 23, 2019
39a8060
Added a router file for lumberjack.
vinaxue Oct 23, 2019
69259a2
Merge branch 'logging-service' of https://github.com/uavaustin/orches…
vinaxue Oct 23, 2019
7ae69f7
Condensed the clearData code.
vinaxue Oct 23, 2019
a72331c
begin work on more unit tests
MasterSushiChef Feb 7, 2020
1f458a2
update tests
MasterSushiChef Feb 9, 2020
b8d8907
Merge branch 'master' into logging-service
MasterSushiChef Feb 9, 2020
c83ceab
fix grafana in testing
MasterSushiChef Feb 23, 2020
f02376a
Revert "fix grafana in testing"
5Nosaj5 Oct 28, 2020
d77f00c
Added Lumberjack timestamps
5Nosaj5 Nov 8, 2020
6327bac
Format fixed
5Nosaj5 Nov 8, 2020
483961b
fix grafana again
senkevinli Nov 20, 2020
84c85ce
updated timing lumberjack
senkevinli Nov 20, 2020
cd23918
env variable support
senkevinli Nov 20, 2020
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Ping data displaying in grafana
  • Loading branch information
MasterSushiChef committed Feb 24, 2019
commit bd73c55248a5260b934102f99d2ca38382545d5e
147 changes: 61 additions & 86 deletions services/lumberjack/src/service.js
Original file line number Diff line number Diff line change
@@ -25,10 +25,10 @@ export default class Service {
*/

constructor(options) {
this._pingHost = '10.148.67.123';
this._pingHost = 'pong';
this._pingPort = 7000;
this._telemHost = '10.148.67.123';
this._telemPort = 5000;
this._forwardInteropHost = 'forward-interop';
this._forwardInteropPort = 4000;
this._influxHost = options.influxHost;
this._influxPort = options.influxPort;
this._influx = null;
@@ -39,35 +39,36 @@ export default class Service {
logger.debug('Starting service.');

this._influx = new Influx.InfluxDB({
host: '10.148.67.123', //env variable localhost
port: 8086, //env variable 8086
database: 'lumberjack',
schema: [
{
measurement: 'ping',
fields: {
ping: Influx.FieldType.FLOAT
},
tags: [
'host',
'port'
]
},
{
measurement: 'telemetry',
fields: {
t1: Influx.FieldType.INTEGER,
t5: Influx.FieldType.INTEGER,
f1: Influx.FieldType.INTEGER,
f5: Influx.FieldType.INTEGER
host: '10.146.229.103', //env variable
port: 8086, //env variable 8086
database: 'lumberjack',
schema: [
{
measurement: 'ping',
fields: {
ping: Influx.FieldType.INTEGER
},
tags: [
'host',
'port',
'name'
]
},
tags: [
'host',
'port'
{
measurement: 'telemetry',
fields: {
t1: Influx.FieldType.INTEGER,
t5: Influx.FieldType.INTEGER,
f1: Influx.FieldType.INTEGER,
f5: Influx.FieldType.INTEGER
},
tags: [
'host',
'port'
]
}
]
})
}
]
});

/*this._influx.getDatabaseNames()
.then(names => {
@@ -109,88 +110,62 @@ export default class Service {

// Start and wait until the server is up and then return it.
return await new Promise((resolve, reject) => {
const server = app.listen(6000, (err) => {
const server = app.listen(6000, (err) => {
if (err) {
reject(err);
console.log(err);
}
else {
console.log('lmaoooo');
resolve(server);
}
});
});

server.closeAsync = () => new Promise((resolve) => {
server.closeAsync = () => new Promise((resolve) => {
server.close(() => resolve());
});
});
}



_startTasks() {
this._forwardTask =
createTimeoutTask(this._logging.bind(this), 500)
.on('error', () => {
console.log('muppet');
})
createTimeoutTask(this._logging.bind(this), 1000)
.on('error', logger.error)
.start();
}

// Get telemetry and ping data and send to database
async _logging() {
logger.debug('');
let ping = Math.random()*100+1;

try {
let { body: ping } =
await request.get('http://' + this._pingHost + ':' + this._pingPort + '/api/ping')
.proto(stats.PingTimes)
.timeout(1000);
} catch (err) {
console.log(err);
}
//console.log(ping);

try {
let ping =
MasterSushiChef marked this conversation as resolved.
Show resolved Hide resolved
(await request.get('http://' + this._pingHost + ':' +
this._pingPort + '/api/ping')
.proto(stats.PingTimes)
.timeout(1000)).body;

for (let endpoint of ping.api_pings) {
let { host, port, name } = endpoint;
this._influx.writeMeasurement('ping', [
{
fields: { ping: ping },
tags: { host: this._pingHost, port: this._pingPort }
}], {
fields: { ping: endpoint.ms },
tags: { host, port, name }
}], {
database: 'lumberjack'
});
} catch (err) {
console.log(err);
}

try {
let { body: total_1, fresh_1, total_5, fresh_5 } =
await request.get('http://' + this._telemHost + ':' + this._telemPort + '/api/upload-rate')
let rate =
(await request.get('http://' + this._forwardInteropHost + ':' +
this._forwardInteropPort + '/api/upload-rate')
.proto(stats.InteropUploadRate)
.timeout(1000);
} catch (err) {
console.log(err);
}
let total_1 = Math.random()*100+1;
let total_5 = Math.random()*100+1;
let fresh_1 = Math.random()*100+1;
let fresh_5 = Math.random()*100+1;

//console.log(total_1);
//console.log(total_5);
//console.log(fresh_1);
//console.log(fresh_5);

try {
this._influx.writePoints([
{
measurement: 'telemetry',
fields: { t1: total_1, t5: total_5, f1: fresh_1, f5: fresh_5 },
tags: { host: this._telemHost, port: this._telemPort }
}])
} catch (err) {
console.error(err);
}
.timeout(1000)).body;

console.log(rate); //eslint-disable-line

this._influx.writeMeasurement('telemetry', [
{
fields: { t1: rate.total_1, t5: rate.total_5,
f1: rate.fresh_1, f5: rate.fresh_5 },
tags: { host: this._forwardInteropHost, port: this._forwardInteropPort }
}]);
}
}
}
70 changes: 44 additions & 26 deletions services/lumberjack/test/service.test.js
Original file line number Diff line number Diff line change
@@ -1,39 +1,57 @@
import nock from 'nock';
import addProtobuf from 'superagent-protobuf';
import request from 'supertest';
import influx from 'influx';

import Service from '/src/service';
import Service from '../src/service';

addProtobuf(request);

beforeAll (async () => {
service = new Service({
influxhost: 'localhost',
influxport: 3000,
pinghost: 'lol'
pingport: 2000,
telemport: 'lmao',
telemhost: 4000
})
});

await service.start();

test('', async () => {

let service;

influx.query('select * from ping').then(results => {
expect(results[0].toEqual('test1'));
expect(results[1].toEqual('dne'));
expect(results[2].toEqual(5));
expect(results[3].toEqual(10));
})
beforeAll (async () => {
service = new Service({
influxServices: [
{
pingHost: 'test1',
pingPort: '7000',
telemHost: 1,
telemPort: 2,
influxHost: 3,
influxPort: 4,
}
]
});
await service.start();
}, 10000);

test('Basic test for influxDB ', async () => {
console.log('oof'); // eslint-disable-line no-console
influx.ping(7000).then(hosts => {
hosts.forEach(host => {
if (host.online) {
console.log('${host.url.host} responded in'); //eslint-disable-line
console.log('${host.rtt}ms running ${host.version}'); // eslint-disable-line
} else {
console.log('${host.url.host} is offline'); // eslint-disable-line
}
});
});

influx.query('select * from pings').then(results => {
expect(results[0]).toEqual('test1');
expect(results[1]).toEqual('dne');
expect(results[2]).toEqual(1);
expect(results[3]).toEqual(2);
expect(results[4]).toEqual(3);
expect(results[5]).toEqual(4);
expect(results[100]).toEqual(4);
});
});

test('', async () => {
test('InfluxDB multiple data test', async () => {

});

afterAll (async () => {

});
await service.stop();
});
8 changes: 8 additions & 0 deletions test/docker-compose.yml
Original file line number Diff line number Diff line change
@@ -103,6 +103,14 @@ services:
test_net:
ipv4_address: 172.16.238.50

lumberjack:
image: uavaustin/lumberjack
ports:
- '6000:6000'
networks:
test_net:
ipv4_address: 172.16.238.17

networks:
test_net:
driver: bridge