Skip to content

Latest commit

 

History

History
67 lines (44 loc) · 2.54 KB

README.md

File metadata and controls

67 lines (44 loc) · 2.54 KB

synthesize-events

Synthesizes, processes, calculates various statistics about events that have taken place in the recent past. It reads event data from redis and then stores the synthesized data in other redis keys. Every day or date is UTC timezone.

create a .env file or set env vars:

UPSTASH_REDIS_REST_URL=""
UPSTASH_REDIS_REST_TOKEN=""

Install redis-stack-server shown here https://redis.io/docs/install/install-stack/mac-os/ because we use the redis JSON module Start a local redis server (brew install redis redis-stack && redis-stack-server) at localhost:6379 and then run a http server to simulate upstash's http server. Github issue upstash/redis-js#802

podman run \
    --rm -d -p 8080:80 --name redis-http \
    -e SRH_MODE=env \
    -e SRH_TOKEN=dummy_token \
    -e SRH_CONNECTION_STRING="redis://host.containers.internal:6379" \
    hiett/serverless-redis-http:latest

Manually set redis values with redis-cli and set <key> <value> command

With node and npm installed, to index yesterday UTC time, run npm install then npm run watchIndex (careful this will re-run on any file save)

Run this on a specific day with npm run watchIndex -- --day '2024-01-30' NOTE!: Indexing for a specific day, relies on the previous day's index. So if you want accurate "monthly active nodes" counts and indexing, then index a months worth of days first before doing a specific day.

Redis keys

Event data read from event::<event-id> and eventsByDay::<yyyy-mm-dd> is synthesized and then the resulting data is stored in metrics:: hashes

Impact Dashboard keys

The types can be found in src/redisTypes.ts

Troubleshooting

We want to use UTC timezones for all dates. Make this clear to users which timezones they are seeing.

Run with cron job

Use crontab -e to edit the user's cron jobs. touch ~/cronoutput-synthesize.txt to create the log file

To run it once a day at a specific time try something like:

04 16 * * * cd /home/johns/dev/synthesize-events && /usr/bin/npm run runProd >> /home/johns/cronoutput-synthesize.txt 2>&1

In conjuction with transfer-events and using UTC timezone:

TZ=UTC
03 0  * * * cd /home/johns/dev/transfer-events && /usr/bin/npm run runProd >> /home/johns/cronoutput.txt 2>&1
06 0 * * * cd /home/johns/dev/synthesize-events && /usr/bin/npm run runProd >> /home/johns/cronoutput-synthesize.txt 2>&1

which npm to determine npm path (path isn't always setup with crontab)

4:00pm Pacific time

Run for a previous day

npm run runProd -- --day '2024-02-23'