Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

Unlike Parallel Jobs, input and or output (passive) stages can be deployed in designs which enable a single stage to act as both an input and output in the one a Server job. When a job contains such a design, the Server engine will synchronize execution of the stage, so that any load processes are completed before performing the read processes.

For example, consider the following job design:

...

Gliffy
imageAttachmentIdatt2148139022
macroId2d6db8f5-9eb8-4fa7-b5da-1e9c31642f2b
baseUrlhttps://datamigrators.atlassian.net/wiki
displayNameSynchronisation Stages
nameSynchronisation Stages
diagramAttachmentIdatt2148466693
containerId1432027151
timestamp1645491097223

The processes used by the server job will be synchronized such to ensure that the stages grouped by the yellow annotation on the left in Group 1 (above) are fully executed before starting the stages grouped by the annotation on the right.in Group 2. To convert this job design to run on the PX engine , we’ll need to create a parallel Parallel job representing each of the yellow annotations job’s synchronised sub-groups (1 and 2) and a coordinating sequence which runs each job in to mimic the synchronization provided by the Server Engine:

Gliffy
imageAttachmentIdatt2148630531
macroIdaa590c06-7521-45a1-b873-f4e3efa2ef39
baseUrlhttps://datamigrators.atlassian.net/wiki
nameParallel Job ConversionpageidSynchronisation Stages Decomposed
diagramAttachmentIdatt2148204553
containerId1432027151
timestamp16129256336951645491577312

A similar challenge exists for shared containers that include stages that act as both a source and target. The same principles apply here but need to split the shared containers:

Gliffy
imageAttachmentIdatt1973354503
macroIdee1a3ec3-b54f-409f-9175-fbad8a0e7aa5
baseUrlhttps://datamigrators.atlassian.net/wiki
nameSrv-Container-dbReadWrite
diagramAttachmentIdatt1974108163
containerId1432027151
timestamp1629784240467
Gliffy
imageAttachmentIdatt1973420042
macroIdf8e366aa-969c-4729-97bd-0c28783d3ffa
baseUrlhttps:

...

//datamigrators.atlassian.net/wiki
namePx-db-readwrite-decompose
diagramAttachmentIdatt1974206482
containerId1432027151
timestamp1629787017912
Note

Jobs that use DSJobName and DSJobController macros will no longer produce the same output after applying this transformation. Any easy solution would be to have the sequence capture these values and pass them to the child jobs as parameters. Any existing use of DSJobName and DSJobController would then be updated to use the parameters.