Thursday, June 25, 2009

JPA в Google App Engine

Як відомо, робота зі стореджем в google app engine зроблена через JDO i JPA. В якості імплементації цих технологій google вибрав DataNucleus. Так от, якщо з JDO наче все більш чи меньше все працює, то з підтримкою JPA не все так добре. А саме, якщо у вас є параметризований запит і ви очікуєте отримати колекцію об'єктів, то, скоріше за все, у вас нічого не вийде. Щоб отримати колекцію з результатами, як правило, визивається javax.persistence.Query.getResultList(). Реалізація цього методу знаходиться у класі org.datanucleus.jpa.JPAQuery. Так от в момент виконання запиту до бази, ця реалізація замість того щоб передати список параметрів зі значеннями. передає null - query.executeWithMap(null). Ну і ви відповідно отримуєте NullPointerException.

Saturday, May 9, 2009

Помилки в логах JBoss

Досить цікава ситуація виникла, коли спробував підняти solr на JBoss. При старті JBoss почав в логи сипати кучу повідомлень про помилки. Після читання вікі та сорців solr виявилося, що solr в якості логера використовую jdk logger, який по дефолту всі повідоплення відправляє в консоль (sys.err). А JBoss, який використовує lo4j, в свою чергу перехоплює всі звернення до системних потоків, приводить їх до формату lo4j і ставить рівень логи як ERROR.
Щоб привести це в порядок, потрібно сворити файл logger.properties приблизно наступного виду
# Default global logging level:
.level= INFO

# Write to a file:
handlers= java.util.logging.FileHandler

# Write log messages in XML format:
java.util.logging.FileHandler.formatter = java.util.logging.XMLFormatter 

# Log to the current working directory, with log files named solrxxx.log
java.util.logging.FileHandler.pattern = solr%u.log
і підправити опці з якими стартує JBoss.
JAVA_OPTS=%JAVA_OPTS% -Djava.util.logging.config.file=/logging.properties

Thursday, March 5, 2009

Розбираємо результат Yahoo geocodes

Є у Yahoo такий сервіс, як по адресі визначити географічні координати місця. Причому задавати можна досить загальну адресу. Наприклад при пошуку за адресою Kiev вертаються координати приблизно Бессарабського ринку. Детальніше про сам сервіс можна прочитати тут.
Результат цей сервіс повертає в XML форматі.
<?xml version="1.0"?>
<ResultSet xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="urn:yahoo:maps"
xsi:schemaLocation="urn:yahoo:maps http://api.local.yahoo.com/MapsService/V1/GeocodeResponse.xsd">
<Result precision="zip">
<Latitude>50.441380</Latitude>
<Longitude>30.522495</Longitude>
<Address></Address>
<City>Kiev</City>
<State>Ukraine</State>
<Zip></Zip>
<Country>UA</Country>
</Result>
</ResultSet>
Щоб дістати значення Latitude і Longitude використаємо XPath. Так як в xml вказаний namespace, то потрібно врахувати це при створені документу
DocumentBuilderFactory domFactory = DocumentBuilderFactory.newInstance();
domFactory.setNamespaceAware(true); //вмикаємо підтримку namespace
DocumentBuilder builder = domFactory.newDocumentBuilder();
Document doc = builder.parse(inputStream);
а також при написанні xpath запиту - хоч в самому xml документі перфікс дефолтового namespace не вказується для тегів, при написанні xpath запитів їх потрібно вкзувати. В нашому випадку превіксом являється urn:yahoo:maps. Таким чином запит для отримання значення Latitude буде мати вигляд
//urn:yahoo:maps:Result/urn:yahoo:maps:Latitude
Часом в результаті може бути кілька записів, наприклад в різних країнах можуть бути міста з однаковою назвою. В такому випадку до запиту можна добавити фільтр який буде вибирати тільки результати з України
//urn:yahoo:maps:Result/urn:yahoo:maps:Latitude[following-sibling::urn:yahoo:maps:State='Ukraine']

Thursday, January 22, 2009

Налаштування прінтера HP 1018 в MacOSX 10.4

Не знаю чим керувалася HP, але якщо з прінтерами LaserJet 1010, 1012 на диску були драйвера для мака, то з новими прінтерами LaserJet 1018, 1020 драйверів крім як для вінді більше ніяких немає. Тому щоб заставити ці прінтери все таки працювати на маках потрібно встановити відкриті драйвера з пакету foo2zjs. Але цей пакет залежить ще від пакетів foomatic-rip та ghostscript. Актуальні лінки на пакети можна отримати тут. Але встановити пакети і вибрати відповідний драйвер це ще не все. Потрібно ще підправити firmware для прінтера. Для цього зкачуємо архів sihp1018.tar.gzв якому знаходиться файл sihp1018.img. В складі пакету foo2zjs є команда arm2hpdl яка зконвертує файл sihp1018.img в потрібний для прінтеру формат. Для цього виконуємо в терміналі команду:
arm2hpdl sihp1018.img > sihp1018.dl
Тепер тільки залишилося відправити цей файл на прінтер, для цього виконуємо команду
lp -oraw sihp1018.dl
Єдиний мінус - останню команду потрібно буде виконувати кожен раз коли включаєте прінтер.