Coming back to this now, one actor, multiple scripts and using ConnectParallel is definitely the right move for my task. Even with a single Heartbeat connection with nothing inside of it, the script activity could jump to 0.3% without using what I just said.
Originally I had one actor and one script, which could essentially slow down the script when iterating through ~20 players, causing false positives. I avoided it by using task.spawn but parallel lua seems like a much more reliable option.
I tried one script and actor per player, however it still drove up script activity when it got to around 20 players. However with one actor and a script per player (under the same actor) it works perfectly. No slowdown and no script activity spikes.
20 scripts not using Parallel Lua.
data:image/s3,"s3://crabby-images/51aab/51aabdc31cbc4a88ac61d1a3d5839de56c036a45" alt="image"
20 scripts using Parallel Lua. (ALL SCRIPTS UNDER ONE ACTOR)
data:image/s3,"s3://crabby-images/fba79/fba79e9f4908dbbe0c4cc79c20eff56e73943e56" alt="image"
20 scripts using Parallel Lua. (ALL SCRIPTS UNDER ITS OWN ACTOR)
data:image/s3,"s3://crabby-images/1fc8e/1fc8e4503527c66d5b4e6bf4248f8b1ae800cb6a" alt="image"
All scripts had this context:
local a = 0
game["Run Service"].Heartbeat:ConnectParallel(function(DeltaTime)
a+=1
end)
Nothing heavy really, but still worth something.
Back here for the final time I promise, this is just for any possible lurkers that are interested in parallel lua but don’t know if it’s worth the switchover.
This is my anticheat with 8 players with parallel lua enabled: (Note that it never reached over 0.5%, it always stayed inbetween .488 and 0. Rarely reaching .488)
data:image/s3,"s3://crabby-images/c8310/c83109c62f4a79c2be558b5b5aa2a0f18eefc6b3" alt="image"
Here’s the same anticheat without parallel lua: (Note that this reached up to 1% per player, the screenshot just didn’t get that)
data:image/s3,"s3://crabby-images/d6370/d6370136256b38baa4dc788772727c0a69790578" alt="image"
While to be fair there are differences in the scripts that probably make the parallel lua run faster not because it’s parallel but because I could create more optimizations just because it was parallel, it’s pretty insane how much of a difference parallel lua can make.