Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: php, js i c++ - wyświetlanie czasu
Forum PHP.pl > Forum > PHP
gulgul
Witam,
mam takowy problem:

program napisany w c++ (początkowo exe potem na linuxie) liczy czas oraz za pomocą socketów sterowane jest jego zatrzymywanie, wznawianie i resetowanie. Komendy start, stop, resume są aktualizowane w bazie mysql.

Ja chciałbym by na stronie WWW był wyświetlany ten czas(odświeżany co 1s).

Jak to zrobić by przeglądarka wiedziała kiedy czas jest zatrzymywany i wznawiany oraz by nie trzeba było co 1s uruchamiać AJAX sprawdzający MYSQL bo to zamula strasznie system.

z góry dziękuję za odpowiedź
CuteOne
Temat rzeka smile.gif o którym pisano już nie jeden artykuł
- google -> duplex connection, polling, long polling, node.js, websockets, tornado web server itp. itd... naprawdę sporo tego smile.gif
gulgul
wielkie dzięki

to może teraz tak:
co z tego najlepiej użyć ze względu na wydajność ale też łatwość implementacji?
CuteOne
jeżeli masz serwer na linuxie i znasz podstawy JS to node.js lub coś bardziej trywialnego - ajax + long polling
gulgul
kurcze,
próbuję znaleźć gdzie jakoś przystępnie opisany poolling i kicha.

możesz coś polecić?

najchętniej znalazłbym coś co:
1. sprawdzi czy nastąpiła zmiana wartości w MySQL (tylko by mało obciążało)
2. uaktualni wartość w JS

pomożesz?
CuteOne
Serwer powinien wyglądać mniej więcej w ten sposób:
Kod
#nieskończona pętla
   #pobierz z bazy informację czy coś się zmieniło

   #nic się nie zmieniło a czas pollingu jeszcze się nie skończył, kolejny przelot pętli
  
   #jeżeli dane zostały zmienione wysyłka danych do klienta np. poprzez json i zatrzymanie pętli

   #jeżeli czas pollingu został przekroczony zatrzymanie pollingu i wysłanie do klienta np. false

   #jakiś sleep żeby skrypt nie zabierał całej mocy obliczeniowej
#koniec pętli

To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.