
개요기본적으로 컨텐츠 정렬은 등록일자의 역순이 일반적이다. 그런데 정책 요구사항으로 이름 순 정렬이 생겼다. 이름 순 정렬이니 별생각없이 컬럼 정렬로 order by name ASC를 한다면? 재미있는 일을 마주하게 된다. 가장 먼저 숫자 쪽에서 의도치 않은 동작을 확인하게 된다.1 5 10 20 100 1100 위와 같은 순서로 이름을 짓게 되면 아래와 같이 정렬이 된다.1 10 100 1100 20 5이건 가장 단편적으로 보이는 문제고... 그외에도 문제가 많다. 가장 먼저 떠오르는 010은 10으로 봐야하나부터 시작해서 특수문자, 이모지 등등... 정말 많은 문제가 있다. 어떻게 할지 하나씩 정리해보자. 본 포스팅은 PostgreSQL을 기준으로 작성되었다. 1. 유니코드 정렬과 언어 기준 정렬 ..

개요PO분이 급하게 도메인을 만들고 정리하시느라 AWS가 아닌 GoDaddy에서 도메인 이름을 발급받으셨다. 거기다 상용 AWS 계정이 승인이 안나서 cloudflare에 모든 서브도메인 라우팅을 설정해두셨다. 추가적으로 SSL 인증서까지 cloudflare 에서 적용하셨다. AWS 상용 계정이 승인되고나서 도메인 서버, SSL 인증서를 마이그레이션해야했다. 처음에 언뜻 듣기로는 아 이거 뭐 금방하지라는 생각으로 모든 권한을 넘겨받았다. 그리고 바로 일이 터졌는데... 별일은 아니고 좀 오래걸렸다. 차근차근 방법을 알아보자cloudflare 설정 일시중지 혹은 삭제하기가장 먼저 해야할 내용은 아니지만 반드시 알아야할 설정이 여기있어서 처음에 뒀다. cloudflare는 CDN 역할만 해주는게 아니라 네임..

개요현재 프로젝트에서 파일 저장소로 S3를 사용하고 있다. 파일을 저장하면서 몇 가지 요구 사항이 붙게 됐다. 1. 업데이트를 하면 파일이 새로 업로드됨2. 그런데 업데이트 하기 전 파일로 롤백하려는 요구 사항이 있을 수 있음3. 그럼 업데이트된 파일을 어떻게 관리할 것인가? 사용하지 않는 파일에 아이디를 일일히 부여하는게 맞는가? 그럼 로우가 계속 늘어날텐데?4. 그러면 삭제 정책이 필요한데, 얼마나 저장할 것이며 어떻게 삭제할 것인가? 스케줄러를 돌리는 것도 말이 안되지 않나? 이런식으로 계속 꼬리질문이 나오는 상황에서 S3를 뒤져보던 중 객체 버저닝이란 것을 알게 됐다.https://docs.aws.amazon.com/ko_kr/AmazonS3/latest/userguide/versioning-w..

이 글에서 조금 더 나아간 버전이다.2024.02.01 - [개발/Kotlin] - 코틀린에서 static class 사용하기 : companion object - 자바와 다른 점 3 Utility 클래스 용으로 static을 사용하기 위해서 companion object를 쓰다가 확장함수까지 알게되서 정리한 글이었고, 이번엔 object를 걸 알게되서 다시 작성해본다. 아래에 작성한 내용들은 내가 사용하면서 느낀 점들이 조금씩 녹아있어서 오피셜한 내용을 파악하고 싶으면 코틀린 공식 문서를 보는 것을 추천한다. https://kotlinlang.org/docs/object-declarations.html#data-objects 목차를 따고 들어가면 다음 순서로 정리된다. 1. compaion object..

