본문 바로가기

프로젝트17

JdbcSQLSyntaxErrorException 에러 해결과정 오늘은 개인 프로젝트를 진행하다가 발생한 이슈에 대해서 정리해보고자 합니다. 개발을 하다보면 더미 데이터가 필요합니다. Springboot에서는 Load시 main/resources안에 있는 data.sql을 읽어 설정된 DB에 Insert시킵니다. 그런데 빌드도중 갑자기 Table을 찾을 수 없다면서 Error가 발생하는 것이었습니다. 😱 Caused by: org.h2.jdbc.JdbcSQLSyntaxErrorException: Table "POST" not found; SQL statement: 🧐 문제인식 처음에는 datasource에 초기 스키마가 먼저 저장되어야 하는데 initialization설정을 하지 않았나? 하고 의심해보았지만 정상적으로 설정이 되어있었습니다. jpa: defer-dat.. 2021. 12. 16.
AWS EC2 서버 생성 및 설정방법 AWS에 서버를 만들기 위해서는 EC2를 생성해야 합니다. 1.EC2를 만들때에는 크게 주의할 것은 없고 Amazon Linux 2 AMI로 생성합니다. 그 이유는 Amazon에서 관리하고있는 리눅스 이기때문에 AWS 서비스와의 호환성이 좋으며, 아마존 독자 개발 레포지토리를 사용하므로 속도가 빠릅니다. 참고로 Amazon Linux 2 는 기본적으로 센토스OS입니다. 2. 만들면 pem키를 잘 관리하도록 합니다. 3. 인스턴스를 만들었으면 외부에서 접근할 수 있도록 탄력적 IP를 연결시킵니다. 4. 그런다음 인바운드 규칙을 설정하여 외부에서 http 요청이 들어오면 수신할 수 있도록 설정합니다. 보안그룹을 선택 하여 인바운드 설정을 수정합니다. EC2이기때문에 기본적으로 외부에서 들어오는 요청을 수신하.. 2021. 12. 14.
배포환경에서 애플리케이션과 S3 연동방법 본 포스팅은 이미 AWS에 EC2와 S3가 만들어져 있다고 가정하고 시작하겠습니다. 혹시라도 S3를 어떻게 만들지?, SpringBoot와 연동은 어떻게 하지? 하시는 분이 있으시다면 이전 포스팅을 참고 부탁드립니다. RDS 만들기 일단 SpringBoot 애플리케이션을 EC2에 띄우기 위해서는 해당 애플리케이션이 접속하는 DB를 구축해야 합니다. 여기서는 MariaDB를 사용하였습니다. MariaDB를 사용하는 이유는 가격입니다. 현재 AWS의 프리티어를 사용하고 있어 1년동안은 최대한 프리티어의 이점을 누리기 위해서 제일먼저 고민했던 부분입니다. MariaDB는 라이센스가 무료임으로 추후 프리티어 기간이 끝나도 MsSql이나 Oracle보다 가격선방을 해줄 것 같았습니다. 또한 성능면에서도 Mysql.. 2021. 10. 26.
Spring Boot AWS S3 연동 진행하던 프로젝트에서 정적 이미지를 업로드 하는 기능이 필요하여 가장 많이 사용하는 AWS S3를 어떻게 구성하고 사용했는지 공유하려고 합니다. 🤔어떤 S3를 사용할까? S3는 AWS뿐만아니라 대표적으로 MS, Google 등 많은 곳에서 제공하고있습니다. 그중 AWS를 사용하기로 결정한 이유는 다음과 같습니다. 클라우드 서비스 중 AWS를 사용한적이 없습니다...(Naver Cloud Platform, GCP) 등 사용한 적이 없어 이번엔 AWS와 친해보려고 합니다. 많은 기업들이 사용하고 있습니다. 1년동안 무료로 사용할 수 있습니다. AWS의 S3로 결정하고 정보를 찾던 도중 GCS는 월 5G까지 무료라고... 하지만 이번엔 1년동안 AWS와 친해져서 익숙해지려고 합니다. S3같은 서비스를 사용하는.. 2021. 10. 22.
페이지네이션 어떻게 처리해야 할까요? 피드를 개발하던 도중 페이징 처리에 대해서 고민을 하게되었습니다. 페이징은 크게 2가지로(offset 방식, cursor방식) 볼 수 있습니다. 각각의 장단점을 파악한 뒤 해당 프로젝트에서는 왜 cursor방식으로 선택했는지 공유해보고자 합니다. offset방식은 offset과 limit를 기준으로 DB에서 특정부분 데이터를 가져오는 방식을 말합니다. 그래서 sql쿼리를 보면 다음과 같습니다. SELECT * FROM Feed ORDER BY updated_at DESC LIMIT 0, 10;그래서 해당 프로젝트에서는 JPA를 사용하기 때문에 JPA에서 제공하는 pageable을 사용하여 손쉽게 페이징처리를 하였습니다. PageRequest pageRequest = PageRequest.of(pageIn.. 2021. 9. 30.
Spring rest docs를 사용한 API문서화 🤔Swegger대신 Spring Rest Docs를 왜 사용하나요? 일단 Swegger와 Spring Rest Docs를 왜 사용해야 할까요? 백엔드 개발의 주된 일은 바로 Api를 제공하는 일 입니다. Api를 프론트 개발자에게 전달한다는 것은 수 많은 대화가 필요하다는 것을 의미합니다. 이러한 대화를 조금이라도 줄인다면 더 많은 성과와 업무 효율을 극대화 할 수 있습니다. 따라서 백엔드 개발자는 Api문서를 제공하여 파라미터 설명, 요청 url, 응답 형식 등을 알려주어 해당 Api를 사용할 개발자들에게 알려줄 의무가 있습니다. 주로 Java 진영에서는 Swegger, Spring Rest Docs를 사용하여 Api 문서를 제공합니다. 우선 Swegger, Spring Rest Docs의 특징을 비교.. 2021. 9. 21.
ngrinder로 성능 테스트 Ngrinder 설치 Controller 설치 ngrinder는 네이버에서 만든 오픈소스임으로 github에서 wget을 통해 다운로드 받습니다. 우선 자바를 설치 후 해당 war파일을 실행합니다. ngrinder를 실행하면 기본 포트인 8080으로 접속하시면 됩니다. ID, PW는 admin으로 기본 설정되어있으며, 보안 상 PW는 변경합니다. 실행 시 github을 확인해보면 MaxPermSize를 설정해줍니다. MaxPermSize는 java 8부터는 사용하지 않습니다. 사용하지 않는 이유는 해당 포스팅에서 벗어나는 내용 같아 참고링크로 대신하겠습니다. 해서 MaxPermSize를 설정하지 않고 바로 실행하였습니다. java -jar ngrinder-controller-3.5.5-p1.war -p .. 2021. 8. 19.
Logging Framework는 어떤게 좋을까? 프로그램 개발을 할때 중요한 요소 중 한 부분은 바로 로깅 처리입니다. 어떤 로깅 프레임워크를 사용할지, 로그레벨 정책은 어떻게 가져갈지 등에 대한 고민은 개발을 들어가기전 결정해야 됩니다. 최근 읽고있는 자바 성능 튜닝이야기 책을 통해 Log4j, Logback을 알게되었고 앞으로 진행해야될 프로젝트에 어떤 로깅 프레임워크를 적용할지 결정하려고 합니다. 자바에서는 Log4j → Logback → Log4j2 시간 순으로 로깅 프레임워크가 나왔습니다. 이들 중 각각의 성능을 비교해보도록 하겠습니다. Log4j 첫 로깅 프레임워크이며 그래서인지 SLF4J를 기본적으로 지원하지 않습니다. 그래서 별도의 의존성 slf4j-log4j12를 설치해야 합니다. 또한 2015년 말 이후로는 더 이상 업데이트를 하지 .. 2021. 8. 16.
Jenkins를 사용한 CD 구성 각종 단위테스트, 빌드 테스트 등을 통과한 검증된 코드들은 실제 운영서버에 배포되어야 합니다. 이를 자동화 하기위해 Jenkins를 사용하였습니다. 이번 포스팅은 Jenkins를 사용하여 CD를 구현한 내용에 대해서 정리글이 될 것 같습니다. 🤔 서버에 배포 시 어떤 방식을 사용해야하나? 제가 생각했을 때 배포 방식은 크게 2가지 였습니다. 깃헙에 있는 코드를 clone하여 build후 실행시키는 것을 자동화하자 도커파일을 만들어서 도커허브에 올려둔 후 각 서버들은 pull받아 사용하자 결론적으로는 2번을 선택하여 배포를 하였습니다. 2번은 선택한 이유는 배포할 서버에 소스코드를 배포한다는 부분이 보안적으로 미흡하다 판단하였고, 빌드로 인한 서버쪽이 지저분해질 것 같았습니다. 또한 서버에 환경구성할 때 .. 2021. 8. 12.