Skip to content
This repository has been archived by the owner on Jan 16, 2025. It is now read-only.

optional TERASLICE_DISPLAY_URL env parameter for metric url labels #7

Merged
merged 3 commits into from
Nov 23, 2020
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
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
3 changes: 3 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ So far it works like this:

```bash
TERASLICE_URL="https://localhost" \
TERASLICE_DISPLAY_URL="https://teraslice-xyz.lan" \
DEBUG=True \
NODE_EXTRA_CA_CERTS=/path/to/ca.crt \
node dist/index.js | bunyan
Expand All @@ -19,6 +20,7 @@ All options are passed as environment variables

```bash
TERASLICE_URL="https://localhost" \
TERASLICE_DISPLAY_URL="https://teraslice-xyz.lan" \
DEBUG=True \
NODE_EXTRA_CA_CERTS=/path/to/ca.crt \
PORT=4242 \
Expand All @@ -31,6 +33,7 @@ The `TERASLICE_URL` is the only environment variable that is required.
### Environment variables

* `TERASLICE_URL` - URL to the Teraslice Instance to Monitor
* `TERASLICE_DISPLAY_URL` - Optional override of TERASLICE_URL for metric label purposes only
* `DEBUG` - Enable debug logging
* `NODE_EXTRA_CA_CERTS` - Standard Node variable to specify CA cert for SSL
connections
Expand Down
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"author": "Terascope, LLC <[email protected]>",
"version": "0.1.1",
"version": "0.2.0",
"license": "MIT",
"dependencies": {
"bunyan": "^1.8.14",
Expand Down
11 changes: 10 additions & 1 deletion src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,12 +11,14 @@ declare let process : {
DEBUG: string,
PORT: number,
TERASLICE_URL: string
TERASLICE_DISPLAY_URL: string
TERASLICE_QUERY_DELAY: number
}
};

async function main() {
let baseUrl: string;
let displayUrl: string;

const server = express();
const port = process.env.PORT || 3000;
Expand All @@ -29,6 +31,13 @@ async function main() {
} else {
throw new Error('The TERASLICE_URL environment variable must be a valid URL to the root of your teraslice instance.');
}
if (process.env.TERASLICE_DISPLAY_URL) {
// I instantiate a URL, then immediately call toString() just to get the
// URL validation but keep a string type
displayUrl = new URL(process.env.TERASLICE_DISPLAY_URL).toString();
} else {
displayUrl = baseUrl;
}
const terasliceQueryDelay = process.env.TERASLICE_QUERY_DELAY || 30000; // ms
const logger = bunyan.createLogger({
name: 'teraslice_exporter',
Expand All @@ -48,7 +57,7 @@ async function main() {
// node v14+
if (process?.env?.DEBUG?.toLowerCase() === 'true') logger.level('debug');

const terasliceStats = new TerasliceStats(baseUrl);
const terasliceStats = new TerasliceStats(baseUrl, displayUrl);
await terasliceStats.update();
updateTerasliceMetrics(terasliceStats);

Expand Down
2 changes: 1 addition & 1 deletion src/metrics.ts
Original file line number Diff line number Diff line change
Expand Up @@ -436,7 +436,7 @@ export function updateTerasliceMetrics(terasliceStats: TerasliceStats): void {
metricsRegistry.resetMetrics();

const globalLabels = {
url: terasliceStats.baseUrl.toString(),
url: terasliceStats.displayUrl.toString(),
name: terasliceStats.info.name,
};
// NOTE: This set of labels expands out to including 'name' twice, right now
Expand Down
5 changes: 4 additions & 1 deletion src/teraslice-stats.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,8 @@ import { pDelay } from './util';
export default class TerasliceStats implements TerasliceStatsInterface {
baseUrl: URL;

displayUrl: string;

controllers: any[];

executions: any[];
Expand All @@ -22,8 +24,9 @@ export default class TerasliceStats implements TerasliceStatsInterface {

queryDuration: TerasliceQueryDuration;

constructor(baseUrl:string) {
constructor(baseUrl:string, displayUrl:string) {
this.baseUrl = new URL(baseUrl);
this.displayUrl = displayUrl;
this.controllers = [];
this.executions = [];
this.jobs = [];
Expand Down