저번 글에서, Kotlin DSL로 JOOQ를 프로젝트에 적용시켜봤다.2025.02.28 - [개발/SPRING] - Kotlin + SpringBoot에 JOOQ 적용기 - 1. 선택 이유와 코드 자동 생성하기 사실 사용법은 여기서 다룰 필요 없이 공식문서에서 굉장히 잘 다뤄주고 있다.https://www.jooq.org/doc/latest/manual/sql-building/sql-statements/select-statement/ 이번 포스팅에서는 그냥 내가 썼던 쿼리들을 몇개 가져와서 어떻게 썼나 소개해보려고 한다. SELECTfun findById(userId: String, projectId: String): Project { return dsl.selectFrom(PROJECTS) ..

난 코테를 매우 싫어한다. 아무것도 몰랐을 때야 아무 생각없이 공부했지만, 코딩 테스트는 실무랑 완전히 동떨어져있다는 걸 알게된 이후로는 코테 공부는 시간 낭비라고 생각을 하고 있다. 하지만, 아직도 많은 기업들이 경력직 개발자에게도 코딩 테스트를 요구하기 때문에 아쉬운 사람이 공부해야하는 어쩔 수 없는 상황이다. 그 와중에 작년 말, Dale님이 운영하는 코딩테스트 스터디를 추천받았고 이번에 3기로 출발해서 15주차까지 완주했다. 목표 였던 모든 문제 완주하기를 어떻게 완료하긴 했는데 솔직히.. 조금 힘들었다. 아니 많이 힘들었다. 특히 하드문제는 GPT의 도움없이는 코드를 완성하기 어려웠다. 다 맞았다고 생각했는데 예외 한두개 때문에 코드가 엄청나게 복잡해지는 일이 많았다. 그래서 그런지 주차가 지날..

나는 이제 5.x년 6년차에 접어든 개발자이다. 긱뉴스에서 재미있는 글을 보고 비슷하게 정리해봤다. https://news.hada.io/topic?id=3635 업계에서 6년 있은 뒤, 마음이 바뀐 소프트웨어 개발 토픽들 | GeekNews마음을 바꾼 것들: 과거엔 싸웠지만, 이제는 믿게된 것들다양한 경험 수준을 가진 사람들로 구성된 팀에서는 Typed 언어가 더 좋음스탠드업 미팅은 신참들을 살펴보는데 유용스프린트 회고는 유news.hada.io https://news.hada.io/topic?id=19081 업계에서 10년 있은 뒤, 마음이 바뀐 소프트웨어 개발 토픽들 | GeekNews4년 전에도 같은 주제로 글을 작성했고, 10년째에 돌아보기로 해서 다시 작성함바뀐 생각들단순함은 저절로 주어지지 ..

서버 개발 중 스프링 부트가 실행 될 때, 반드시 한번 실행 시키고 싶은 코드가 생겼다. 코드 상 서비스로직에 추가해야할 것 같고, 굳이 빈일 필요가 없다. 예를 들어, 변수에 어떤 값을 초기화 한다던가, 객체를 초기화 한다던가 여러가지 예가 있을 것 같다. 여러가지 방법이 있다. 하나씩 정리해보자.1. @PostConstruct @Serviceclass DataService { private val dataList = mutableListOf() @PostConstruct fun loadData() { // 애플리케이션 시작 시 데이터 초기화 dataList.addAll(listOf("Data1", "Data2", "Data3")) println(..
- Total
- Today
- Yesterday
- Kotlin
- docker
- 티스토리챌린지
- elasticsearch
- ChatGPT
- cache
- AWS
- serverless
- 후쿠오카
- 스프링부트
- Spring
- terraform
- springboot
- 람다
- S3
- AWS EC2
- MySQL
- AOP
- GIT
- OpenAI
- lambda
- Log
- java
- EKS
- JWT
- 오블완
- CloudFront
- openAI API
- Elastic cloud
- object
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | ||
6 | 7 | 8 | 9 | 10 | 11 | 12 |
13 | 14 | 15 | 16 | 17 | 18 | 19 |
20 | 21 | 22 | 23 | 24 | 25 | 26 |
27 | 28 | 29 | 30 |