вторник, 28 июня 2011 г.

JavaME сдохла

Так можно сказать, если начать что-либо искать в сети по теме. 

На работе делаем приложение для мобильных устройств, в их числе и java ME. Была проблема с большой задержкой при Http запросах. Как и полагается система работает через Connector, т.е. соединение открывается методом Connector.open(url).

Потом из него открывается output или input stream.  После завершения работы потоки и соединение нужно обязательно закрывать, не то лимит будет исчерпан. На некоторых телефонах даже нормальное закрытие не помогает. Как я когда-то вычитал на форуме nokia нужно обнулить ссылки на потоки и соединение, затем вызвать Runtime.getRuntime().gc(). Затем Thread.sleep(50), т.е. включить сборку мусора и дать ему время (50 мс), чтобы он убрал за нами. И на большинстве нокий и самсунгов только после этого шаманства соединение возвращается в пул и приложение не будет зависать после 13 соединения (на всех телефонах, на которых была данная ошибка, объем пула составлял 13 соединений).

Со всей этой батвой приложение работает, но работает медленно. Данные скачиваются относительно быстро, а перед этим приложение долго простаивает, ожидая получить GPRS соединение.  Посовещавшись, решили попробовать сделать соединение через сокет. При старте приложения открывать сокет, гонять по нему данные к серверу и обратно, потом при завершении приложения закрываеть потоки и соединение. Пока вроде все получается, т.е. соединение открывается вызовом метода Connector.open("socket://127.0.0.1:9000); Открывается поток conn.openInputStream(). Открывается поток на запись conn.openOutputStream(); В него пишется запрос outputStream.write("GET / http/1.1\n\nHost:127.0.0.1"); Потом outputStream.flush(); Потом считываем с inputStream методом write. ... (Продолжение следует, наверное)

Первый подход к playframework.org

Удалось поработать с платформой play!. После питона с Django переход на Java оказался не таким ужасным благодаря возможностям play, а именно, компиляция кода на лету и возможность мгновенного наблюдения за результатом внесенных в код изменений и классный язык шаблонов. 

Проблему создал hibernate, в play 1.2 он представлен  версией 3.6, которая, как оказалось плохо работает с драйвером postgresql, если использовать иерархию классов на одной таблице. Короче, с play 1.2 не сраслось. Откатился на версию 1.0.3, в который включен hibernate версии 3.3.

Вторая проблема возникла, когда я к серверу попытался получить доступ по сокету. Он никак не хотел принимать мой запрос вида GET / http/1.1   Host: 127.0.0.1. Вопрос решился установкой модуля netty версии 1.0.6, который заменяет стандартный веб-сервер. Для этого в командной строке достаточно набрать play install netty-1.0.6  и запускать приложение с помощью команды play netty:run [название каталога с приложением внутри].