Nie jesteś zalogowany.
Jeśli nie posiadasz konta, zarejestruj je już teraz! Pozwoli Ci ono w pełni korzystać z naszego serwisu. Spamerom dziękujemy!
Prosimy o pomoc dla małej Julki — przekaż 1% podatku na Fundacji Dzieciom zdazyć z Pomocą.
Więcej informacji na dug.net.pl/pomagamy/.
Witam,
Mam problem z Javą 6, który występuje tylko na Debianie (tylko tu go znalazłem).
Debian GNU/Linux 6.0.5 (squeeze)
Java(TM) SE Runtime Environment (build 1.6.0_26-b03)
Podstawowe polecenie Thread.sleep() zatrzumuje wątak na kilkanaście razy dłuższy czas niż powinno.
Przykładowy kod:
try { System.out.println("start"); long t = new Date().getTime(); Thread.sleep(500); System.out.println("took: "+(new Date().getTime() - t)+" ms."); } catch (Exception x ) { x.printStackTrace(); }
Daje zawsze inny output, na przykład:
start took: 58006 ms.
A powinno dawać mniej więcej 500 ms
Podejrzewam, że to może być kwestia jakiś debianowych bibliotek.
Czy ktoś zna rozwiązanie tego problemu?
Offline
Offline
Tą analizę znam, ona wskazuje na różnice rzędu kilkunastu milisekund, co mi w ogóle nie przeszkadza.
U mnie kod zamiast wykonywać sie pół sekundy wykonuje się prawie minutę!
Pracuję na javie na Debianie od wielu lat i wcześniej tego problemu nie zauważałem. Zaczął on występować po ostatnim upgradzie pakietów, ale za nic nie potrafię ustalić, które to aktualizacje spowodowały.
Na pewno nie aktualizacja javy, bo sprawdziłem, że problem występuje na starszych wersjach także.
Offline
Commandline: apt-get -u upgrade
Upgrade: bind9-host:amd64 (9.7.3.dfsg-1~squeeze4, 9.7.3.dfsg-1~squeeze5), dnsutils:amd64 (9.7.3.dfsg-1~squeeze4, 9.7.3.dfsg-1~squeeze5), mysql-server:amd64 (5.1.61-0+squeeze1, 5.1.63-0+squeeze1), php5:amd64 (5.3.3-7+squeeze9, 5.3.3-7+squeeze13), libdns69:amd64 (9.7.3.dfsg-1~squeeze4, 9.7.3.dfsg-1~squeeze5), libapache2-mod-php5:amd64 (5.3.3-7+squeeze9, 5.3.3-7+squeeze13), mysql-server-core-5.1:amd64 (5.1.61-0+squeeze1, 5.1.63-0+squeeze1), php5-gd:amd64 (5.3.3-7+squeeze9, 5.3.3-7+squeeze13), libmysqlclient16:amd64 (5.1.61-0+squeeze1, 5.1.63-0+squeeze1), libisccc60:amd64 (9.7.3.dfsg-1~squeeze4, 9.7.3.dfsg-1~squeeze5), php-pear:amd64 (5.3.3-7+squeeze9, 5.3.3-7+squeeze13), liblwres60:amd64 (9.7.3.dfsg-1~squeeze4, 9.7.3.dfsg-1~squeeze5), libbind9-60:amd64 (9.7.3.dfsg-1~squeeze4, 9.7.3.dfsg-1~squeeze5), php5-pgsql:amd64 (5.3.3-7+squeeze9, 5.3.3-7+squeeze13), libisccfg62:amd64 (9.7.3.dfsg-1~squeeze4, 9.7.3.dfsg-1~squeeze5), libpq5:amd64 (9.1.3-2~bpo60+1, 9.1.4-1~bpo60+1), php5-mysql:amd64 (5.3.3-7+squeeze9, 5.3.3-7+squeeze13), host:amd64 (9.7.3.dfsg-1~squeeze4, 9.7.3.dfsg-1~squeeze5), php5-cli:amd64 (5.3.3-7+squeeze9, 5.3.3-7+squeeze13), libisc62:amd64 (9.7.3.dfsg-1~squeeze4, 9.7.3.dfsg-1~squeeze5), mysql-common:amd64 (5.1.61-0+squeeze1, 5.1.63-0+squeeze1), php5-common:amd64 (5.3.3-7+squeeze9, 5.3.3-7+squeeze13), mysql-server-5.1:amd64 (5.1.61-0+squeeze1, 5.1.63-0+squeeze1), mysql-client-5.1:amd64 (5.1.61-0+squeeze1, 5.1.63-0+squeeze1)
End-Date: 2012-07-02 02:23:14
Zdaje mi się, że jeszcze jakieś pakiety były aktualizowane, ale nie mam tego w logach apt.
// jeśli masz coś do dodania, edytuj posta zamiast pisać kolejnego pod swoim własnym — ArnVaker
Offline
Po pierwsze, to zaktualizuj javę - skoro nie działa teraz, to działać najprawdopodobniej nie będzie później, a zyskasz nowszą wersję (bodaj 1.7). Dodajesz repozytorium:
deb http://www.duinsoft.nl/pkg debs all
I wykonujesz:
sudo aptitude update && sudo aptitude purge sun-jave6-bin sun-java6-plugin sun-java6-jre && sudo aptitude install update-sun-jre && sudo aptitude clean
Próbowałeś zatrzymać czymś innym, niż thread.sleep?
Czy w rachubę wchodzi zmiana sun-java6-XXX na np icedtea?
Offline
Może fakt, że czasy są dziwne. Odpalałem ten program i miałem zazwyczaj wynik 500ms, czasem 501ms. Co do JDK, osobiście nigdy nie korzystam z paczek. Polecam ściągnać archiwum ze strony oracle, rozpakować, ustawić JAVA_HOME, dodać do PATH, można chyba nawet do alternatyw debianowych. Z paczkami bywa różnie, no i najlepiej jak najnowsza wersja.
Offline