기본 콘텐츠로 건너뛰기

stacktistics 웹사이트 개발하면서 배운 점들 정리

오랫만에 만들어본 간단한 웹앱 stacktistics.com을 개발하면서 배운 내용을 정리해보자.
앞에서도 말했지만 stacktistics 웹사이트는 내가 즐겨찾는 개발자 Q&A 사이트인 stackoverflowopen API를 이용하여 질문의 갯수를 기준으로 프로그래밍 언어, 모바일 플랫폼, 웹 기술의 인기도를 가늠해본다.

1. 시작하기
stackoverflow 사이트를 즐겨 활용하던 나는, 이 사이트에서 open API를 제공하면 꼭 응용프로그램을 하나 만들어봐야겠다고 생각했었다. 자매 사이트인 stackapps에서 open API를 제공하는 것을 알게되어 간단한 웹앱 프로젝트를 시작하게 된다. 이 API는 RESTful 형태의 URL이고 JSON 포맷으로 값을 반환한다.

2. 어디서 개발할까?
웹 프로그램을 개발한지도 오래되었고 워낙 간단한 아이디어를 실현해보는 것이 목적이었으므로 작은 돈도 투자하고 싶지 않았다. 그래서, 몇가지 무료 App Hosting Service를 검토해 보았는데 Google의 App Engine이 가장 무난해보였다. App Engine은 Java, Python, Go와 같은 3가지 언어 기반의 Framework를 제공한다. 기존 내 경험으로 보자면 Java로 개발하는 것이 편한 선택이었는데 새로운 기술을 공부하는 것도 이 프로젝트의 개인적 목표여서 처음으로 Python을 써보기로 결정했다. (막상 써보니 동적 스크립트 언어라 사용이 편하고 코드 가독성도 좋아 맘에든다.)

3. Python 기반의 webapp Framework로 기초 공사
Google App Engine은 Python 기반의 간단한 web application framework인 webapp을 제공한다. Django와 같은 framework도 사용이 가능하지만 별도의 과정 필요 없이 바로 개발을 시작할 수 있는 webapp을 사용하기로 했다.

class MainHandler(webapp.RequestHandler):
    def post(self):
        # some codes
        
    def put(self):
        # some codes
        
    def get(self):
        # some codes

위 코드와 같이 HTTP METHOD 별로 클래스 메쏘드를 구현하여 원하는 동작을 처리하고 웹 페이지를 생성할 수 있다.

4. App engine의 data store에 자료 생성
Stackoverflow 사이트에 각 언어 별 질문 개수를 매번 조회하기에는 시간이 너무 오래 걸리므로 미리 데이터로 저장해두고 웹 페이지 생성시에는 저장해둔 데이터를 이용하도록 구현했다.
Google App Engine이 제공하는 Datastore를 이용하면 Python 클래스를 데이터 스키마로 활용 가능하고 데이터 저장 및 조회도 Python 객체와 binding되어 코드 작성이 아주 쉽다.
데이터를 한달 주기로 자동으로 생성하기 위해서 Google App Engine의 Cron 서비스를 활용하였다.

5. Django의 Template 및 CSS 활용하여 HTML 페이지 작성
Python 코드와 HTML 페이지를 분리 시키기 위해 Django의 template 기능을 사용했다. Google App Engine의 webapp에서 Django template 엔진을 제공한다.

6.  Facebook 좋아요 버튼 달기
완성된 웹페이지에 방문자들의 호감도를 파악하기 위해 Facebook의 좋아요 버튼을 달았다.

7.  Goolgle Chart Tools를 이용해 파이 챠트 그리기
테이블 형태로만 순위 정보를 제공하는 것이 좀 밋밋해서 파이 챠트를 추가해보기로 했다. Google Chart Tools를 사용하면 Javascript를 이용하여 간단하게 다양한 형태의 챠트를 추가할 수 있다.

8. RSS feed도 제공해볼까?
좀 나간다 하는 웹사이트는 대부분 RSS feed를 제공하더라. 내 웹페이지에서도 RSS feed를 제공해자. 내 웹페이지가 가진 내용을 RSS XML 포맷에 맞춘 페이지로 생성해주면 된다.

9. jQuery Mobile을 이용한 Mobile web page
마지막으로 요즘 트랜드에 맞추어 모바일 웹 페이지도 제공하기로 결정! jQuery Mobile을 사용해서 아래와 같은 멋진 모바일 페이지를 쉽게 구현하였다.


모바일 브라우저를 알아내기 위해서는 http://detectmobilebrowser.com/ 웹페이지가 제공한 Python 코드를 사용하였다.

10. Twitter Button 추가
 Twitter에 웹사이트를 홍보하기 위해 Twitter Button을 추가하였다. http://twitter.com/about/resources/tweetbutton 페이지에서 코드를 생성하여 웹페이지에 복사해주면 된다.

11. 다음 숙제들
  • Admob을 이용한 모바일 광고 게시: Python 기반 코드가 없어 약간 공부가 필요할 듯
  • 데이터가 더 쌓이면 년간 통계치를 챠트로 보여주기
  • RSS feed로 월별 데이터를 조회해볼 수 있도록 제공

최종 결과물은 http://www.stacktistics.com/ 에서 확인!

댓글

  1. 잘 만드셨네요. 최근 3개월의 변화량에 대한 순위도 있으면 좋을 듯.

    답글삭제
  2. 네. 의견감사합니다.
    데이터가 좀더 쌓이면 기능을 더 추가하려고해요.

    답글삭제

댓글 쓰기

이 블로그의 인기 게시물

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 영화를 보면 자주 등장하는 미래의 빌딩 숲을 날아다니는 자동차로 전투도 치르고 무역도 하며 캐릭터를 키우는 게임으로