기본 콘텐츠로 건너뛰기

Mobile Developer Economics - Java ME 기준으로 정리

이 글은 Vision Mobile이 제공한 "Mobile Developer Economics" 자료를 기준으로 개인적인 의견을 추가한 것이다.


2010년 기준 모바일 소프트웨어 개발자가 선택한 가장 인기 있는 개발 플랫폼은 Android로 보인다. (400명 정도의 모바일 S/W 개발자 대상 설문 조사 결과)

지난 10년간 가장 영향력이 있었던 Symbian이나 Java ME는 신흥 주자인 iPhone과 Android에 자리를 내주고 3, 4위에 머물고 있다.

하지만, 실제 시장 사항을 보면 개발자의 선호도와는 조금 다른 측면을 알 수 있다.


위 도표에서 볼 수 있듯이 install base가 가장 많은 플랫폼은 Java ME이다. 또한, install base 대비 응용 프로그램의 개수 역시 상대적으로 매우 적다. iPhone은 이와 반대로 install base 대비 응용 프로그램의 개수가 너무 많아 보인다.


아이러니하게도 개발자에게 모바일 플랫폼을 선택하는 가장 중요한 이유를 고르라고 하면 위와 같이 얼마나 시장에 널리 퍼져 있는가를 꼽는다. 이는 자신들이 선호하는 개발 환경으로 꼽은 iPhone과 Android의 현재 시장 지배력을 볼 때 상반되는 결과라 할 수 있다.

Java ME가 성공을 거둘 수 있는 좋은 환경처럼 보이는데 개발자에게 외면을 당하고 있는 이유는 무엇일까? 많은 개발자가 아래와 같은 문제점을 지적하고 있다.

"The only developers who thought that the grass is greener on the other side of the
fence were Java ME developers, of whom only a fraction believed in the future of
cross platform apps. One could say that the vast majority of Java ME developers have
lost faith in the write-once-run-anywhere vision."

즉, Java ME는 Sun이 주장했던 것처럼 write once, run everywhere가 제대로 지원되지 못한다는 것이다. 아무리 시장에 많은 디바이스가 존재해도 결국 디바이스 종류별로 서로 다른 코드를 개발해야 한다면 큰 시장의 효과가 감소하여 버린다. (이 점에 있어 Android도 과연 아무런 문제가 없다고 장담할 수 있을까? 연구해 볼 가치가 있다.)

요즘 관심이 집중되고 있는 애플리케이션 판매 방법은 어떠한가?
Java ME 경우에는 iPhone이나 Android와 비교하여 소위 Application Market에서의 판매 비중이 매우 작다. 대부분 캐리어가 관리하는 채널이나 혹은, 개발 회사의 자체 홈페이지를 통해 배포되고 있다.


모바일 소프트웨어 개발자에게 더 많은 이익을 돌려주고 또한, 사용자들이 손쉽게 프로그램을 설치하여 사용할 수 있도록 하기 위해서는 Java ME 역시 공개된 소프트웨어 시장을 제공해야만 할 것이다.
iPhone의 App Store의 7:3 이익 분배 방식과 달리 기존 캐리어들은 수익의 절반 이상 혹은 심한 경우 80% 이상의 수익을 차지하곤 했다. 이러한 이유로 Java ME 개발자로서는 잠재적 시장은 클지 모르나 수익성 측면에서는 별로라는 인식이 심어진 것으로 보인다.

Java ME 개발자에게 큰 골칫거리로 뽑히는 또 한가지의 문제는 바로 signing이다. Java ME 애플리케이션의 보안을 위해 필요한 signing 절차는 대부분의 개발자에게 절차상의 복잡함, certification을 사용하기 위해 지급해야하는 비용 문제 등 쓸데없이 개발비용만 증가시키는 것으로 인식되고 있다.


또한, 사용자로서도 signing되지 않은 Java ME 애플리케이션을 사용 시 반복적으로 보안창이 떠 확인을 하고 혹은, 특정 기능이 동작하지 않는 등 사용상의 어려움을 증가시킨다.

간단한 애플리케이션을 개발하는 데 필요한 노력을 비교했을 때는 Java를 개발언어로 사용하는 Java ME, Android가 Native 개발환경인 iPhone, Symbian에 비해 더 쉬운 것으로 보인다.


위 도표에서 보이듯이 Symbian은 명성(?)처럼 개발 노력이 가장 많이 드는 환경이며 Android가 제일 손쉬운 개발 환경으로 인식되고 있다.

조사 결과를 볼 때 Java ME를 더 활성화 시키기 위해서는 아래와 같은 조건들이 충족되어야 할 것으로 보인다.
  1. Fragmentation 이슈를 해결하기 위해 Java ME Runtime을 관리
  2. 디바이스 별 포팅을 좀 더 쉽게 할 수 있는 개발 환경 제공
  3. 캐리어들의 수익 분배 조건을 개발자에게 더 유리하게 변경
  4. 혹은, GetJar와 같은 Java ME 프로그램 배포 사이트를 강화
  5. JCP의 표준에 의해 강제된 signing 절차를 없애거나 약화
  6. 사용하기 편하고 보기 좋은 UI를 개발할 수 있게
  7. Java ME 오픈소스 라이브러리 발굴 및 개발자 포럼 지원
참고자료:

댓글

이 블로그의 인기 게시물

Wireless: HotSpot 2.0 이란?

