분류 전체보기

0. 이 글의 작성 이유 최소한으로 JWT토큰을 발급하고 사용자에게 전달하는 과정을 설명하기 위함 다음에 Spring Security를 이용한 보안 처리를 진행할 예정이어서 미리 대비해 둔 코드가 존재할 수 있다. no used가 발생해도 당황하지 말자. 같이 보면 좋은 글 : https://developer-youn.tistory.com/166 JWT 0. 이 글을 작성하는 이유 JWT에 대해 정말 엄청 겉핥기로만 알고 있어서 이번에 프로젝트에 적용을 하기 위해 알아본 내용을 정리하기 위함 1. JWT란? Json Web Token의 약자이다. 이름에서 유추해 보 developer-youn.tistory.com 이전 글 https://developer-youn.tistory.com/165 맨땅에서 뭐라..
0. 이 글을 작성하는 이유 JWT에 대해 정말 엄청 겉핥기로만 알고 있어서 이번에 프로젝트에 적용을 하기 위해 알아본 내용을 정리하기 위함 1. JWT란? Json Web Token의 약자이다. 이름에서 유추해 보면 Json형태로 된 Web에서 사용하는 Token이다. 우리는 이 Token을 가지고 인증 / 인가에 대한 처리를 할 수 있다. 2. JWT 구성 JWT는 크게 헤더(JOSE Header), 페이로드(JWS Payload), 서명(JWS Signature) 3가지 파트로 구성된다. 2-1. 헤더(JOSE Header) JOSE라는 단어가 생소하게 느껴질 수 있다. JOSE는 Javascript Object Signing and Encryption의 약자로 간략하게 설명하면 claim(payl..
0. 이 글의 목적 Kotlin으로 Entity를 만드는 것에 대해 기술한다. 1. Java에서 도메인은? 아 맞다. 우리는 상남자식 코딩답게 jpa를 사용할 수 있는 환경도 만들어주지 않았다. gradle을 추가해 주자. https://spring.io/guides/tutorials/spring-boot-kotlin/ Getting Started | Building web applications with Spring Boot and Kotlin Instead of using util classes with abstract methods like in Java, it is usual in Kotlin to provide such functionalities via Kotlin extensions. Her..
0. 이 글의 목적 코프링으로 뭐라도 하기 위해 장난하며 나오는 결과물을 정리하기 위함 1. 프로젝트 생성 실은 나는 IntelliJ Ultimate버전을 사용하고 있어서 아래 사진들로 정리가 가능하다. New Project -> Spring Initializr 여기서 Language는 Kotlin, Type은 Gradle - Kotlin을 고른다. Spring Boot의 버전은 최신으로 고르고 보통 여기서 Dependencies를 추가하겠지만 상남자답게 그냥 스킵한다. 만들어진 프로젝트를 바로 실행해 보자. 뭔가 에러가 없이 실행된 것 같은데 멈춘다. 생각해 보니 spring-boot-starter-web을 추가하지 않았다. 추가해 주자. implementation("org.springframework..
· AMQP/Redis
0. 이 글의 작성 목적 https://www.youtube.com/watch?v=92NizoBL4uA Redis에 대해 알아보다 이 영상이 너무 설명을 잘해주고 있어서 영상의 챕터별로 조금씩 정리해보고자 한다. 1. Redis 캐시 대부분 Redis를 캐시로 사용할 텐데 이 부분에 대해 잘 사용하는 방법에 대해 짚고 넘어가고자 한다. 우선 Caching이 무엇인지 다시 확인해 보자. Caching은 사용자 입장에서 데이터를 더 빠르고 효율적으로 액세스 할 수 있는 임시 데이터 저장소다. 이때 이 Cache가 유용하게 사용되려면 당연히 원본에 접근하는 것보다 Cache에 접근하는 게 더 쉽고 빨라야 한다. 또한 동일 데이터에 대해 반복적으로 접근하는 경우 사용하는 것이 좋다. 이 조건에 대해 Redis는..
· ELK
0. 이 글을 작성하는 이유 ElasticSearch의 사용법을 알기 위해서는 어떤 구조로 이루어져 있는지 간략하게는 알고 가야 할 것 같아서 정리하기 위함 주요 참고 : https://www.youtube.com/watch?v=JqKDIg8fgd8 1. 파트 Index : Document의 집합으로 RDBMS에서의 Database에 해당함. Indices : ElasticSearch에서는 Index의 집합 Cluster : 독립된 ElasticSearch의 시스템 환경, Cluster가 여러 개더라도 서로 독립된 데이터를 가짐 Node : 실행 중인 ElasticSearch 시스템 프로세스 Document : 저장된 데이터 단위 Shard : Document들에 대한 색인과 검색을 진행하는 작업 단위 ..
· ELK
0. 이 글의 목적 ElasticSearch8.9를 공식 문서를 토대로 설치하는 과정을 정리하기 위함 1. ElasticSearch 설치 환경 MacOS Docker iTerm 2. 설치 시작 https://www.elastic.co/guide/en/elasticsearch/reference/current/docker.html Install Elasticsearch with Docker | Elasticsearch Guide [8.9] | Elastic The container runs Elasticsearch as user elasticsearch using uid:gid 1000:0. Bind mounted host directories and files must be accessible by thi..
· AMQP/Redis
0. 이 글을 작성하는 이유 Redis가 어디에 좋고 왜 사용하는지 알아보면서 정리하기 위해 1. Redis란? Redis는 비관계형 데이터베이스 관리 시스템 NoSQL DBMS입니다. Key와 Value로 데이터를 구성하여 별도의 SQL없이 Key로 데이터를 조회할 수 있습니다. 어 어? 동작 그만. 마! Key와 Value는 Java에서도 Map지원하는데 이걸 왜 쓰는데 조회 속도가 빠릅니다. 내가 빙다리.. 아니 컴공과 1학년으로 보이냐 임마. Java의 Map도 Hashing을 사용해서 조회 속도가 빠른데 어?! 성격이 좀 급하십니다. 실은 그게 핵심은 아닙니다. Redis는 RAM에 데이터를 저장합니다. RDBMS는 데이터를 어디에 저장하죠? 보조 기억장치(HDD, SSD)에 저장하죠. (물론 ..
· AMQP/Redis
0. 이 글을 쓰는 목적 https://redis.io/docs/getting-started/ Get started with Redis How to get up and running with Redis redis.io Redis 해보려다가 Redis Stack이라는게 보여서 이걸로 연동 맛보기 해보려고함 1. Redis와 Redis-stack의 다른점은? Redis + Additional features 정도로 생각하면 될 것 같다. 2. 환경 구축 우선 Redis-stack은 딱히 이유는 없고 docker로 구축하려고 한다. redis-stack-server와 redis-stack이 반겨준다. 이 중 뭘 골라야할지 고민이 되는데 redis-stack은 redis-stack-server와 GUI Clie..
0. 이 글의 목적 Real MySQL 8.0을 읽으면서 내가 정리하고 싶은 부분에 대해 작성하기 위함 1. 환경 container : docker db : mariadb 10 (아무튼 mariadb는 mysql 서비스를 fork 해서 만들었기 때문에 이걸로 진행) 2. 서버 설정 MySQL 서버는 단 하나의 설정 파일을 사용한다. 확장자는 운영체제의 환경에 따라 다르나 보통 리눅스 환경에서 사용한다고 가정하고 cnf 파일로 진행한다. 리눅스 : my.cnf 윈도우즈 : my.ini 단 하나의 설정 파일을 사용한다고 했는데 이는 공통적으로 my.cnf라는 이름을 사용한다는 것이다. 문제는 이 파일이 여러 경로에 존재할 수 있는데 어느 디렉토리에 있는 my.cnf를 참조하고 있는지 아래 명령어로 확인이 가..
Berno
'분류 전체보기' 카테고리의 글 목록 (4 Page)