Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 15 Next »

Status

IN PROGRESS

Impact

HIGH /

Driver

Mikael Nordlander (Unlicensed) Mattias Gradin (Unlicensed)

Approver

Per Persson

Contributors

ola.enebro (Unlicensed) Jakob Melander

Informed

Jari Koponen (Unlicensed)

Due date

Resources

-

\uD83D\uDCDA Relevant data

https://camunda.com/best-practices/deciding-about-your-stack/

\uD83D\uDCD8 Background

När vi nu bygger nytt flöde enligt målarkitektur behöver vi bestämma hur vår uppsättning av Camunda ska vara. Dagens deployment gjordes utifrån behov och för en PoC (till L&P), nu ska vi bygga i tilltänkt målarkitektur och behöver då fatta några beslut som kommer att vara styrande för vår framtid.

Några aspekter att värdera är:

  • Instansstrategi i termer av:

    • Behov av att skilja på externa och interna tillämpningar (CaseManagement vs SupportCenter)?

    • Behov av att skilja på processområden och verksamheter?

  • Teknikval t.ex. val av databas.

 Arkitektur för servrar (Beslut #1)

Köra vidare i PoC deployment

Greenfield enligt Camunda

Description

Vi sätter inte upp nya serverar utan använder samma som används i ärendehanteringen för Lön & Pension

Vi sätter upp nya servrar för Dev,Test och Prod

Pros and cons

(plus) Finns på plats.

(plus)

(plus)

(minus) Sattes inte upp optimalt från början, utan utvecklades under projektets gång.

(minus) Ännu en databas installeras (PostgreSQL i tillägg till Mariadb och MySQL).(minus)

(plus) Renare installation (inga andra db kvar bara PostgreSQL).

(plus)

(plus)

(minus) Ny set up krävs.

(minus)

(minus)

Estimated cost

MEDIUM

MEDIUM

Olika typer av deploy av Camundas processmotor (Beslut #2)

Köra vidare med embeded process engine

Greenfield enligt Camunda med remote process engine

Description

Processmotorn deployas i ett Spring Boot-projekt tillsammans med övrig Java-kod. Detta är så vi har gjort i ÄHS för Lön & Pension

Processmotorn körs i en egen docker-container och deployas separat från övriga kod.

Pros and cons

(plus) Klipp och klistra från tidigare projekt, vi vet exakt hur man gör

(minus) Hård koppling mellan processmotor och övrig kod, eftersom dom driftsätts samtidigt.

(minus)

(plus) Följer best practice från Camunda.

(plus) Separerar processmotorn från annan kod som då inte blir beroende av varandra vid driftsättning, omstart etc.

(plus) Använder docker vilket är en teknik som bara kommer att öka i användning inom Sundsvalls kommun. Vi sätter upp vår infrastruktur för framtiden.

(minus) Har inte satts upp tidigare, så det kommer ta längre tid än att kopiera det vi gjort tidigare.

Estimated cost

LITEN

MEDIUM

Separera Camunda för internt och externt nyttjande (Beslut nr 3).

Här antas att vi vill skilja på nyttjandet när det gäller internt och externt nyttjande. Detta kommer främst från att ha en renare arkitektur enligt:

  1. Mikrotjänsten CaseManagement är styrande för nyttjandet av externa tillämpningsfall med Camunda.

  2. Mikrotjänsten SupportCenter är styrande för nyttjandet av interna tillämpningsfall med Camunda.

Ha både intern och extern instans på samma servrar

Separera intern och extern instans på olika servrar

Description

Processmotorn deployas i ett Spring Boot-projekt tillsammans med övrig Java-kod. Detta är så vi har gjort i ÄHS för Lön & Pension

Processmotorn körs i en egen docker-container och deployas separat från övriga kod.

Pros and cons

(plus)

(minus)

(plus)

(minus)

Estimated cost

LITEN

MEDIUM

Historiknivå för Camunda (Beslut nr 4).

Camunda Platform Enterprise kommer med olika former av historik för körda processinstanser där man kan se olika saker beroende på vilken historiknivå man sätter. Det här behöver sättas första gången Camunda startas upp i en ny miljö, för sedan är det väldigt mycket svårare att ändra. Det beror på att en massa databas-tabeller skapas upp och är sedan inte tänkta att ändras på något sätt.
Här beskrivs dom olika nivåerna från lägst till högst. Tar inte med nivån eftersom den inte direkt är en nivå utan snarare ett sätt som beskriver hur flera processmotorer som ansluter mot samma databas ska bete sig.

För mer info: https://docs.camunda.org/manual/latest/user-guide/process-engine/history/

En viktig sak att ha koll på är att historik är väldigt krävande rent databasmässigt. Camunda kommer regelbundet skriva historik till historikdatabasen, och det är något som får en databas att växa i storlek snabbare än man kan tro. Det går snabbt att komma upp i flera 100 GB om man kör full historik och skickar runt mycket data i sin process.

Vi måste dessuto besluta hur ofta historikdata måste rensas, för den måste regelbundet rensas för att inte historikdatabasen ska växa sig för stor. Om det är så att man vill spara historikdata längre tid,från flera månader tillbaka eller ännu längre, så bör vi fungera på att använda en separat databas skild från Camundas vanliga databas för runtime-data.
Mer om history cleanup: https://docs.camunda.org/manual/7.16/user-guide/process-engine/history/#history-cleanup

NONE

ACTIVITY

AUDIT

FULL

CUSTOM

Description

Historik är avslagen och ingen data skrivs till historikdatabasen.

Här loggas vilken väg i en process som har tagits och vilka aktiviteter som har körts.

Samma som Activity men du får även historik över variabler.

Förutom allt i Activity så får du också historik över User Taks och när en användare har kört dom. Du får också tillgång till historik över DMN-tabeller och vilka regler som har körts där.

Du kan också bygga en egen custom level med hjälp av Java-kod om inte någon av dom vanliga historiknivåerna duger.

Pros and cons

(plus) Ingen data skrivs till historikdatabasen, vilket ökar prestanda i processerna som körs.

(minus) Du tappar all spårbarhet i Camunda Cockpit och du kan endast se incidenter och instanser som körs.

(plus) Om man mest är intresserad av hur processerna körs och inte vilken data som har använts så är det här en bra nivå.

(plus) Mindre krävande än andra nivåer när det kommer till prestanda, utan att man helt tappar historiken.

(minus) Du får ingen information om vad olika variabler har haft för värde, vilket kan göra felsökning svårare.

(minus) Ingen information om vilka beslut via DMN som har tagits.

(plus) Vid felsökning i historikdata så kan man se vilket värde en viss variabel har haft och hur det har ändrats under processens gång.

(minus) Mer last på databasen, även med minimalt antal variabler i processen.

(minus) Ingen information om vilka beslut via DMN som har tagits.

(plus) Du får full tillgång till all historik för din process och kan se exakt vad som har hänt i den. Inkluderar User tasks och beslut via DMN.

(minus) Allra störst last på databasen, både skrivningar till databasen och hur mycket den kommer att växa.

(plus) Du får full kontroll över vilken data som sparas i historikdatabasen.

(minus) Kräver utvecklingstimmar istället för att bara använda en av dom färdiga historiknivåerna.

(minus) Kräver också mer detaljerad kunskap om exakt vilken historikdata som ska sparas undan.

Estimated cost

LITEN

MEDIUM

MEDIUM

MEDIUM

HÖG

✅ Action items

\uD83C\uDF1F Outcome

  • No labels