Skip to content

Latest commit

 

History

History
177 lines (142 loc) · 9.57 KB

DEVELOPMENT.md

File metadata and controls

177 lines (142 loc) · 9.57 KB

Prerequisites

For devops av notifikasjonsplattformen er det nødvendig at naisdevice, nais cli og kubectl er installert.

Se: https://doc.nais.io/operate/how-to/command-line-access/?h=

Lokal utvikling og tester

For lokal utvikling benyttes docker-compose til å starte nødvendige platform tjenester (postgres, kafka etc). Vi har god erfaring med colima.

  1. colima start
  2. docker-compose up (må kjøres i rot-mappen til prosjektet)

Lokal app startes ved å kjøre main metoden i LocalMain.kt.

Apiene blir da å nå på:

Hvert api kan inspiseres vha hostet graphql ide:

For at dette skal virke må man sende med riktig auth header (Authorization: Bearer ). Du kan f.eks. sette opp mod-header plugin i chrome eller firefox. Bruk LocalhostIssuer til å lage tokens du kan bruke i header.

Deploy med reset og rebuild

obs: kun for ikke kritiske apps som f.eks statistikk. Scale ned replicaset: kubectl get replicaset kubectl scale --replicas=0 deployment/notifikasjon-statistikk deploy ny app:

  • med migrering som nullstiller database til ønsket tidspunkt eller helt.
  • med ny consumer-group-id postfix eller set offset vha nais aiven cli

Koble direkte til DEV databaser

Se nais cli postgres command i dokumentasjonen https://doc.nais.io/operate/cli/reference/postgres/?h=proxy

Koble direkte til en topic på aiven

Dersom man trenger å administrere en topic (f.eks. inspisere en topic, eller endre offsets for en consumer group), så kan man benytte kafka cli kombinert med nais aiven cli kafka-cli kan man laste ned med ./download_kafka_cli.sh nais aiven installeres.

Det er opprettet en notifikasjon-devops applikasjon med read access til topic i dev og prod. Etter nais aiven er installert kan man opprette applikasjonen. husk å ha valgt riktig context i k8s først: nais login nais aiven create kafka notifikasjon-devops fager

Kommandoen over vil gi deg instruks for å generere klienter når du kjører den. Kopier siste linje fra output og kjør den. F.eks: nais aiven get kafka fager-notifikasjon-devops-ad9c851a fager

Dette genererer noen filer med secrets i en mappe lokalt, og viser hvor disse ble laget. Man kan med disse credentials bruke kafka-cli f.eks. kafka-console-consumer eler kafka-consumer-groups.

Noen eksempler på bruk:

Set env vars fra genrerert secrets (som f.eks $KAFKA_BROKERS)

KAFKA_CONFIG=/var/folders/7d/d3gk6jrx4c31pbjqb3qcyc_r0000gn/T/aiven-secret-1881600168
source $KAFKA_CONFIG/kafka-secret.env

i fish:

set KAFKA_CONFIG /var/folders/7d/d3gk6jrx4c31pbjqb3qcyc_r0000gn/T/aiven-secret-1881600168
bass "set -a; source $KAFKA_CONFIG/kafka-secret.env"

se at $KAFKA_BROKERS er satt fra secrets:

echo $KAFKA_BROKERS

List alle consumer groups på fager.notifikasjon topic:

# TODO: funker dette??
./kafka-consumer-groups.sh --bootstrap-server $KAFKA_BROKERS --command-config $KAFKA_CONFIG/kafka.properties --all-groups count_errors --describe

List offsets for en consumer group (fra listen over consumer groups):

.kafka-cli/bin/kafka-consumer-groups.sh --bootstrap-server $KAFKA_BROKERS --command-config $KAFKA_CONFIG/kafka.properties --group bruker-model-builder --describe

Dersom man skal endre en offset på en partisjon må consumer group være inaktiv. Dette gjøres enklest ved å skalere ned deployment til 0:

kubectl scale --replicas=0 deployment/notifikasjon-dataprodukt 

Sett til et bestemt offset på en gitt partisjon for en consumer group:

.kafka-cli/bin/kafka-consumer-groups.sh --bootstrap-server $KAFKA_BROKERS --command-config $KAFKA_CONFIG/kafka.properties --group dataprodukt-model-builder-3 --topic fager.notifikasjon:12 --reset-offsets --to-offset 94700 --execute

Deretter skalerer man opp igjen til antall replicas som er definert i nais deployment descriptoren (yml):

kubectl scale --replicas=1 deployment/notifikasjon-dataprodukt 

Hopp over en offset på en gitt partisjon for en consumer group:

.kafka-cli/bin/kafka-consumer-groups.sh --bootstrap-server $KAFKA_BROKERS --command-config $KAFKA_CONFIG/kafka.properties --group bruker-model-builder --topic fager.notifikasjon:12 --reset-offsets --shift-by 1 --execute

Les topic for en gitt partisjon fra et gitt offset:

.kafka-cli/bin/kafka-console-consumer.sh --bootstrap-server $KAFKA_BROKERS --consumer.config $KAFKA_CONFIG/kafka.properties --topic fager.notifikasjon --formatter kafka.tools.DefaultMessageFormatter --property print.value=true --property print.offset=true --partition 12 --offset 124

