User:Babbage Linden/Office Hours/2009 03 18

From Second Life Wiki
Jump to navigation Jump to search

Transcript of Babbage Linden's office hours:

 Topics
 * MONO scheduler will change. If you using memory nealy 64K,
   you should check your script on Preview Grid. LINK
 * Script memory limit per percel, per avatar. LINK
[3:59] Babbage Linden: thanks for coming

[3:59] Babbage Linden: i moved my office hour to 3AM SLT last week

[3:59] Roberto Salubrius: geez it's 5am here but good to know

[3:59] Babbage Linden: and then managed to miss it this week due to UK daylight saving not happening yet

[4:00] Babbage Linden: it's 11AM in brighton where I'm based

[4:00] Susan Whizenhunt laughs

[4:00] Babbage Linden: which is the best time for me as I don't have meetings with the US lindens until the afternooon

[4:01] Nock Forager: Timezone difference is one of big problem in SL :)

[4:01] Susan Whizenhunt: I've never met a Linden before, so I'm kind of in awe

[4:01] Babbage Linden: yes, this time is probably bad for most us residents

[4:01] Babbage Linden: but hopefully will be convinient for some people

[4:02] Susan Whizenhunt: Or it could be that I haven't had coffee yet

[4:02] Babbage Linden: so, normally i talk about what we've been up to regarding scripting

[4:02] Babbage Linden: and what our plans are

[4:02] Roberto Salubrius: good

[4:02] Babbage Linden: and then we talk about any scripting or technology issues people would like to discuss

[4:03] Babbage Linden: so, the biggest thing that happened this week is that the new mono scheduler past internal QA

[4:03] Roberto Salubrius: ohhhhhh

[4:03] Roberto Salubrius: care to share the ins and outs and implications

[4:03] Roberto Salubrius: or what can we expect

[4:04] Babbage Linden: the plan is that we will deploy that code to the beta grid after the 1.26 server release

[4:04] Babbage Linden: it's a set of bug fixes really

[4:04] Roberto Salubrius: now new limitations that we should be aware of ?

[4:04] Babbage Linden: previously it was possible to exploit the scheduler to get long time slices

[4:05] Babbage Linden: that should now be fixed

[4:05] Babbage Linden: also, it was possible to temporarily use more than 64K with mono scripts within a time slice

[4:06] Roberto Salubrius: mmm

[4:06] Roberto Salubrius: do you think that that might break content ?

[4:06] Babbage Linden: yes, it will, that's why we're running a beta

[4:07] Babbage Linden: so that residents can test their scripts

[4:07] Babbage Linden: scripts that are most often affected are those which use list operations like this

[4:07] Babbage Linden: l = llListSortList(l);

[4:08] Babbage Linden: during the evaluation of that expression there are 2 lists

[4:08] Babbage Linden: the copy passed to llListSortList

[4:08] Babbage Linden: and the current value of l

[4:08] Babbage Linden: after the expression there is only 1 list, l

[4:08] Babbage Linden: the copy passed to the function is freed

[4:08] Babbage Linden: previously you could get away with this

[4:09] Babbage Linden: but the new scheduler checks whenever a script might use too much memory

[4:09] Babbage Linden: the advantage of this is that scripts will no longer be affected by scheduler changes

[4:09] Babbage Linden: but when we make this change there will be some scripts that break

[4:09] Babbage Linden: so, anyone who pushes the limits of script memory in mono

[4:10] Roberto Salubrius: ListRandomize, ListFindinList ? those will be affected ?

[4:10] Babbage Linden: and uses long lists or strings as arguments to functions should be checked

[4:11] Babbage Linden: any scripts containing function calls which take strings or list parameters might be affected

[4:12] Babbage Linden: all scripts which run ok on the LSO VM should be fine

[4:12] Babbage Linden: but scripts that specifically take advantage of the extra memory mono provides might be affected

[4:12] Babbage Linden: it's unfortunate that we're having to make a change which might break content

[4:13] Babbage Linden: but hopefully this will be a one off

