흐르는 시간의 블로그...

개인적인 스터디겸 간단한 프로젝트를 Java SE 8으로 개발하였다.

IntelliJ가 많은 도움을 줘서 쉽게 개발하였다.

배포도 귀찮은지라 IntelliJ에서 jar로 만들어 Linux 머신에서 실행하였다.

사용한 것은 JDBC, TCP, Thread, logger와 HashMap, Hashtable, Multimap의 컨테이너들이다.

전반적으로 C++과 큰 차이점은 느끼지 못했다. 헤더와 소스의 분리가 안되는 것과 int 데이터의 적절한 형변환에 더 조심해야하는 것 외에는 말이다.


이렇게 해피엔딩이면 좋았겠지만 PC에서 문제가 없던 부분이 Linux 머신에서는 문제를 일으켰다.

첫번째는 버전 관련 사항이었다.

http://stackoverflow.com/questions/10382929/how-to-fix-java-lang-unsupportedclassversionerror-unsupported-major-minor-versi

뭐 결론은 Linux에 Java SE 8을 인스톨하여 정리하였다.


두번째는 class path 관련 사항이었다.

귀찮아서 jar로 만들어서 실행하였다.


세번째는 JDBC로 연결하는 시간이 매우 많이 소요 됐다.

그래서 스택오버플로에 검색을 했다.

주로 나오는 내용은 random 관련된 사항이었다.


http://stackoverflow.com/questions/5503063/oracle-getconnection-slow

http://stackoverflow.com/questions/137212/how-to-solve-performance-problem-with-java-securerandom


DriverManager.getConnection()에서 SecureRandom을 호출하는데 일반적인 random의 경우 블럭될 수 있다는 것이다. 이 현상은 Linux에서 나타난다 하였다. 해결방법은 urandom을 사용하는 것과 haveged란 프로그램을 통해 random의 seed를 만드는 노이즈를 빨리 수집하는 방법이 있다.

두가지를 모두 적용하였으나 여전히 connection은 5초~30초 사이로 오래 걸렸다.


결국 팀원에게 도움을 청해 답을 얻었다.

네트웍 문제였던 것이다.

IP로 접근하는 지라 특별히 dns문제나 네트웍 쿼리가 문제가 있을꺼라 생각하지 않았으나 내 착각이었다.

/etc/resolv.conf를 수정하여 접근 속도를 개선하였다.

약 400ms이 소요되는지라 아주 빠르다 할 순없지만 말이다.

http://webdir.tistory.com/116




'프로그래밍???' 카테고리의 다른 글

GO Lang 시작  (0) 2016.09.22
iBatis 설정 자료 링크  (0) 2016.01.20
Redis 시작...  (0) 2015.12.11
DNS의 타입에 대해...  (0) 2015.04.21
엑셀에서 랜덤 문자열 생성하는 VBA 스크립트  (0) 2015.03.04