분류 전체보기
-
[Redis] Medis를 사용하여 Redis GUI를 사용하는 법Tool 2021. 8. 10. 23:43
Medis 설치해서 사용하기! MySQL 같은 경우는 WorkBench가 있어서 손쉽게 데이터를 보고 관리할 수 있는데요. 하지만 Redis는 매번 redis-cli를 통해서 데이터를 확인하고 하는 것이 번거로웠습니다. 그러던 중에 Medis라는 Redis 데이터를 UI로 볼 수 있는 아주 좋은 것이 있어서 정리해보려고 합니다. 그래서 Mac에서 Medis를 설치해서 사용하는 법에 대해서 알아보겠습니다. 먼저 AppStore에서 Medis를 검색하면 Medis2 - GUI for Redis가 나오는데요. 이것을 다운하겠습니다. 그러면 위와 같은 화면이 뜨는데요. 위의 화면에서 다른 ElastiCache와 같은 것을 사용한다면 해당 URL을 적은 후에 Connect를 누르면 되고 local Redis를 사..
-
[Spring] Spring Data Redis로 자료구조 사용해보기Server/Spring 2021. 8. 10. 22:59
Spring Data Redis로 자료구조 다루어 보기 Redis 는 간단하게 말하면 Key-Value 형태의 영속성을 지원하는 인메모리 데이터 저장소입니다. 이번 글에서는 Spring Data Redis를 활용해서 List, Set, Sorted Set, Map을 사용해서 데이터를 저장하고 조회하는 것에 대해서 정리해보겠습니다. 먼저 Spring Boot gradle 기반의 프로젝트에서 의존성 부터 추가해서 시작해보겠습니다. gradle implementation 'org.springframework.boot:spring-boot-starter-data-redis' 위의 Spring-data-redis 의존성을 추가하겠습니다. 이제 Redis 설정을 해보겠습니다. Redis 설정 @Configurati..
-
[DB] Redis란 무엇일까? 간단하게 알아보기!Computer Science/Database 2021. 8. 10. 16:47
Redis란 무엇일까? Redis는 Memcached와 비슷한 캐시 시스템으로서 동일한 기능을 제공하면서 영속성, 다양한 데이터 구조와 같은 부가적인 기능을 지원하고 있습니다. 레디스는 모든 데이터를 메모리에 저장하고 조회합니다. 즉, 인메모리 데이터베이스 입니다. 이 말만 들으면 Redis에 모든 데이터를 메모리에 저장하는 빠른 DB가 다라고 생각할지도 모릅니다. 하지만 빠른 성능은 레디스의 특징 중 일부분 입니다. 다른 인메모리 디비들과의 가장 큰 차이점은 레디스의 다양한 자료구조 입니다. 이렇게 다양한 자료구조를 지원하게 되면 개발의 편의성이 좋아지고 난이도가 낮아진다는 장점이 있습니다. 예를들어, 어떤 데이터를 정렬을 해야하는 상황이 있을 때, DBMS를 이용한다면 DB에 데이터를 저장하고, 저장..
-
[Java] 인터페이스와 추상 클래스 차이는 무엇일까?Language/Java 2021. 8. 7. 01:47
인터페이스와 추상 클래스 차이는? 이번 글에서는 인터페이스와 추상 클래스의 차이에 대해서 정리해보겠습니다. 실제로 이 질문은 면접에서도 자주 물어보는 질문이고, 약간 알듯 말듯 한데 대답하기는 애매한 주제라 한번 각각 특징에 대해서 정리해보고 둘의 차이를 정리 해보겠습니다. 추상 클래스 클래스를 설계도에 비유한다면 추상 클래스는 미완성 설계도에 비유할 수 있습니다. 추상 클래스는 키워드 abstract를 붙이기만 하면 됩니다. public abstract class Test {} 추상 클래스는 추상 메소드를 0개 이상 가지고 있다는 것을 제외하고는 일반 클래스와 전혀 다르지 않습니다. 추상 메소드는 간단하게 말하면 선언부는 있는데 구현부가 없는 메소드를 의미합니다. public class 쥐 extend..
-
[MySQL] InnoDB 언두(Undo) 로그와 MVCC란 무엇일까?Book/Real MySQL 2021. 7. 29. 16:17
언두 영역이란? 언두 영역은 UPDATE 문장이나 DELETE 문장으로 데이터를 변경했을 때 변경되기 전의 데이터(이전 데이터)를 보관하는 곳입니다. UPDATE membere SET name='홍길동' WHERE member_id = '1'; 위 문장의 실행되면 트랜잭션을 커밋하지 않아도 실제 데이터 파일 내용은 홍길동으로 변경됩니다. 그리고 변경되기 전의 값이 Gyunny 였다면, 언두 영역에는 Gyunny라는 값이 백업되는 것입니다. 이 상태에서 사용자가 커밋하게 되면 현재 상태가 그대로 유지되고, 롤백하게 되면 언두 영역의 백업된 데이터를 다시 데이터 파일로 복구합니다. 언두의 데이터는 크게 두 가지 용도로 사용됩니다. 트랜잭션의 롤백 대비용 트랜잭션의 격리 수준을 유지하면서 높은 동시성을 제공 ..
-
1일 1커밋을 1년 7개월 동안 하면서 느낌점Retrospect 2021. 7. 29. 13:52
1일 1커밋을 1년 7개월 동안 해오면서... 이번 글에서는 제가 1일 1커밋을 1년 7개월 동안 하면서 느낀점에 대해서 간단하게 회고를 해보려 합니다! (Github) 1일 1커밋을 왜 시작했는지? 1일 1커밋을 지속할 수 있었던 것들은 어떤 것이 있었는지? 1일 1커밋에 대한 장단점! 자주 받았던 간단한 질문들 정리~? 이정도에 대해서 가볍게 회고하면서 저의 생각을 공유해보려 합니다. 바로 본론으로 고고싱! 1일 1커밋을 왜 시작했는지? 🤔🤔 1일 1커밋에 대해서 다른 사람과 얘기를 하다 보면 1일 1커밋을 왜 시작했는지 라는 질문을 아주 많이 받았습니다.(동아리 면접 때도 자주 들었던 질문!) 왜 시작했는지? 대해 얘기하려면 2019년으로 가야 하는데요. 2019년의 저는 간단한 개발 조차 해본 적..
-
[MySQL] COUNT 쿼리와 숫자 타입에 대한 주의 사항카테고리 없음 2021. 7. 26. 15:30
MySQL COUNT() 함수 정리 COUNT 함수는 모두가 알고 있듯이 결과 레코드의 건수를 반환하는 함수입니다. COUNT() 함수는 컬럼이나 표현식을 인자로 받고, COUNT(*)와 같이도 사용할 수 있습니다. 여기서 *는 SELECT 절에 사용될 때처럼 모든 컬럼을 가져오라는 의미가 아니라 그냥 레코드 자체를 의미하는 것입니다. 실제로 COUNT()이라고 해서 레코드의 모든 컬럼을 읽는 형태로 처리하지는 않습니다. 그래서 굳이 COUNT(id), COUNT(1) 같이 사용하지 않아도 됩니다. COUNT()와 비슷한 속도로 처리된다고 합니다. (오.. 뭔가 차이가 있을 줄 알았지만 차이가 없다니~!!) MyISAM 스토리지 엔진을 사용하는 테이블은 항상 테이블의 메타 정보에 전체 레코드 건수를 관리..
-
[MySQL] Upsert 쿼리란 무엇일까?Book/Real MySQL 2021. 7. 22. 16:21
MySQL Upsert 사용법 이번 글에서는 MySQL에서 Upsert 쿼리를 사용하는 법에 대해서 정리해보겠습니다. Upsert는 이름에서 어느정도 유추할 수 있듯이 Update + Insert를 합친 말입니다. 즉, Upsert는 중복되는 값이 있다면 Update를 하고 중복되는 값이 없다면 Insert를 하는 쿼리입니다. 좀 더 정확히 말하면 Unique Key의 값이 중복된다면 Update를 하고, Unique 컬럼의 값이 존재하지 않는다면 INSERT를 하는 것입니다. 실제로 프로젝트를 하다 보니 이러한 쿼리를 사용해야 할 상황이 와서 이렇게 정리를 하게 되었습니다. Upsert 쿼리를 보면 아래와 같습니다. INSERT INTO user_refresh_token (user_id, refresh..