[4:13] Roberto Salubrius: mmm that worries me, not because I have done it "explicitly" but since I don't check ram as often it might hurt some content

[4:14] Babbage Linden: then i encourage you to check your scripts on the beta grid when we get the code there

[4:14] Roberto Salubrius: yea good to know I hope you make a big announcement

[4:14] Babbage Linden: we will make sure we communicate it widely closer to the time

[4:14] Babbage Linden: and we'll make sure we run the beta for a good while so people have time to check their code

[4:15] Babbage Linden: these changes won't make it on to the main grid until 1.27 server at the earliest

[4:15] Roberto Salubrius: will there be "brustable" moments

[4:15] Babbage Linden: ?

[4:16] Roberto Salubrius: meaning that if a script goes over 64K

[4:16] Roberto Salubrius: for a small period of time

[4:16] Roberto Salubrius: it can burst to 65K for instance

[4:16] Roberto Salubrius: then go back to the original 64K ?

[4:17] Babbage Linden: memory can only be tested when the script is not running

[4:17] Babbage Linden: but what happens now is that the script will yield whenever it might have gone over 64K

[4:18] Babbage Linden: whereas before the script would yield at the end of it's time slice

[4:18] Babbage Linden: and if you had dropped back down below 64K by then, you got away with using more than 64K

[4:18] Babbage Linden: but that meant if anything changed to change when your script yielded

[4:18] Babbage Linden: you might stop being lucky and so run out of memory

[4:19] Babbage Linden: these changes decouple scheduling and memory accounting

[4:19] Babbage Linden: which means that if we need to change the scheduler in future

[4:19] Babbage Linden: we won't break scripts

[4:20] Roberto Salubrius: mmm well I guess we have to check then

[4:20] Babbage Linden: yes

[4:20] Babbage Linden: sorry for the extra hassle

[4:20] Babbage Linden: it's the right thing to do in the long run

[4:20] Babbage Linden: and it's best to do it now

[4:21] Babbage Linden: when only 10% of scripts are mono

[4:21] Babbage Linden: than when 90% of scripts are mono

[4:21] Roberto Salubrius: do you have a percentaje of the ram that people get to use

[4:21] Roberto Salubrius: I mean

[4:21] Roberto Salubrius: do you have a number and say ok some people go up to 65K

[4:21] Roberto Salubrius: or something like that ?

[4:22] Roberto Salubrius: I am going to the fact that is it possible to change the scheduler and while you are at it give us more ram

[4:22] Babbage Linden: yes, that's possible

[4:22] Babbage Linden: i'd like to see how many scripts are affected first

[4:23] Roberto Salubrius: that will allow a change for the scheduler, and well not break any content

[4:23] Siann Beck: So long as your script isn't using, say, 128k :)

[4:23] Roberto Salubrius: well it's good to know you are considering it

[4:24] Babbage Linden: there is a separate project we're working on which we limit script memory based on parcel ownership

[4:24] Roberto Salubrius: the problem is that we have no idea of how much ram a script might be using... or what is the real limit on the scheduler right now

[4:24] Babbage Linden: and give avatars and allowance for attachments

[4:24] Babbage Linden: which will work like prim limits

[4:25] Roberto Salubrius: so limit ram and or script time per avatar

[4:25] Roberto Salubrius: and per parcel ?

[4:25] Babbage Linden: yes

[4:26] Babbage Linden: when scripts are running in world, they will request memory from the parcel's script memory pool

[4:26] Babbage Linden: when scripts are attachments, they will request memory from the avatar's script pool

[4:26] Roberto Salubrius: mmmm.... I guess you guys are studing what an average avatar uses right now, add some and then limit up there.

[4:27] Siann Beck: Wouldn't you have a problem then of a script working in some places but not others? How do you communicate that effectively to non-techie customers?

[4:27] Babbage Linden: if the memory is not available, scripts won't rez

[4:27] Babbage Linden: the idea of having a constant size avatar pool is that if you can attach an object, it will work wherever you go

[4:28] Babbage Linden: with land pools, the process will work the same as with scripts

