오랜만에 옛날 안드로이드 프로젝트를 열려고 했으나, 다음과 같은 에러 때문에 빌드가 되지 않았다. 내용을 읽어보면 두 가지 버전의 Kotlin Standard Library가 충돌된다고하는데 1.8.0과 1.6.21인가보다. 그리고 jdk8도있고 jdk7도 있다. Execution failed for task ':app:checkReleaseDuplicateClasses'. > A failure occurred while executing com.android.build.gradle.internal.tasks.CheckDuplicatesRunnable > Duplicate class kotlin.collections.jdk8.CollectionsJDK8Kt found in modules jetified-..
1. Springdoc? 1) 구성 Springdoc은 아래와 같이 구성되어있다. 그래서 타 블로그처럼 openapi-ui를 설치하게 되면, Swagger-ui까지 같이 사용하게 된다. UI를 사용하지 않아도 OpenAPI JSON이 제공된다. 그래서 코어 기능인 webmvc-core만 사용하려고 한다. UI에 관한건 Redoc을 쓰기로 했기 때문이다. 2) Default Version의 문제점 기본적으로 Spring에서 Swagger는 Description 남발은 피할수가 없다. Springdoc에서 제공하는 Example이 바로 Petstore인데 Petstore Swagger-UI로 열어보면 내용이 별로 없다는걸 알 수 있다. Front 개발자가 참고 할 만한 설명이 모두 들어가려면 @Tag, @O..
필요성의 자각 Spring 프로젝트를 백엔드 용도로 진행하면 API 문서를 작성해야만 한다. 대학에서 그렇게 논문을 쳐다보던 사람이 개발자가 되서는 문서의 효율성을 모르는 사람마냥 여기는 사람이 많더라. API 문서는 사용자의 입장에서 최대한 질문이 없도록 꼼꼼하게 써야하고, 필요한 내용이 있으면 업데이트를 해야만 한다. 프로젝트를 추후에나 혹은 새 인원이 참가하는 경우에도 인수인계를 최소한으로 할 수 있을만큼 작성되어야 한다는 것. 그리고 API 문서는 개발 진행 당시에도 중요하지만 최종 산출물이기도 하다. 좋은 API가 무엇인가를 좀 더 알고 싶다면, LINE 형님들이 쓴 글을 읽어보면 도움이 된다. 그 동안에는 어떻게 쓰였는가? 1) 문서 프로그램으로 작성 초기에는 심한경우는 Excel(물론 정리되..
시작하기에 앞서 Legacy 1, 2를 두고서 얼마나 귀찮고 힘든 과정으로 필터문을 만들어야 했는지 알아보았다. 결과적으로 SQL이 차지하는 비율은 항상 절반이 넘었다는 것을 알 수 있었다. 또한, JPA만 사용한다고 하더라도, Specification이나 Native Query를 꼭 사용해야만 하는 경우가 많았음을 보여준다. 이때까지만 하더라도 QueryDSL이 그렇게 좋아? 하는 의문이 들었다. 예전부터 QueryDSL을 쓰고 싶었으나, 내 입맛에 맞게 쓰려면 Hibernate 5, 6이나 vladmihalcea의 hibernate-types까지 나오기 전엔 못쓰겠다 싶었는데 다행히 도입하는 시점에는 입맛에 맞는 상황이 돼버린 터라 쓰게 되었다. QueryDSL을 시작하려고 다른 사람들은 어떻게 쓰고..
1. Install /etc/yum.repos.d/ 에 nginx.repo로 Repository 등록 [nginx] name=nginx repo baseurl=http://nginx.org/packages/centos/7/$basearch/ gpgcheck=0 enabled=1 이후 Nginx 설치 yum install -y nginx 80포트 개방 firewall-cmd --permanent --zone=public --add-port=80/tcp firewall-cmd --reload 2. 확인 systemctl enable nginx systemctl start nginx systemctl status nginx conf 설정은 /etc/nginx/conf.d/default.conf에 있으므로 기본..
Centos Setup 1. Java 설치 sudo yum install java-1.8.0-openjdk-devel #javac 라는 명령어의 위치 확인 which javac #javac의 심볼릭 링크를 통해 원본 파일의 위치 추출 readlink -f /usr/bin/javac #profile 파일을 vi에디터로 열어 아래 export 구문을 추가한 후 저장 vi /etc/profile export JAVA_HOME=/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.332.b09-1.el7_9.x86_64 #7 확인 echo $JAVA_HOME 2. Tomcat 설치 1) 톰캣 다운로드 https://tomcat.apache.org/ 에서 Core 트리의 tar.gz를 받음. tar..