chat management

alexho

New Member
Reaction score
0
i have developed a chatroom running with js/ajax on client, and php for server side storing data in mysql. My only real issue is the method i use in having registered (site members) being logged in right as they enter the page -- And being logged out when they leave; thus being added/removed from the table...

possible methods for this that i tried but dont work well for me are using onload/onunload which are not really reliable enough.


i though about using Java as some applet in the page for monitoring and passing data more easily, but im not sure what to use and i haven't used java that much so.. For the chat I need a better way of managing the users IN real time, more reliably....

or possibly a timeout using php time() recoreded last updated ping greater than a value then user is assumed logged out

does anybody have experience in creating chatrooms? or have any knowledge of Java and possible implements to this which could guide me to the right direction?
tyvm :)
:rolleyes:
 

enouwee

Non ex transverso sed deorsum
Reaction score
240
You really shouldn't rely on the client to be nice and tell you it's leaving. Just like the IRC servers, keep track of the last data pushed/pulled to the browser and remove the client when it's been idle longer than a grace period.

Or join the "ultimate" chat theory thread [THREAD=110587]here[/THREAD].
 

alexho

New Member
Reaction score
0
what i have is 2 divs 1 for users 1 for content. within the content of user div i add new divs with ids of the users. so dynamically when users leave it removes that user from all clients in the parent user div.
^^^ that is what i was hoping to do.....

//client idle afk w/e kick using ajax
in the client i make a timeout of 60*60 seconds every sent post made it counts off to kick them from the chat idle users who just sit there will eventually get kicked out.

now for users who leave in any way disestablished from the server:
in the request i send, suppose i have a variable user=test

server get:
for kicking idle grace periods..
mysql find user test in table get last activity/ping currenttime-lastactivitytime()

if the sent request grace period is every second and lastactivity is > grace period then user removed from chat. and it sends a bit of data to all clients marking user id to be removed from the users div.

this is doing it for all connected clients--alot of load it would seem

how do i do this server side effectively? checking whole user in chat table for last ping time and removing all users > grace period its a bit cumbersome

i will not rely on the client for anything but data retrieval, that was a test workaround.
 

enouwee

Non ex transverso sed deorsum
Reaction score
240
this is doing it for all connected clients--alot of load it would seem

how do i do this server side effectively? checking whole user in chat table for last ping time and removing all users > grace period its a bit cumbersome

i will not rely on the client for anything but data retrieval, that was a test workaround.

Through a paradigm change: by pushing data to the connected clients and not having them repeatedly poll for new things. If it works for the big ones(TM), it should be fine for you.

I posted a link to a sample implementation in the other thread, here's another blog post with a nice time diagram.

You can further improve performance by getting rid of the database, which is entirely useless, given the ridiculously little data you're managing. I'd run an non-blocking application that handles the "persistent" client streams and keeps the whole data (chats, members) either in-memory of MMAPed to disk.

PHP won't be a good choice though for such an implementation. I'd rather rely on a heavy duty server (written in C/C++ or Java). See CometDaily for more information.

Not the "easy-to-implement" answer you expected? Sorry, this is the price to pay for improving server-side performance.
 

alexho

New Member
Reaction score
0
thanks, and for the diagram.
i didnt expect it to be easy to implement, but for my situation i guess it is ok and best i keep it simple. it is more of a simple chatroom, with 1 room. i will have to put more boundaries and limits on it. but if my situation demanded a very active user base then id have to and it wouldn't be an easy implementation. ill have to do with what i have. :p
 
General chit-chat
Help Users
  • No one is chatting at the moment.
  • WildTurkey WildTurkey:
    is there a stephen green in the house?
    +1
  • The Helper The Helper:
    What is up WildTurkey?
  • The Helper The Helper:
    Looks like Google fixed whatever mistake that made the recipes on the site go crazy and we are no longer trending towards a recipe site lol - I don't care though because it motivated me to spend alot of time on the site improving it and at least now the content people are looking at is not stupid and embarrassing like it was when I first got back into this like 5 years ago.
  • The Helper The Helper:
    Plus - I have a pretty bad ass recipe collection now! That section of the site is 10 thousand times better than it was before
  • The Helper The Helper:
    We now have a web designer at my job. A legit talented professional! I am going to get him to redesign the site theme. It is time.
  • Varine Varine:
    I got one more day of community service and then I'm free from this nonsense! I polished a cop car today for a funeral or something I guess
  • Varine Varine:
    They also were digging threw old shit at the sheriff's office and I tried to get them to give me the old electronic stuff, but they said no. They can't give it to people because they might use it to impersonate a cop or break into their network or some shit? idk but it was a shame to see them take a whole bunch of radios and shit to get shredded and landfilled
  • The Helper The Helper:
    whatever at least you are free
  • Monovertex Monovertex:
    How are you all? :D
    +1
  • Ghan Ghan:
    Howdy
  • Ghan Ghan:
    Still lurking
    +3
  • The Helper The Helper:
    I am great and it is fantastic to see you my friend!
    +1
  • The Helper The Helper:
    If you are new to the site please check out the Recipe and Food Forum https://www.thehelper.net/forums/recipes-and-food.220/
  • Monovertex Monovertex:
    How come you're so into recipes lately? Never saw this much interest in this topic in the old days of TH.net
  • Monovertex Monovertex:
    Hmm, how do I change my signature?
  • tom_mai78101 tom_mai78101:
    Signatures can be edit in your account profile. As for the old stuffs, I'm thinking it's because Blizzard is now under Microsoft, and because of Microsoft Xbox going the way it is, it's dreadful.
  • The Helper The Helper:
    I am not big on the recipes I am just promoting them - I use the site as a practice place promoting stuff
    +2
  • Monovertex Monovertex:
    @tom_mai78101 I must be blind. If I go on my profile I don't see any area to edit the signature; If I go to account details (settings) I don't see any signature area either.
  • The Helper The Helper:
    You can get there if you click the bell icon (alerts) and choose preferences from the bottom, signature will be in the menu on the left there https://www.thehelper.net/account/preferences
  • The Helper The Helper:
    I think I need to split the Sci/Tech news forum into 2 one for Science and one for Tech but I am hating all the moving of posts I would have to do
  • The Helper The Helper:
    What is up Old Mountain Shadow?

      The Helper Discord

      Members online

      No members online now.

      Affiliates

      Hive Workshop NUON Dome World Editor Tutorials

      Network Sponsors

      Apex Steel Pipe - Buys and sells Steel Pipe.
      Top