[4:28] Babbage Linden: instead of being told you don't have prims available, you will be told you don't have script memory available

[4:28] Siann Beck: Right, but if I'm selling a script or a scripted object, how do I tell prospective buyers, "This may or may not work on your parcel".

[4:28] Nock Forager: hmhm

[4:29] Roberto Salubrius: I really think that will make a lot of people angry

[4:29] Babbage Linden: you will need to sell it as a 6 prim, 16KB object

[4:29] Babbage Linden: people are widely aware of prim limits

[4:29] Siann Beck: Sure, but not memory limits.

[4:29] Roberto Salubrius: babbage so are we going to get the thing we have asked for a long time, to get to know the "script rendering cost" and now "memory cost" of each script ?

[4:30] Babbage Linden: "memory limits are like prim limits: you get them with your land"

[4:30] Babbage Linden: yes

[4:30] Babbage Linden: the first phase is to do the accounting, to work out how much memory scripts on avatars and parcels are using

[4:30] Babbage Linden: the next phase is to make that visible

[4:31] Babbage Linden: the final phase is to enforce it

[4:31] Siann Beck: And what happens when you implement it, and someone's existing content suddenly is over the memory limit?

[4:31] Babbage Linden: so, there will be a long period where you will be able to see how much memory is being used on your parcel

[4:31] Siann Beck: And they come screaming to the developer?

[4:31] Roberto Salubrius: Babbage I mean from your POV and me being a system adminstrator also and a RL programmer I understand, why this is being implemented

[4:32] Roberto Salubrius: or being looked at

[4:32] Babbage Linden: and if you're over you'll be able to reconfigure your land

[4:32] Roberto Salubrius: but from the other side of the fence, as a user, I see this as a possible form of mayhem

[4:32] Babbage Linden: the reason this is being worked on is that currently you can use as much memory as you like for scripts

[4:32] Babbage Linden: where regions have lots of scripts running, they cause simulators to swap

[4:33] Babbage Linden: which destroys the performance of all regions running on that simulator host

[4:33] Babbage Linden: in order to avoid lag we need to limit the size of the simulator processes

[4:33] Roberto Salubrius: but your virtualization system ... that already does not implement limits on the simulator usage ?

[4:34] Babbage Linden: it only enforces per script limits currently

