I have to do a lot of complex processing on XML files that are >8 GB in size with millions of “records.” I know to use XMLReader rather than XMLDocument, but in addition to that what I’d like to do is split up the file into smaller chunks and allocate it to multiple instances of my app (this is on Linux servers). My code is not threaded, as everything is pretty sequential and there’s no UI.
My question is: on a machine with multiple cores, is there any way to guarantee that different instances of the app will run on different cores? Is there any way for the app to even know what core it’s on? If I’m trying to achieve parallelism, having multiple copies of the app on different cores would seem to be the best approach, but I don’t know if I can even control that.
I can always spin up another machine, but I’d like to try it this way first.
Thanks!