FAQ |
Kalender |
2013-01-05, 16:37 | #1 | ||
|
|||
Medlem
|
Om jag typ har ett ett ställe där man kan skriva med varandra. låt oss säga en chat.
Då har jag med ajax kanske varje sekund kallat på ett skript som gjort en fråga till databasen och hämtade de senaste 10 insatta radera. Men då har ja funderat på om man kan vi varje ny rad man skriver så skriver man samma sak till en fil, chat.txt och sen med ajax hämtar man innehåll från chat.txt varje sekund. Det borde väl vara mycket lättare, alltså inte lika krävande? Tänker ja rätt? |
||
Svara med citat |
2013-01-05, 17:26 | #2 | ||
|
|||
Klarade millennium-buggen
|
Det blir nog helt fel för då har du ett extra steg och dessutom är inte chat.txt unikt för varje användare elle aktuellt, så det verkar inte vara någon bra idé.
Du skulle behöva kalla filen chat[user123].txt, chat[user124].txt, chat[user125].txt... och därmed få tusentals små filer på disken som du måste rensa bort. Databasen är ju orginalet av informationen så du behöver hämta den därifrån. Däremo skulle du kunna kolla om det finns en ny post i databasen med en tidstämpel som är senare än den när du senast hämtade texterna från databasen. Om det fins nya postningar så slår du en hämtningsfråga, annars låter du texten på skärmen ligga kvar oförändrad. Senast redigerad av Conny Westh den 2013-01-05 klockan 17:35 |
||
Svara med citat |
2013-01-05, 17:44 | #3 | ||
|
|||
Medlem
|
det behöver inte vara unikt :P det ska inte vara precis som en chat. tänk dig ett forum med en tråd.
|
||
Svara med citat |
2013-01-05, 18:05 | #4 | ||
|
|||
Flitig postare
|
En bättre teknik att göra detta på är ju att använda push, inte pull som ajax gör.
Titta t.ex på http://meteor.com |
||
Svara med citat |
2013-01-05, 19:11 | #5 | ||
|
|||
Flitig postare
|
Det funkar ju att använda ajax. Fördelen är väl att det går snabbt att göra. Nackdelarna är däremot rätt många. Men kan man leva med nån sekunds försening och inte har så många användare så funkar det ju helt ok.
Hänger bara hårdvara och bandbredd med... Kan man ju alltid ha fler användare. Men det är inte optimalt. Men för en sida med få besökare funkar det fint. Blir det fler besökare kan man ju öka tiden mellan uppdateringarna om man kan leva med det. Räknar du med många användare så googla "node.js" t.ex finns en del olika system som använder push istället precis som CotopaXi sa. Jag hjälper en chatt ibland som använder ajax... Runt 200 inne samtidigt funkar helt ok. Men beror ju som sagt helt och hållet på hårdvara och bandbredd. |
||
Svara med citat |
2013-01-05, 20:59 | #6 | ||
|
|||
Medlem
|
node.js tycker jag ser helt fantastiskt ut men jag har haft en jäkla tid att försöka installera det och sen köra. Det funkar inte :/.
Men mitt sätt som ja beskrev det gör ju att på varje request så hämtar en innehål ur en fil och inte en fråga till databasen. Det borde väl vara såååå mycket snabbare? |
||
Svara med citat |
2013-01-05, 21:27 | #7 | ||
|
|||
Flitig postare
|
Nja, är mer eller mindre de samma. Handlar mer om datamängd då. Databaser är snabba.
Däremot får du se upp så att du inte ställer till det när det skrivs i filen. Så inte två försöker skriva samtidigt. Dvs lås filen, öppna och skriv, spara filen och sen går det att skriva i filen igen. |
||
Svara med citat |
2013-01-06, 10:52 | #8 | ||
|
|||
Klarade millennium-buggen
|
Citat:
|
||
Svara med citat |
2013-01-06, 11:03 | #9 | ||
|
|||
Medlem
|
ingen aning om vilken backendteknologi du kör men om du vill bygga en chat och kör .NET så kika på SignalR. Här är en site byggd i SignalR http://jabbr.net/
|
||
Svara med citat |
2013-01-06, 11:50 | #10 | ||
|
|||
Administratör
|
Citat:
Använder du en push-teknologi istället så kommer en ny kommentar att pushas ut direkt till de andra i chatten och därmed inte behövas hämtas från databasen annat än om en ny användare ska få gammal chat-data (även här kan man eventuellt behålla en array i node.js som man skickar till nya klienter). Måste du tvunget använda pull så skulle jag dock göra mig av med text-filen, du får en fördröjning på upp till 1.99s om reload och text-fil är max out of sync. Och om du vill halvera den fördröjningen genom att skriva alla uppdateringar direkt till text-filen så finns en viss risk att du korrumperar text-filen. Istället för text-filen borde du isåfall fundera över antingen en cache (memcache, apc etc) eller byta till en mycket lättare databas-lösning (se t ex Redis, Membase). Om du gör detta så kommer ditt val av pull att ge dig en första bottleneck i CPU eller RAM vid ditt dynamiska språk som PHP/Ruby/vadsom (förutsatt att du använder en bra webbserver). Men som redan tidigare föreslagits, push är absolut bäst.
__________________
eldefors.com - Personlig (teknik)-blogg |
||
Svara med citat |
Svara |
|
|