[4:34] Babbage Linden: which is both annoying (because you can't make a big script)

[4:34] Babbage Linden: and useless (because you just add more scripts, memory usage is not limited)

[4:35] Babbage Linden: once we have parcel and avatar memory pools we can actually limit script memory usage

[4:35] Babbage Linden: (which stops the simulators swapping)

[4:35] Babbage Linden: and we can allow scripts to use more memory

[4:35] Roberto Salubrius: ok so the core of the issue was a problem implementing the virtualization when SL was convieved

[4:35] Babbage Linden: we could add library calls which request more memory for a script

[4:35] Roberto Salubrius: concieved

[4:36] Babbage Linden: yes, the LSO memory limit made it easy to implement scripts that can move around between simulators

[4:36] Babbage Linden: you just ship a 16K block to another machine

[4:36] Babbage Linden: with Mono there is no reason to limit a script to any amount

[4:36] Babbage Linden: big scripts will take longer to ship to another machine

[4:36] Babbage Linden: but some scripts should just be able to sit in a region using 2MB of memory if that makes sense

[4:37] Babbage Linden: but, you can't allow scripts to just keep requesting memory

[4:37] Babbage Linden: you need some kind of overall simulator limit

[4:37] Siann Beck: I'm going to have to run. See you all later!

[4:37] Nock Forager: bye Siann

[4:37] Babbage Linden: and the fairest way to do that is based on parcel ownership

[4:37] Babbage Linden: bye siann

[4:38] Babbage Linden: thanks for coming

[4:38] Roberto Salubrius: I know this is an open forum to talk about things, and this are just "ideas" right now, but I have to say, that well scripting on SL has never been easy, we get a lot of limitations, but now to also limit ram usage, like this, will make things a real nightmare for us coders.

[4:39] Roberto Salubrius: ok now I have a question, as we all know scripts grow

[4:39] Roberto Salubrius: or can grow

[4:39] Roberto Salubrius: for instance a simple visitor counter

[4:39] Roberto Salubrius: when you rez it it has a requirement of 2K of ram

[4:39] Roberto Salubrius: then it logs 100 visitors

[4:39] Roberto Salubrius: and it needs 4K of ram

[4:40] Roberto Salubrius: what is the scheme planned for issues like that one ?

[4:40] Babbage Linden: yes, so what you'd like to be able to do

[4:40] Babbage Linden: is rez the script with a default allocation of memory

[4:40] Babbage Linden: then have a library call that can get the current memory usage

[4:40] Babbage Linden: and another that can ask for more memory if required

[4:41] Babbage Linden: instead of running out of memory at 16KB or 64KB, it can grow as needed

[4:41] Babbage Linden: only running out of memory when it can no longer ask for more

[4:42] Roberto Salubrius: ok so we are gonna have to implement something like malloc, and free for our scripts

[4:42] Babbage Linden: up to you

[4:43] Babbage Linden: most people will want to build objects that have a fixed memory and prim requirement

[4:43] Roberto Salubrius: how will that work with previous content that have no idea of memory managment and renders it all to the server side ?

[4:43] Babbage Linden: "this object needs 6 prims and 64KB"

[4:43] Roberto Salubrius: renders memory usage to the server side I mean

[4:43] Roberto Salubrius: ugh memory managment

[4:43] Babbage Linden: but others will want to allow dynamically growing scripts

[4:43] Babbage Linden: depends what you're building

[4:44] Babbage Linden: previous content will just use fixed amounts

[4:44] Babbage Linden: LSL scripts will need 16KB

[4:44] Babbage Linden: Mono scripts will need 64KB

[4:44] Babbage Linden: but for new scripts you will have much more flexibility

[4:44] Roberto Salubrius: and that will be set per prim or per script ?

[4:45] Babbage Linden: and not need to chop your script in half and use link messages every time you need another 16KB

[4:45] Babbage Linden: scripts will have a memory requirement

[4:45] Roberto Salubrius: ok

[4:45] Babbage Linden: parcels and avatars will have a memory pool

[4:45] Babbage Linden: in order to rez a script you need to have enough memory available in the pool to fulfil the requirement

[4:46] Babbage Linden: just like a prim limit

[4:46] Babbage Linden: but separate

[4:46] Babbage Linden: you might have a 1 prim object that needs 1MB

[4:46] Babbage Linden: or a 100 prim object that needs 16KB

[4:46] Babbage Linden: depends what you're building

[4:46] Roberto Salubrius: no I understand the implementation, I am worried about the implications of this

[4:46] Babbage Linden: if you want to find out how it will work, go and play with HTTP In

[4:47] Babbage Linden: which uses this system to ration public URLs

[4:47] Roberto Salubrius: yes I worked with it already

[4:47] Babbage Linden: and was a good first resource to limit as it is a new resource

[4:47] Babbage Linden: so, you know how this is going to work already then

[4:47] Roberto Salubrius: I posted to the jira that how it was implemented I was able to render a sim with 0 http-in connections

[4:47] Roberto Salubrius: with one script

[4:48] Roberto Salubrius: i hogged all the connections

[4:48] Roberto Salubrius: for the sim ( when peri asked us to do the closed beta test )

[4:48] Babbage Linden: which is much better than being able to rez 100,000 scripts making the sim swap and completely unusable for all users

[4:48] Babbage Linden: ;-)

[4:48] Babbage Linden: which happens currently

[4:49] Babbage Linden: not having limits doesn't work

[4:49] Babbage Linden: so we need to have limits and make them as workable as possible

[4:49] Babbage Linden: you could only hog all the connections as you were using a sandbox presumably

[4:49] Roberto Salubrius: ok I insist I do understand it all form a system admin POV, but as a user, I think it will be hard on people

[4:49] Babbage Linden: and also, you couldn't hog all the connections for all the avatars

