V 2.03 Noch ein paar Anpassungen
This commit is contained in:
4
.vscode/launch.json
vendored
4
.vscode/launch.json
vendored
@@ -14,8 +14,8 @@
|
||||
"program": "${workspaceFolder}/fetchnewdata.js",
|
||||
"args": [],
|
||||
"env": {
|
||||
"MONGOPORT": "27098",
|
||||
"TYP": "['noise', 'thp']"
|
||||
"MONGOPORT": "27017",
|
||||
"TYP": "['radioactivity', 'thp']"
|
||||
}
|
||||
}
|
||||
]
|
||||
|
||||
68
deploy.sh
68
deploy.sh
@@ -1,19 +1,59 @@
|
||||
# Deploy Sensor-Files via esprimo und docker.citysensor.de
|
||||
# 2023-12-17 rxf
|
||||
#
|
||||
#!/bin/bash
|
||||
|
||||
# set -x
|
||||
# Deploy Script für werte-next
|
||||
# Baut das Docker Image und lädt es zu docker.citysensor.de hoch
|
||||
|
||||
LINUX='esprimo'
|
||||
path="/home/rxf/Projekte/Sensors"
|
||||
name=readin
|
||||
set -e
|
||||
|
||||
rsync -avn --exclude=node_modules --exclude=.git --exclude=deploy.sh --exclude=TRANSFERE --exclude=INFLUXSERVER --exclude=data --exclude=log --exclude=.idea --exclude=.vscode --exclude=docs ./ $LINUX:$path/$name
|
||||
exit 0
|
||||
# Konfiguration
|
||||
REGISTRY="docker.citysensor.de"
|
||||
IMAGE_NAME="readin"
|
||||
TAG="${1:-latest}" # Erster Parameter oder "latest"
|
||||
FULL_IMAGE="${REGISTRY}/${IMAGE_NAME}:${TAG}"
|
||||
|
||||
ssh $LINUX "cd $path/$name;
|
||||
./build_and_copy.sh localhost;
|
||||
docker tag $name docker.citysensor.de/$name;
|
||||
docker push docker.citysensor.de/$name;"
|
||||
# Build-Datum
|
||||
BUILD_DATE=$(date +%d.%m.%Y)
|
||||
|
||||
exit 0
|
||||
echo "=========================================="
|
||||
echo "Werte-Next Deploy Script"
|
||||
echo "=========================================="
|
||||
echo "Registry: ${REGISTRY}"
|
||||
echo "Image: ${IMAGE_NAME}"
|
||||
echo "Tag: ${TAG}"
|
||||
echo "Build-Datum: ${BUILD_DATE}"
|
||||
echo "=========================================="
|
||||
echo ""
|
||||
|
||||
# 1. Login zur Registry (falls noch nicht eingeloggt)
|
||||
echo ">>> Login zu ${REGISTRY}..."
|
||||
docker login "${REGISTRY}"
|
||||
echo ""
|
||||
|
||||
# 2. Multiplatform Builder einrichten (docker-container driver erforderlich)
|
||||
echo ">>> Richte Multiplatform Builder ein..."
|
||||
if ! docker buildx inspect multiplatform-builder &>/dev/null; then
|
||||
docker buildx create --name multiplatform-builder --driver docker-container --bootstrap
|
||||
fi
|
||||
docker buildx use multiplatform-builder
|
||||
echo ""
|
||||
|
||||
# 3. Docker Image bauen und pushen (Multiplatform)
|
||||
echo ">>> Baue Multiplatform Docker Image und pushe zu Registry..."
|
||||
docker buildx build \
|
||||
--platform linux/amd64,linux/arm64 \
|
||||
--build-arg BUILD_DATE="${BUILD_DATE}" \
|
||||
-t "${FULL_IMAGE}" \
|
||||
--push \
|
||||
.
|
||||
|
||||
echo ">>> Build und Push erfolgreich!"
|
||||
|
||||
echo ""
|
||||
echo "=========================================="
|
||||
echo "✓ Deploy erfolgreich abgeschlossen!"
|
||||
echo "=========================================="
|
||||
echo ""
|
||||
echo "Auf dem Server ausführen:"
|
||||
echo " docker pull ${FULL_IMAGE}"
|
||||
echo " docker-compose -f docker-compose.prod.yml up -d"
|
||||
echo ""
|
||||
|
||||
@@ -5,20 +5,20 @@ volumes:
|
||||
influx_vol:
|
||||
|
||||
services:
|
||||
timeseries:
|
||||
image: timeseries
|
||||
environment:
|
||||
DEVELOP: "true"
|
||||
MONGOHOST: mongodb
|
||||
MONGOUSRP: "rexfue:noise4mongo"
|
||||
MONGOAUTH: "true"
|
||||
INFLUXHOST: influxdb
|
||||
INFLUXTOKEN: "q35XUBaElzcy8dDd9HF2_mpeHvYCampZg_9mJNP5jeBQRopq3EWIzNTZ555QLSIXhZC05RXCoFgjiaT7VzyNkQ=="
|
||||
TYP: "[\"noise\", \"thp\"]"
|
||||
volumes:
|
||||
- ${PWD}/log:/var/log
|
||||
container_name: timeseries
|
||||
restart: unless-stopped
|
||||
# timeseries:
|
||||
# image: timeseries
|
||||
# environment:
|
||||
# DEVELOP: "true"
|
||||
# MONGOHOST: mongodb
|
||||
# MONGOUSRP: "rexfue:noise4mongo"
|
||||
# MONGOAUTH: "true"
|
||||
# INFLUXHOST: influxdb
|
||||
# INFLUXTOKEN: "q35XUBaElzcy8dDd9HF2_mpeHvYCampZg_9mJNP5jeBQRopq3EWIzNTZ555QLSIXhZC05RXCoFgjiaT7VzyNkQ=="
|
||||
# TYP: "[\"noise\", \"thp\"]"
|
||||
# volumes:
|
||||
# - ${PWD}/log:/var/log
|
||||
# container_name: timeseries
|
||||
# restart: unless-stopped
|
||||
|
||||
mongodb:
|
||||
image: mongo:6
|
||||
|
||||
@@ -24,7 +24,7 @@ import { logit, logerror } from './logit.js'
|
||||
import { DateTime } from 'luxon'
|
||||
import fs from 'fs'
|
||||
import mod_getopt from 'posix-getopt'
|
||||
import pkg from './package.json' assert { type: "json" }
|
||||
const pkg = JSON.parse(fs.readFileSync(new URL('./package.json', import.meta.url), 'utf8'))
|
||||
|
||||
|
||||
// import nodeSchedule from 'node-schedule'
|
||||
@@ -76,7 +76,7 @@ const fetchNewData = async (args) => {
|
||||
function parse_cmdline(argv) {
|
||||
let parser = new mod_getopt.BasicParser('i(influx)m(mongo)t:(typ)h(help)v(version)',argv);
|
||||
let option;
|
||||
let ret = {influx: true, mongo: true, typ: TYP}
|
||||
let ret = {influx: false, mongo: true, typ: TYP}
|
||||
while((option = parser.getopt()) !== undefined) {
|
||||
switch(option.option) {
|
||||
case 'i':
|
||||
|
||||
2
mongo.js
2
mongo.js
@@ -1,4 +1,4 @@
|
||||
/* Interface for MongoDB
|
||||
/* Interface for MongoDB
|
||||
*/
|
||||
import { MongoClient } from 'mongodb'
|
||||
import { logit, logerror } from './logit.js'
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
{
|
||||
"name": "timeseries_mongo",
|
||||
"version": "2.0.2",
|
||||
"date": "2023-12-17",
|
||||
"name": "readin",
|
||||
"version": "2.0.3",
|
||||
"date": "2026-04-01",
|
||||
"description": "",
|
||||
"main": "main.js",
|
||||
"scripts": {
|
||||
|
||||
2
parse.js
2
parse.js
@@ -168,7 +168,7 @@ export const constructDBaseEntries = async (client, body, args) => {
|
||||
pm: [], thp: [], noise: [], radioactivity: [], gps: [], unknown: []
|
||||
}
|
||||
let datalines = ''
|
||||
actualProps = await mongo.getallProperties(client)
|
||||
// actualProps = await mongo.getallProperties(client)
|
||||
try {
|
||||
for (let item of body) { // check all entries
|
||||
const dt = item.timestamp.split(' ')
|
||||
|
||||
Reference in New Issue
Block a user