스마트폰 사용자가 HotSpot 2.0을 지원하는 Wi-Fi 망을 사용하는 경우라면 기존 Wi-Fi 망과 달리 이동통신 망에서 Wi-Fi 망으로의 네트워크 연결 전환이 자연스럽게 이루어진다. 예를 들면, 3G 네트워크를 이용하여 영화를 보고 있다가 HotSpot 2.0 네트워크에 연결이 가능하게 되면 영화 시청 중단 없이 Wi-Fi 망으로 자연스럽게 네트워크 연결이 이동하여 3G 망의 부하도 줄이고 사용자의 네트워크 비용도 절약할 수 있다. 시스코에서 제공한 White Paper 를 참고.

Apple M1 Mac Mini에서 이더리움 (Ethereum) 채굴하기

 돈을 벌 목적은 아니고 이더리움 기술에 대한 호기심에 직접 채굴(마이닝)에 나서 보기로 했다. 머신은 Apple M1 Mac Mini. 스팩을 살펴보니 8 Core GPU에 16GB 메모리를 공유하고 있어 가능은 해보인다. 큰 흐름은 다음과 같다. 채굴한 이더리움을 저장할 지갑을 만든다 만든 지갑의 정보를 잘 보관해둔다 (Secret Recovery Phrase, 지갑의 주소 값) Apple M1용 채굴 프로그램 설치 내 지갑 정보를 이용해서 채굴 프로그램 실행 일단, 채굴한 이더리움을 저장할 지갑(wallet)을 만들어야 한다.  크롬 브라우저 익스텐션 설치로 비교적 간단하게 지갑을 만들 수 있는  https://metamask.io/ 를 이용하기로 했다. 크롬 익스텐션을 설치 후 기존에 만든 지갑이 없으므로 "Create a Wallet"을 선택한다. 패스워드 입력하고 등등의 절차를 거치면 아래와 같은 Secret Recovery Phrase가 나온다. 이 값을 잘 보관해두기 바란다. 나중에 지갑을 복구할 때 필요한 값이다. 이 값이 유출되면 지갑에 모아둔 이더리움을 다 털릴 수 있으므로 안전한 곳에 보관한다. Confirm Your Secret Phrase에서 확인 과정을 거친다. 직접 입력하는 것이 아니라 단어 별 버튼을 일일이 클릭해서 확인해주어야 한다. (좀 번거롭지만 그만큼 Secret Recovery Phrase가 중요함을 인지시키기 위한 과정이다.) 이제 지갑은 준비 완료. 생성된 Account 화면에서 지갑의 주소갑을 얻을 수 있다.  Apple M1용 채굴 프로그램을 설치해보자. Ethminer M1 Github 프로젝트 에서 미리 컴파일된 바이너리를 다운로드 받는다. (Assets를 펼치고 ethminer-m1을 클릭해서 다운 받으면 된다) 원하는 폴더에 파일을 옮겨 놓고 Terminal에서 chmod +x로 실행가능하게 만든다. % mv ~/Downloads/ethminer-m1 .             %   % c

Java: Java for Game? Java가 Game 개발에 어울릴까?

Java가 기업용 서버 소프트웨어 개발에 활발하게 쓰이는 것과 달리 일반 응용프로그램 분야에서는 별로 대접을 받지 못하는 현실을 개선하려면 어떤 분야부터 손보면 좋을까? 로딩타임, 성능, 사용자 인터페이스 등 Java를 이용한 클라이언트 프로그램을 개발하지 않는 이유들은 개발자 별로 서로 다를 것이다. 하지만, 이런 단점에도 불구하고 점점 복잡해지는 소프트웨어를 더 쉽게 다양한 환경에서 동작하도록 만들기 위해서는 Java만큼 이미 성숙한 해결책도 없지 않은가? 클라이언트 개발을 활성화하기 위해 Java를 게임 개발에 활용할 수 있도록 지원하면 어떨까? 역시, 사용자가 직접 쓰는 응용프로그램 중에는 게임이 가장 시장이 큰 분야이니 말이다. 그렇다면, 현재 게임 개발에 Java가 어느 정도 사용되고 있고 미래에 더 활성화 될 가능성은 있을 것인가? 이런 의문점을 가지고 "Java + Game"에 대해 조사해보기로 했다. 1. Java로 개발한 게임들 우선, Java로 개발한 게임들에 대해 살펴보자. Oracle의  Java in Action 웹페이지 를 보면 Java를 이용한 3D MMORPG RuneScape 에 대한 설명이 있다. 가입자가 1억 3000만명이 넘는다고 하다. 실제 게임을 설치해서 실행해보니 WOW같은 화려한 그래픽에는 못미치치만 잘만든 Role Playing 게임이다 Puppy Games 에서 개발한  Revenge of the Titans 게임도 눈여겨 볼 만하다. 이 회사는 작고 손쉽게 즐길 수 있는 게임을 개발하는데 모든 게임을 Java로 만든다. Revenge of the Titans는 Starcraft와 같은 전략 게임으로 너무 머리쓰지 않고 즐길 수 있는 게임이며 그래픽도 신선하다. 개발이 진행 중인 것으로 보이는 Urban Galaxy 라는 게임도 재미있을 것 같다. SF 영화를 보면 자주 등장하는 미래의 빌딩 숲을 날아다니는 자동차로 전투도 치르고 무역도 하며 캐릭터를 키우는 게임으로