Describe topic:

kafka-cli/bin/./kafka-topics.sh --bootstrap-server $KAFKA_BROKERS --command-config $KAFKA_CONFIG/kafka.properties --topic fager.notifikasjon --describe

Konsumer topic fra starten, pipe til fil og koble fra når ferdig:

.kafka-cli/bin/./kafka-console-consumer.sh --bootstrap-server $KAFKA_BROKERS --consumer.config $KAFKA_CONFIG/kafka.properties --topic fager.notifikasjon --formatter kafka.to
ols.DefaultMessageFormatter --property print.key=true --property print.value=true --property print.offset=true --property print.timestamp=true --timeout-ms 30000 --from-beginning > dev.fager.notifikasjon.topic

Ticks n' Trips

  • start lokal kafka cluster
    • docker-compose up -d
  • connect til broker
    • docker exec -it broker bash
  • kjøre command på broker
    • docker exec -it broker <command>
  • vis broker version
    • kafka-broker-api-versions --bootstrap-server localhost:9092 --version
  • create topic
    • kafka-topics --zookeeper $ZK_HOSTS --create --topic fager.notifikasjon --partitions 3 --replication-factor 3
      • legg til --if-not-exists for å kun opprette dersom den ikke eksisterer fra før
  • list topics
    • kafka-topics --zookeeper zookeeper:2181 --list
    • kafka-topics --zookeeper zookeeper:2181 --list --exclude-internal
  • describe topic
    • kafka-topics --zookeeper zookeeper:2181 --topic fager.notifikasjon --describe
  • juster opp antall partisjoner for topic
    • kafka-topics --zookeeper zookeeper:2181 --alter --topic fager.notifikasjon --partitions 5
  • purge en topic (krever å sette retention lav, så vente, så slette retention)
    • kafka-configs --zookeeper zookeeper:2181 --alter --entity-type topics --entity-name fager.notifikasjon --add-config retention.ms=1000
    • a few moments later
    • kafka-configs --zookeeper zookeeper:2181 --alter --entity-type topics --entity-name fager.notifikasjon --delete-config retention.ms
  • list config for en topic
    • kafka-configs --bootstrap-server localhost:9092 --describe --entity-type topics --entity-name fager.notifikasjon
  • endre config på en topic
    • kafka-configs --bootstrap-server localhost:9092 --alter --entity-type topics --entity-name fager.notifikasjon --add-config cleanup.policy=compact
  • delete topic
    • kafka-topics --zookeeper zookeeper:2181 --delete --topic fager.notifikasjon
  • consume en topic og print til console (default from latest)
    • kafka-console-consumer --bootstrap-server localhost:9092 --topic fager.notifikasjon --formatter kafka.tools.DefaultMessageFormatter --property print.key=true --property print.value=true
    • from the beginning (legg til --from-beginning)
      • kafka-console-consumer --bootstrap-server localhost:9092 --topic fager.notifikasjon --formatter kafka.tools.DefaultMessageFormatter --property print.key=true --property print.value=true --from-beginning
    • from a specific offset to a specific offset (useful to check compaction)
      • ./kafka-console-consumer.sh --bootstrap-server $KAFKA_BROKERS --consumer.config $KAFKA_CONFIG/kafka.properties -topic fager.notifikasjon --formatter kafka.tools.DefaultMessageFormatter --property print.key=true --property print.value=true --property print.offset=true --partition 12 --offset 80148 --max-messages 5
  • produce til en topic
    • kafka-console-producer --bootstrap-server localhost:9092 --topic fager.notifikasjon
  • delete messages from a topic
    • kafka-delete-records.sh --bootstrap-server $KAFKA_BROKERS --offset-json-file delete-records.json
  • inspect a consumer group
    • kafka-consumer-groups.sh --bootstrap-server $KAFKA_BROKERS --command-config /tmp/kafka.properties --group query-model-builder --describe
  • adjust offset of a consumer group (requires group is inactive, i.e. no running consumers)
    • kafka-consumer-groups.sh --bootstrap-server $KAFKA_BROKERS --command-config /tmp/kafka.properties --group query-model-builder --topic fager.notifikasjon --reset-offsets --to-earliest --execute
    • kafka-consumer-groups.sh --bootstrap-server $KAFKA_BROKERS --command-config /tmp/kafka.properties --group query-model-builder --topic fager.notifikasjon --reset-offsets --shift-by 1 --execute
    • kafka-consumer-groups.sh --bootstrap-server $KAFKA_BROKERS --command-config /tmp/kafka.properties --group query-model-builder --topic fager.notifikasjon --reset-offsets --to-datetime 2020-11-01T00:00:00Z --execute
    • specify partition using --topic topic:0,1,2. e.g. reset offset for partition 14 to 5004:
    • kafka-consumer-groups.sh --bootstrap-server $KAFKA_BROKERS --command-config /tmp/kafka.properties --group query-model-builder --topic fager.notifikasjon:14 --reset-offsets --to-offset 5004 --execute

ref: https://medium.com/@TimvanBaarsen/apache-kafka-cli-commands-cheat-sheet-a6f06eac01b