[4:49] Nock Forager: Do you have in your mind the limitation numbers? KB/sqm or something.

[4:49] Roberto Salubrius: specially non techs

[4:50] Babbage Linden: we're currently analysing the script usage across the grid

[4:50] Babbage Linden: to come up with numbers that will break as little content as possible

[4:50] Roberto Salubrius: remember when http-in was first first implemented the first draft it had the connection limit based on the sim not on the parcel

[4:50] Babbage Linden: there will be edge cases were people are running 2000 scripts on a 512m parcel of land

[4:51] Babbage Linden: those will stop working

[4:51] Roberto Salubrius: ok

[4:51] Babbage Linden: but we should be able to make nearly all parcels work fine

[4:51] Nock Forager: 2000 on 512sqm lol

[4:51] Babbage Linden: by picking the right numbers

[4:51] Babbage Linden: and actually, running tons of scripts on a tiny parcel is griefing all the other parcel owners anyway

[4:52] Roberto Salubrius: yes of course

[4:52] Babbage Linden: i agree that this will require lots of communication to get right

[4:52] Babbage Linden: but ultimately we need to do it

[4:52] Roberto Salubrius: and there are some attachments that will bring a sim down to it's knees like some multitools out there

[4:52] Babbage Linden: and second life will be a better place because of it

[4:52] Babbage Linden: exactly, those will stop rezzing

[4:53] Babbage Linden: but again, we will pick numbers for avatar pools that will mean that most people can continue to use the scripted attachments they currently use

[4:53] Babbage Linden: only extreme edge cases should be affected

[4:53] Roberto Salubrius: ok

[4:53] Babbage Linden: and if you set your land to not allow other people to rez objects

[4:53] Roberto Salubrius: well I guess we will have enough time on the beta grid to test it

[4:54] Babbage Linden: then you should be able to set up a parcel with a set of scripts

[4:54] Babbage Linden: and it will just keep working

[4:54] Babbage Linden: without swapping

[4:54] Babbage Linden: regardless of who turns up[

[4:54] Babbage Linden: yes, there will be lots of testing time

[4:54] Susan Whizenhunt: I'm not sure if this is off-topic, but is memory usage the main cause of lag? Or are there ways in which a simple script can be as taxing on a SIM?

[4:54] Babbage Linden: and lots of communications

[4:54] Babbage Linden: CPU time is already limited

[4:55] Babbage Linden: a sim will only run scripts for a few ms per frame

[4:55] Babbage Linden: but, when you have tons of scripts in memory

[4:55] Babbage Linden: and cause the simulator host to swap, everything lags

[4:55] Babbage Linden: for all regions running on that host

[4:55] Babbage Linden: making servers touch their hard drives is horrible for performance

[4:56] Roberto Salubrius: Susan you can basically crash a sim on 1 script

[4:56] Babbage Linden: so, if you have scripts that sit in tight loops doing complex calculations

[4:56] Babbage Linden: they will slow each other down

[4:56] Babbage Linden: but non-script performance should remain fine

[4:56] Babbage Linden: if you have lots of scripts filling memory

[4:57] Babbage Linden: then the performance of every aspect of every region on the host will be affected

[4:57] Babbage Linden: ok, we're just about out of time

[4:57] Babbage Linden: and i need to get back to work

[4:57] Babbage Linden: thanks for coming everyone

[4:57] Roberto Salubrius: one last question

[4:58] Roberto Salubrius: when will we see httpd in

[4:58] Roberto Salubrius: on the main grid

[4:58] Babbage Linden: 1.27

[4:58] Babbage Linden: ok, i'm off

[4:58] Babbage Linden: hope to see you next week

[4:58] Nock Forager: THanks for the meeting Babbage.

[4:58] Susan Whizenhunt: Thanks

[4:58] Roberto Salubrius: thx

[4:58] Roberto Salubrius: have a nice day

[4:59] Roberto Salubrius: geez that only wories me

[4:59] Roberto Salubrius: or you guys as well ?

[5:00] Nock Forager: Need time to educate others...