I’m using FME 2023.2.
I thought I understood parallel processing but clearly there are some intricacies that I don’t understand and I’d appreciate any insights people can provide.
I have a custom transformer that processes Lidar tiles and takes some time to run, so I enabled parallel processing and saw some significant performance improvements with my test set of 20 tiles.
However, when I enable the full data set of 10,000+ files I get an error:
2025-03-28 11:26:41| 63.6| 0.0|ERROR |Could not bind port to socket
2025-03-28 11:26:41| 63.6| 0.0|ERROR |Failed to create transporter
2025-03-28 11:26:41| 63.6| 0.0|ERROR |TransporterSender (TransporterFactory): An error has occurred. Check the logfile above for details
2025-03-28 11:26:41| 63.6| 0.0|ERROR |An error has occurred. Check the logfile above for details
2025-03-28 11:26:41| 63.6| 0.0|ERROR |f_25 (TransformFact): Transformer 'ProcessSingleTile': Unable to create worker; try reducing the parallelism level (currently 'MODERATE') or the number of groups (7521 seen so far, 1000 considered borderline, 10000 close to upper limit in best possible scenario)
So, what I don’t understand is, why does FME try to establish over 7000 processes? I thought the number of processes was limited based on the machine architecture (# cpu’s) and the license level?