본문 바로가기

Eric112

카카오 겨울 인턴 알고리즘 문제 보호되어 있는 글 입니다. 2019. 11. 9.
[cocos2d-x] 드래곤 슈팅 게임 개요 cocos2d-x를 사용하여 만든 간단한 종스크롤 탄막 슈팅 게임입니다. 내려오는 우주선을 공격하고, 피하면 됩니다. 약 400줄정도 코드가 나왔습니다. 게임 개발도 꽤 재밌어 보입니다. 코드가 필요하시다면 댓글로 이메일을 남겨주세요. 개발 기간 3시간 개발 환경 Visual Studio 2019 cocos2d-x 플레이영상 2019. 11. 6.
[이슈 #6] 주소 데이터의 빠른 조회를 위해 인덱스 설정하기 얼마 전 주소데이터를 DB에서 관리하도록 변경하였는데, 데이터가 100,000,00건정도 되어서 검색이 정말 느렸습니다. 인덱스를 걸지 않은 상태로 조회를 하면 검색에만 10초가 넘게 걸리는 무시무시한 상황이었습니다. 다행히도 주소 DB는 DML문이 거의 진행되지 않습니다. 가끔 공공데이터에서 업데이트 정보가 올라온다면 그 부분만 수정해주면 되는 것이죠. 조회는 많고 수정 삽입 삭제가 거의 없는 테이블이니 인덱스를 잡기에 부담은 없을 것 같습니다. 우선 해당 주소 DB를 구축하는 과정은 이전 포스팅에 적혀있습니다. 필요하시다면 참고해주세요. https://deveric.tistory.com/66?category=350852 [이슈 #4] 주소를 외래키로 관리하도록 변경(공공데이터 사용) 기존 방식의 문제.. 2019. 11. 1.
[이슈 #5] 반복되는 로그인 체크 로직을 AOP로 리팩토링하기 로그인 체크가 필요한 상황 회원의 정보가 필요하거나, 해당 회원의 접근권한을 확인해야 할 때가 있습니다. 마이페이지, 내 정보 수정 등이 대표적인 예 입니다. DelFood 화면 프로토타입의 마이페이지는 다음과 같습니다. 해당 화면을 출력하려면 일단 회원 로그인이 먼저 진행되어야 합니다. 비회원의 경우에는 내 정보를 볼 수 없겠죠. 변경 전 프로젝트 코드 AOP를 적용하지 않은 상태에서는 다음과 같이 코드를 작성하여 권한을 확인하였습니다. 1. HttpSession에서 Member id 정보를 가져온다. 2. 가져온 id 정보가 null이면 401 status를 반환한다. 3. id가 null이 아니면 핵심 로직을 수행한 후 반환한다. Session 체크용 공통 모듈 SessionUtil Code pub.. 2019. 11. 1.
[이슈 #4] 주소를 외래키로 관리하도록 변경(공공데이터 사용) 기존 방식의 문제점 기존에 주소를 입력하는 방식은 '주소', '상세주소' 컬럼을 사용하여 사용자의 주소를 직접 입력받는 식이였습니다. 당연히 이 주소들은 공통적인 포맷으로 관리하기도 어렵고, 주소 체계를 변경한다면 모든 테이블의 주소 체계를 전부 변경해야 했습니다. 간단하게, 변경 전 회원 테이블은 다음과 같이 생겼습니다. MEMBER Table Schema 위 방식과 같이 주소를 직접 입력하도록 한다면, 주소를 이용한 좌표 검색, 입력한 주소 별 정렬 등 주소 관리가 어려울 것이라 생각됩니다. 또한 도로명주소와 지번 주소의 관리도 어렵게 되어 테이블의 변경이 필요하다고 판단하였습니다. 1. 주소 정보를 공공데이터에서 가져오기 '공공데이터포털'에서는 도로명주소, 지번주소, 좌표 등의 데이터를 가지고 있는.. 2019. 10. 27.
[Spring] Spring은 왜 memcached 대신 Redis를 선택했을까? 개요 Multi Server 환경에서의 Session데이터를 Servere마다 관리하도록 설계한다면 어떻게 될까요? 사용자가 로그인한 상태에서 요청 서버가 바뀐다면, 해당 사용자는 로그인이 해제될 것입니다.(해당 서버의 세션 저장소에는 사용자가 로그인한 데이터가 없으므로) 그렇기 때문에 웹 서버에서는 세션 데이터를 서버가 아닌 외부 저장소에 저장합니다. 이때 사용하는 저장소에 대해 의문이 들었습니다. Spring의 세션 클러스터링은 기본적으로 Redis를 이용하여 진행됩니다. 세션 정보 저장과 캐싱에 Redis를 사용하던 도중 왜 Spring은 Redis를 이용하게 되었을까에 대한 궁금증이 생겼습니다. RDBMS에도 저장할 수 있고 MongoDB, Memcached 등 다른 NoSQL에도 데이터를 저장할.. 2019. 10. 22.
[Java] Java의 GC(Garbage Collection)방법과 종류 GC란? Java Application은 JVM(Java Viirtual Machine) 위에서 구동됩니다. JVM에서는 Java Application이 사용하는 메모리를 관리하고 있는데 이 JVM의 기능중 더 이상 사용하지 않는 객체를 청소하여 공간을 확보하는 GC라는 작업이 있습니다. GC란 Garbage Collection(쓰레기 객체 정리, 이하 GC)의 약자입니다. Java Runtime시 Heap 영역에 저장되는 객체들은 따로 정리하지 않으면 계속헤서 쌓이게되어 OutOfMemmory Exception이 발생할 수 있습니다. 이를 방지하기 위하여 JVM에서는 주기적으로 사용하지 않는 객체를 수집하여 정리하는 GC를 진행합니다. GC 전 후의 메모리 JVM의 메모리 영역 GC 작업을 진행하는 G.. 2019. 10. 17.
[Spring Mybatis] 중복 쿼리를 include, sql로 대체하기 속성이 많은 테이블의 정보를 조회해야 할 때, WHERE 조건만 다른 쿼리를 짤 때 등 중복되는 쿼리를 작성해야 할 때가 있습니다. WHERE 조건을 제외한다면 다른 부분은 모두 중복되는 쿼리 SELECT id, name, delivery_type deliveryType, signature_menu signatureMenu, tel, zipcode, address, address_detail addressDetail, biz_number bizNumber, info, min_order_price minOrderPrice, notice, operating_time operatingTime, delivery_location deliveryLocation, owner_id ownerId, created_at .. 2019. 10. 16.
[이슈 #3] 아이디 중복 체크시 Http Status값을 어떻게 설정해야 할까? 아이디 중복 체크를 했을 때 HttpStatus값을 어떻게 설정해서 넘겨줘야 할지 고민입니다. HttpStatus Enum을 하나하나 읽어보며 어떤 것을 적용할 지 고민해보았습니다. ID 중복체크 소스코드 /** * 회원가입 시 아이디의 중복체크를 진행한다. * 아이디 중복체크는 회원가입 아이디 입력 후, 회원가입 요청시 두번 진행한다. * 아이디 중복체크를 한 후 회원가입 버튼을 누를 때 까지 동일한 아이디로 누군가 가입한다면 PK Error가 발생되고 * 실제로 회원가입이 진행되지 않을 수 있기 때문에 회원가입을 눌렀을 때 한번 더 실행하는 것이 좋다. * @param id * @return */ @GetMapping("idCheck/{id}") public ResponseEntity idCheck(.. 2019. 10. 6.