User:Zero Linden/Office Hours/2008 Jan 17

From Second Life Wiki
Jump to navigation Jump to search

Transcript of Zero Linden's office hours:

[8:43] Harleen Gretzky: Zero Linden's office hour
[8:43] Wyn Galbraith: Hello.
[8:43] Harleen Gretzky: Hi Zero
[8:43] Zha Ewry: In a Linden office, full of gearheads
[8:43] Teravus Ousley: greetings
[8:43] Zha Ewry: Hey Zero!
[8:43] Rex Cronon: u r where a tech meeting is supposed to take place
[8:43] Thoys Pan: hello zero
[8:43] Rex Cronon: hi zero
[8:43] Saijanai Kuhn: goood morning teacher
[8:43] Dr Scofield: hi zero
[8:43] SignpostMarv Martin: hi Zero
[8:44] Wyn Galbraith: Greetings Zero ;)
[8:44] Wyn Galbraith: You could join us on Squirrel's zero :)
[8:44] katalina Zerbino: what is an avatar?
[8:44] Arawn Spitteler rezzed a chair, to save on lag, by sitting on a physical object...
[8:45] Neas Bade: morning zero
[8:45] luckdog Enzo: the flags is nice,but how about my country,the flag of china.?
[8:45] Zero Linden: Sorry all
[8:45] Zero Linden: Was in an "engineering directors" meeting that was the only time it could be held this week
[8:45] Zero Linden: oy vey
[8:45] luckdog Enzo: thnx very much
[8:45] SignpostMarv Martin: yw
[8:45] Kerry Giha: Ah the life of meetings
[8:46] Zero Linden: Welcome to my office hours all
[8:46] Saijanai Kuhn looks alert (whats up with that?)
[8:46] luckdog Enzo: lol~its nice
[8:46] TomHa Zymurgy: hav a sit ;)
[8:46] Teravus Ousley figures it might be good to jump right in because of ~15 minutes less? :D
[8:46] Zero Linden: So, I had a wonderful face-to-face meeting with Adam Z. on Tuesday
[8:46] Zha Ewry: So.. If we don't have a topic Zero, I was going to pester you, merrciless ly, about the long poll, and how we plan to use it and such in the next round of stuff
[8:47] Zero Linden: He was in town - we ate Indian food
[8:47] Neas Bade: awesome
[8:47] Teravus Ousley: :D
[8:47] Zha Ewry pricks up her ears at Adam's name
[8:47] Saijanai Kuhn: Adam Z...
[8:47] Zha Ewry wonders if it was the same nice little Indian down the street from Zero's office
[8:47] Thoys Pan: Adam azure islands?
[8:47] Dr Scofield: LL going to switch to OpenSim... ;-)
[8:47] Zero Linden: He told me a bit about the way OpenSim runs the scripts in a separate script server
[8:48] Zero Linden: which seems much like the "script interface" we've been talking about at the last few meetings
[8:48] Zha Ewry nods
[8:48] Zha Ewry: Closely related in any case
[8:49] Thoys Pan goes brb (souptime in holland)
[8:49] Rex Cronon: "script interface" talk? i guess reading the transcripts would clear that.
[8:49] Zero Linden: As currently defined, it is pretty heavily reliant on .Net structures, and works via RPC, but it might serve as a model for a
[8:49] Zero Linden: open protocol there
[8:50] Zha Ewry nods
[8:50] Zero Linden ducks after realizing he's been remiss about the transcripts
[8:50] Zha Ewry: one would want a set of web service style notifcations for that
[8:50] Neas Bade: there is a latency problem with using web services on that interface
[8:50] Saijanai Kuhn has a pointer to zero's transcripts on teh AW Groupies page. Its loking barren
[8:50] Zha Ewry: Not web services, but web services mediated notifcatoin
[8:50] Neas Bade: you really want something fast and low latency
[8:50] Zha Ewry: pub/sub low level
[8:50] Zha Ewry: but, controlled by caps
[8:50] Neas Bade: ok, right
[8:51] Saijanai Kuhn: TCP?
[8:51] Zha Ewry: Which is, in general, going to be an issue with the whle long term design for things like managing any UDP/low level stuff in the protocol
[8:51] Dr Scofield: saijanai, this is the HTTP-and-HTTP-only camp
[8:51] Zha Ewry: Its all sort of "Well, we just send stuff on the cirucuits"
[8:52] Zero Linden: Well, lessee
[8:52] Zha Ewry: and the client hopefully swallows it
[8:52] Zero Linden: we've often assumed that hte Agent Domain and the Region Doain have to be addresable - that is
[8:52] Zero Linden: they are not behind NAT firewalls that don't allow incoming connections
[8:52] Zha Ewry nods
[8:52] Zero Linden: in that case, one can do pub/sub pretty easily with HTTP and caps
[8:52] Zha Ewry: But.. at what performance cost
[8:52] Catherine Pfeffer: (as long as there's no dependancy towards .net everything is fine... lol)
[8:52] Zero Linden: you do it by registring a cap that is the service you want events posted to (the sub)
[8:53] Dr Scofield grins
[8:53] Zero Linden: and then the generator of the event just needs to invoke all the registered caps when the event fires (the pub)
[8:53] Saijanai Kuhn is a mac user.Everything is .net already... isnt' it? ;-)
[8:53] Zha Ewry nods at Zero
[8:53] Zero Linden: a pub/sub aggrigator could be used
[8:53] Zha Ewry: Things like that feel right
[8:53] Zero Linden: I think, one might even be able to put a small amount of convention in those calls so that
[8:53] Catherine Pfeffer: (sorry didn't mean to troll... not really)
[8:53] Zero Linden: (which is always the trick to making pub/sub efficient, if I understand it at all)
[8:53] Zha Ewry: where we use the high level caps stuff to control the low level
[8:53] Zha Ewry: event flow
[8:54] Zha Ewry: And aboslutely, Zero
[8:55] Zha Ewry: There's a huge amount of work been done on how to let the low level stuff do a little bit of control. to keep from having to do the expensive operations
[8:55] Zha Ewry: What you want to avoid, is letting that get out of hand, tho
[8:56] Zero Linden: So - this leads into the event queue and long poll I think
[8:56] Zha Ewry nods
[8:56] Zha Ewry: The event queue, and the circuits, even
[8:57] Zero Linden: both of these are mechanisms to get the semantics of REST across a path that can't support it directly
[8:57] Saijanai Kuhn: and how that actually works. Serveral lindens have attempted to pour the knowledge into the head but its leaking
[8:57] Zero Linden: We could imagine other, lower latency paths, that still support the REST calls, but don't use an HTTP/TCP connection per request
[8:57] Zero Linden: surely there must be already something out htere that does this
[8:58] Zero Linden: other than, say, Pipelined HTTP, which has a host of problems
[8:58] Dr Scofield doesn't dare to mumble "xmpp"
[8:59] Zero Linden: well- but xmpp doesn't - there isn't a strong request/response correllation is there? and the addressing is - well, Baroque at best
[8:59] Dr Scofield: IQ message
[8:59] Zero Linden: but I imagine one could cast HTTP semantics into XMPP, and that is perhaps not so bad
[8:59] Dr Scofield: IQ is supposed to be suc
[8:59] Dr Scofield: sync
[9:00] Zero Linden: hmmm google doesn't turn up a link to anything like IQ message
[9:00] Neas Bade: it would be nice to not get too far ahead of ourself here, and actually have some sort of REST semantics before trying to cast it into something else :)
[9:00] Zero Linden: hehe
[9:00] Dr Scofield: you send IQ request and get a result back
[9:00] Dr Scofield: XMPP RFC
[9:00] Dr Scofield: s
[9:01] Zero Linden: well, Neas, one thing I think Zha is trying to be sure of is that all the styles of communication we are going to need can be covered
[9:01] Zha Ewry: Also.. I think there is a case to be made for building it as simply as possible, and seeing where we need more than what we can get from base http.
[9:01] Dr Scofield: xmpp message is async
[9:01] Dr Scofield: xmpp iq sync
[9:01] Zero Linden: oh oh - I see on IQ, sorry, thought it was a separate protocol
[9:01] Zha Ewry: And, yes, tha is on my list
[9:01] Neas Bade: zha, absolutly agreed
[9:01] Zero Linden: So, event queue
[9:02] Zero Linden: details? It is simple: the viewer can't be contacted via HTTP
[9:02] Zha Ewry: Its really easy, to convince yourself you're going to *need* a fancy new widget, when base http will do. Now, we know there will be cases where we want better, but I am far from sure anyuone knows the line between those and the http is good enough cases
[9:02] Neas Bade: I'd rather have us prove http won't work first before trying to do something else, instead of guessing that it won't up front for most things
[9:02] luckdog Enzo: there are still so many questions for HTTP or ohers .we should have a better way to resoulve it.and the first is the net speed.
[9:02] Zero Linden: so instead, we remember a list of everythign we would have liked to send to the viewer via HTTP as a sequence of events
[9:02] Dr Scofield: neas, pipelined HTTP is reinventing the wheel, i think
[9:02] Zero Linden: and give the viewer a cap for fetching the events
[9:03] Zero Linden: when the viewer invokes the cap, it gets a sequence number and a list of events
[9:03] Dr Scofield: polling
[9:03] Zha Ewry: Right. So, you pull on that instead
[9:03] Zha Ewry: and when it has nothing to say, it says 'Try again later"
[9:03] Zero Linden: the simulator holds those sent events on the side, since it doesn't know if the viewr actually got 'em
[9:03] Zero Linden: the next time the viewer invokes the cap, it includes the sequence number of the last set of events it got
[9:04] Zero Linden: the simulator says - if the number matches the events on the side, ditch 'em, 'cause they got there
[9:04] Zero Linden: if it doesn't match, it sticks them back on the front of the queue, 'cause they got lost
[9:04] Zha Ewry nods
[9:04] Zha Ewry: That process, then, is sort of lockstep?
[9:04] Zero Linden: lather - rinse - repeat
[9:04] Zero Linden: and then it bumps the sequence number and sneds the event queu again (moving them all aside)
[9:05] Zha Ewry: since the client asks
[9:05] Zha Ewry: Assumign a request doesn't get broken, we should see it just rachet up?
[9:05] Dr Scofield: hmmm...still think a bi-directional protocol would be better suited for that
[9:05] Zero Linden: yes, the sequence number just goes up each time
[9:05] Zero Linden: Dr. - so I agree
[9:05] Teravus Ousley wonders if there's a spec somewhere with the events that get put into EventQueueGet
[9:06] Zero Linden: but the barrier to implementing XMPP was high-
[9:06] Zero Linden: Teravus
[9:06] Zero Linden: the events are just an LLSD version of messages right now
[9:06] Teravus Ousley: ah
[9:06] Zha Ewry: As if they had been put on the UDP cirtcuit, Zero?
[9:08] Zha Ewry: .
[9:08] Rex Cronon: zero crashed?
[9:08] Zha Ewry wonders if Zero has crashed
[9:09] Zero Linden: the events have the form { message: m, body: b}
[9:09] Zero Linden: where b is the LLSD encoded message body
[9:09] Zero Linden: in theory, we were going to implement { request: r, body: b}
[9:09] Zero Linden: or rather { request: r, body: b, id: i }
[9:10] Saijanai Kuhn: there's something missing from that equation, though, Zero. When I send theack with the last event ID obtained, I get the same event with a new ID
[9:10] Zero Linden: which would be a REST semantics request expecting a respond during the poll
[9:10] Zero Linden: but that isn't spec'd or implemented
[9:10] Rex Cronon: shouldn't id be first?
[9:10] Saijanai Kuhn: do I need to close the connection and reopen it to stop getting the same event?
[9:10] Saijanai Kuhn: its ack/ID in LLSD format, Rex
[9:10] Zero Linden: Sai - I don't think so
[9:11] Saijanai Kuhn: OK, so I'm doing something wrong (as usual)
[9:11] Thoys Pan is back
[9:12] Zha Ewry wonders exactly how close to REST polling gets.. The event queue is full of events that don't have resources. I'm not suggesting that there is a good REST semantic, actually, just musing that it feels funny
[9:12] Saijanai Kuhn: you send the llsd-xml of ack and the id and it sends you back an llsd array of events
[9:12] Zero Linden: but the event set is sent as { id: n, events: [ ... ] }
[9:12] Zero Linden: the ack must be (body of the poll) { ack: n }
[9:12] Saijanai Kuhn: right
[9:12] Zero Linden: Zha - no, at present, the event queu does messages
[9:12] Teravus Ousley listens
[9:12] Rex Cronon: until a prototype is made, u can't be sure how bad or good this is
[9:13] Dr Scofield needs to go earlier today: RL avalanche training
[9:13] Dr Scofield: cu all
[9:13] Saijanai Kuhn: I send and receive stuff in the right format, but don't get what I expect. I'm either sending the wrong ID or not understanding
[9:13] Zero Linden: so, messages can be cast as POSTs to a /messages/<messagename>
[9:13] Rex Cronon: bye dr
[9:13] Zero Linden: where the requestor doesn't expect anything other than a null body resposne
[9:13] Zero Linden: messages are a degenerate REST request :-)
[9:13] Neas Bade: you'd still get a proper return code though, right?
[9:14] Neas Bade: 20x or 40x depending
[9:14] Zero Linden: No - the message system didn't have any semantics of return code at all
[9:14] Saijanai Kuhn: <llsd><undef /> ?
[9:14] Neas Bade: so you have no idea if the message was accepted?
[9:14] Zero Linden: some messages have the semantic of the sender knows if it was received or no
[9:14] Zero Linden: and the event queue supports that by, when it gets the ack, it tells all the senders that cared that the message was received
[9:14] Zero Linden: but that is all
[9:14] Saijanai Kuhn: this seemes an abuse of CAP
[9:15] Zha Ewry: Not really.
[9:15] Zha Ewry: The cap, is just saying "here is how you polll"
[9:15] Zero Linden: so it is like a REST request where the sender checks if it got any HTTP return code or not -- but doens't even look a thte code
[9:15] Thoys Pan: btw, for intrested people i opensourced the ircchantoslgroupbot -> http://code.google.com/p/sl-group-irc-gateway/
[9:15] Saijanai Kuhn: but if you send a message and don't know if it arrived...
[9:15] Zero Linden: Sai - no more like <llsd />
[9:15] Zha Ewry: Well, the poll, is outside the caps abstraction
[9:15] Zero Linden: !
[9:16] Zha Ewry: Thus, the comment, about resources
[9:16] Zha Ewry: If you wanted to do it all pure rest, you'd die making all those messages into REST resrouces
[9:16] Saijanai Kuhn: OK, I cansorta see that
[9:17] Zero Linden: well - internlly, in the viewer, we cast all of those events into /external/message/<message-name>
[9:17] Zha Ewry brushes signposts flag out of her face
[9:17] Zero Linden: (or some such), look up those resources and invoke POST on 'em with the body
[9:17] Saijanai Kuhn: so you can POST messages to EventQueueGet? or is that only with other caps?
[9:18] Zero Linden: there is a wild cared handler at /external/message/* that picks up any message that isn't implemented as an HTTPResponder
[9:18] Saijanai Kuhn: ah, ok. So thats the format for all CAPs other then EventQueueGet?
[9:18] Zero Linden: and turns around and looks up th emessage in the old message template system, finds the registered C++ function pointer, and calls it
[9:18] Zero Linden: doing the translation from LLSD to the old binary version on the fly
[9:19] Zero Linden would kill for a shared white board right now
[9:19] Zero Linden or even a non-shared one
[9:19] Rex Cronon: doesn't windows have that?
[9:20] Rex Cronon: oh, u mean in here
[9:20] Saijanai Kuhn: recalls one fo the IM services used ot have one but hasn't seenit lately
[9:20] Teravus Ousley: yeh, best way in here at the moment is to set up a vid stream
[9:20] Zero Linden: so - here's the path...........
[9:21] Zero Linden: Simulator wants to send message FooBar with {x:12, name: Baz} to the viewer
[9:21] Thoys Pan: zero, can notecards be created using NewFileAgentInventory?
[9:21] Arawn Spitteler suggests Zarf might market through Etch-A-Sketch.
[9:21] Zero Linden: it could send it via UDP, binary encoded, or it could send it via the event queue
[9:22] Zero Linden: if it does the later
[9:22] Zero Linden: then { message: FooBar, body: { x: 12, name: Baz } } gets added to the EventQueue for the agent
[9:22] Zero Linden: Now -
[9:22] Zero Linden: the simulator waits
[9:23] Zero Linden: at some point, the viewer invokes the cap for it's event queue that it was given long ago, when it connected to this simualtor
[9:23] Zero Linden: the viewer does a POST to the cap w/ { ack: undef }
[9:23] Thoys Pan: Zero, the cap NewFileAgentInventory is used for Image uploading and other assets, but would it work for notecards?
[9:24] Zero Linden: the simulator responds with a response of { id: 912, events: [ { message: FooBar, body: { x: 12, name: Baz } } ] }
[9:24] Zha Ewry: Is the undef everytime, or just the first?
[9:24] Zero Linden: The viewer gets that body, pulls it apart and makes the requests that the simulator would have made if it could have
[9:25] Zero Linden: (Zha - just the first time)
[9:25] Zero Linden: so the viewer does an internal POST to /external/messages/FooBar with a body of { x: 12, name: Baz }
[9:26] Zero Linden: that either lands at an HTTPResponder that handles the mssage, or routes to the old message handler with LLSD to binary translation
[9:26] Zero Linden: the next time the viewer polls, it invokes the smae cap with { ack: 912 }
[9:26] Zha Ewry suspects that Undef is what's killing Sai
[9:27] Zero Linden: so - there are two levels of REST going on here - the outer, done with caps, to enable getting the inner requests, tothe viewer
[9:27] Saijanai Kuhn: but the internal is all within the viewer. Thats how the SL viewer handles things. A new viewer, that doesn't know about the UDP, wouldn't be doing thigns that way
[9:27] Lena Franciosa: Hi everyone
[9:28] Wyn Galbraith: Hello Lena.
[9:28] Rex Cronon: jo
[9:28] Rex Cronon: i mean hi
[9:28] Zero Linden: Sai - sure it would - it just wouldn't bother implementing the connector back to the old call-back style of message handler, since it wouldn't have that
[9:28] Neas Bade: Zero: is there any mock up code to do any of this. I think I'm getting lost in the micro explanations and need some bits to make it all make sense to me
[9:28] Saijanai Kuhn: well it wouldn't be POSTing anything
[9:28] Neas Bade: like some python mock up or something
[9:29] Zero Linden: The new viewer would still have to contend with the fact that the simulator can't make an HTTP connection directly to the viewer
[9:29] Zha Ewry: I'd actually like a set of annotated flows, or such, and a simple pyhton that implements it
[9:29] Zero Linden: the viewer is behind NAT firewals
[9:29] Zero Linden: Neas - alas, this is all in C++ - though it is pretty simply C++
[9:29] Zha Ewry: Right. We have to asume the poor viewer is hiding behing a firewall, a NAT router, and a few buggy gateways
[9:29] Saijanai Kuhn: I send { ack: undef } to EventQueueGet
[9:30] Neas Bade: well, C++ is better than nothing
[9:30] Zero Linden: righ - and it doesn't have a stable IP address either!
[9:30] Saijanai Kuhn: I get back { message: FooBar, body: { x: 12, name: Baz } }
[9:31] Wyn Galbraith has to run to work y'll.
[9:31] Saijanai Kuhn: rather I get back the { id: 912, events: [ { message: FooBar, body: { x: 12, name: Baz } } ] }
[9:31] Wyn Galbraith: B-bye!!! :D
[9:31] Saijanai Kuhn: I send {ack:912} and get back
[9:31] Saijanai Kuhn: { id: 913, events: [ { message: FooBar, body: { x: 12, name: Baz } } ] }
[9:32] Linx Newt: aoummmmmm
[9:32] Linx Newt: hey hey :)
[9:32] Rex Cronon: bye wyn
[9:32] Lena Franciosa: hey linx
[9:32] Saijanai Kuhn: ack 913 gets back { id: 914, events: [ { message: FooBar, body: { x: 12, name: Baz } } ] }
[9:32] Thoys Pan: hello
[9:32] Linx Newt: c est une secte ?
[9:32] Saijanai Kuhn: so obviously I'm missing something
[9:32] Linx Newt: lol
[9:33] Zero Linden: Sai - here's the code
[9:33] Lena Franciosa: oui on va t'enroller
[9:33] Lena Franciosa: mdr
[9:33] Zero Linden: last
[9:33] Catherine Pfeffer: chut lynx
[9:33] Zero Linden shout: last
[9:34] Zero Linden: there
[9:34] Linx Newt: c quand le suicide collectif ? :)
[9:34] Lena Franciosa: ssh
[9:34] Catherine Pfeffer: SILENCE
[9:34] Zero Linden: so you can see that there is always an outter map of {id:, evnets:}
[9:34] Zero Linden: actually - I need to run too
[9:35] Zero Linden: sigh
[9:35] Zero Linden: thanks all for coming
[9:35] Rex Cronon: bye zero
[9:35] Zha Ewry: Zero, if we can ghet this a little more wrtten up