HoneyBadger said:
Is there a way for you to see which scripts are the biggest culprits?
Lake / James said:
Assuming this is the link you're needing, Riley?
https://app.roll20.net/campaigns/details/123013/eberron-v2-dot-0
Lake / James said:
Assuming this is the link you're needing, Riley?
https://app.roll20.net/campaigns/details/123013/eberron-v2-dot-0
Kevin said:
Something seems off all of the sudden, or I don't understand what could cause an infinite loop, which is quite possible as I am a novice, however everything I run now is generating "Heartbeat timed out, infinite loop most likely culprit."
I actually commented out everything except for the "on("chat:message", function (msg)" and a simple log() statement and it still generate the Heartbeat timed out.
Michael A. said:
Can I get any idea if my campaign is getting anywhere near the boundaries of "CPU usage" for the servers?
Honestly my campaign has been a project which has been worked on by a team for several months now, so this is a bit of a concern for myself and all my players.
Kevin said:
Riley: https://app.roll20.net/campaigns/details/414779/pa...
Currently the script that I have in there is completely commented out except for the basics necessary to run the !import command.
Riley D. said:
Lake / James said:
Assuming this is the link you're needing, Riley?
https://app.roll20.net/campaigns/details/123013/eberron-v2-dot-0
I just tried yours and it seemed to work fine for me (I pressed "Save", then loaded up the game in another tab, and the sandbox started up fine). Did you try running the campaign in the last few hours and it gave you that error? Or did you just see that error when you went to the API scripts screen and stop there?
Note that I didn't actually test any of the functionality of the scripts themselves since I don't know what you have all in there and what they're supposed to do, so let me know if you encounter problems when you actually go to use the script's functionality. But at least the "no scripts for campaign" thing seems to be resolved...
Riley D. said:
There are some types of scripts I'm seeing looking through these logs that really are pretty close to what I would consider "abuse" of the system, or at the very least they aren't respecting the way that the system was designed to be used.
I admit, I'm kinda curious what that's supposed to mean. I'm having a hard time thinking of a means to abuse the system that hasn't already been closed. I mean, I think it's still possible to poison your object data, but that gets fixed when you start a new session and I can't fathom how making your objects more difficult to work with locally would harm the system.
Aaron said:
Couple questions I know will come up, so I'll bite the bullet and ask them:
- Is there any chance that you'll be introducing a less impactful method of uploading data to the API without editing a script?
- Are there any plans for introducing a means of interacting with the scripts via a custom UI?
- If someone wanted to have a database style of script, what would be the appropriate method?
(Edit: And thanks for the clarity, I'm sure we all appreciate the frank response!)
There's a script which uses the gmnotes field to import monster statistics. However, the XML is never more than 100KB. Is that unacceptable too?
2. Not currently, no. I've toyed around with the idea of letting API scripts add "hooks" to the UI, but I don't have any definite plans on that.Would you consider adding a syntax to /direct anchors that allows them to execute an API command? Something like:
<a href="sendChat:!cal next">Tomorrow</a>would let us send UI without adding anything more than typing the commands already does.
events.js:72
throw er; // Unhandled 'error' event
^
Error: listen EADDRINUSE
at errnoException (net.js:904:11)
at Server._listen2 (net.js:1023:19)
at listen (net.js:1064:10)
at Server.listen (net.js:1132:5)
at Sandbox.start (/home/symbly/www/d20-api-server/sandcastle/lib/sandbox.js:35:15)
at Object.<anonymous> (/home/symbly/www/d20-api-server/sandcastle/bin/sandcastle.js:11:9)
at Module._compile (module.js:456:26)
at Object.Module._extensions..js (module.js:474:10)
at Module.load (module.js:356:32)
at Function.Module._load (module.js:312:12)
Riley D. said:
Scripts That Are Too Large, Usually "Databases"
There are people that are running 50,000+ lines of code in their campaigns. That might literally be more lines of code than it takes to run large parts of Roll20. The usual pattern I'm seeing here is with people trying to shoehorn "databases" into their scripts -- for example there's one floating around that is 50,000+ lines of code that is just a giant database of Pathfinder spells. On top of that, the database is being saved to the state object, so every 5 seconds the system is having to write something like 10MB of JSON data to the disk. Not super performant.
Please consider that when you have 10MB+ of script source code, that is a lot of data to move around, compile, and execute. In addition, your entire source code tree shouldn't be saving itself to the state object.
Is the problem mostly large codebases, or storing all of that in state? For example, I've got a half-finished Fiasco automation script which stores the playset tables as objects, but they're simply global objects in the script, not pushed into state. Each playset is 144 strings (each ~1 sentence) plus the boilerplate to get the object structure.
Further, if disabling a script tab reduces the memory footprint, my script setup has each playset's table data in a separate tab, making it easy to disable them individually. OTOH, if the VTT simply "hides" the disabled tabs at runtime, that wouldn't help any.
Brian said:
Riley D. said:
Scripts That Are Too Large, Usually "Databases"
There are people that are running 50,000+ lines of code in their campaigns. That might literally be more lines of code than it takes to run large parts of Roll20. The usual pattern I'm seeing here is with people trying to shoehorn "databases" into their scripts -- for example there's one floating around that is 50,000+ lines of code that is just a giant database of Pathfinder spells. On top of that, the database is being saved to the state object, so every 5 seconds the system is having to write something like 10MB of JSON data to the disk. Not super performant.
Please consider that when you have 10MB+ of script source code, that is a lot of data to move around, compile, and execute. In addition, your entire source code tree shouldn't be saving itself to the state object.Is the problem mostly large codebases, or storing all of that in state? For example, I've got a half-finished Fiasco automation script which stores the playset tables as objects, but they're simply global objects in the script, not pushed into state. Each playset is 144 strings (each ~1 sentence) plus the boilerplate to get the object structure.
Further, if disabling a script tab reduces the memory footprint, my script setup has each playset's table data in a separate tab, making it easy to disable them individually. OTOH, if the VTT simply "hides" the disabled tabs at runtime, that wouldn't help any.
Riley D. said:
Well, the *main* problem is the state saving object. That's what that's the only thing we're looking to put a hard limitation on. Does your Fiasco script have 50,000+ lines of objects? If so you might want to rethink doing that, if not that it's fine. Again these are extremes we are talking about.
~2,000 lines of actual script (not quite finished, but the end result will be close to that) and ~16,000 lines of playset object data using all currently available playsets (although the campaign currently only has one playset for testing, at 276 lines). So, around 36% of the Pathfinder script you found, when and if I complete it, although Bully Pulpit games occasionally releases additional ones. (They used to have a playset of the month thing going, but that appears to have stopped.)
Riley D. said:
But you would only have one playset script enabled at once? That would be fine. 18,000 lines total is *probably* okay as long as it's not being saved to the state object. Again, if it's not taking 30 sec+ to load the script editor page, it's probably okay.
The original intent of the campaign includes some API commands to select the playset for a single game, which would necessitate all of the playsets being enabled. That would let people in the campaign hop online and run a game without my presence. However, if the "database" objects were an issue, I could simply trim off some of the automation, and require my presence, selecting the playset manually by enabling/disabling script tabs.
HoneyBadger said:
Guess I jumped the gun on my scripts prematurely. Most of them at least. Haven't tested the importers, but they only deal with 100'ish kb of data at a time and that data is then deleted from the token.
Riley D. said:
HoneyBadger said:
Guess I jumped the gun on my scripts prematurely. Most of them at least. Haven't tested the importers, but they only deal with 100'ish kb of data at a time and that data is then deleted from the token.
Yeah the importers may be an issue if people abuse them (see my post up-thread on that), but I don't think any of your others are a problem at all.
Aaron said:
Regarding the setInterval()/setTimeout() running even when no one is in the game, is there a way from the API to detect that no one is connected and shut them down? Something like on('suspend:campaign',...) or something on the campaign object?