NVIDIA가 개발한 오픈 소스 툴킷: NeMo Guardrails 소개
NeMo Guardrails는 NVIDIA가 개발한 오픈 소스 툴킷으로, 대규모 언어 모델(LLM)을 사용하는 AI 애플리케이션의 안전성과 유용성을 보장하기 위해 설계되었습니다.이 툴킷은 AI가 비윤리적이거나 유해한 콘텐츠를 생성하지 않도록 제한하며, 특정 비즈니스 규칙을 따르도록 제어할 수 있습니다.사용자는 YAML 또는 Python 파일을 통해 대화 규칙(Rails)을 정의하고, 이를 기반으로 AI 응답을 필터링하거나 수정할 수 있습니다.Amazon Bedrock에서 AI 안전 기능으로도 제공합니다.간단한 네모 가드레일 사용 방법에 대해 알아보겠습니다.Guardrails에서 사용되는 AI 모델과 작업 환경을 정의하는 데 yaml을 사용됩니다.이 파일은 Guardrails의 동작 방식을 설정하는 핵심 구성 요소로, AI 모델 유형, 엔진, 파라미터 등을 정의합니다.• Rails는 특정 시나리오에 대해 AI가 따라야 하는 규칙입니다.• Python 및 YAML 파일을 사용하여 대화 규칙을 정의합니다.• None models: Guardrails에서 사용할 AI 모델을 정의합니다. 여러 개의 모델을 지정할 수 있으며, 각 모델은 역할에 따라 구분됩니다.• None type: 주로 대화를 생성하거나 질문에 답변하는 주요 모델 정보• None engine: Guardrails가 사용할 API 또는 플랫폼을 지정합니다.• None model: 사용할 모델 이름을 지정합니다.• None parameters (선택 사항):모델의 동작을 제어하는 추가 파라미터를 정의합니다.• None temperature: 응답의 다양성을 제어 (0.0 ~ 1.0).• None app : Guardrails 애플리케이션 전반의 동작을 설정합니다.• None• None max_turns: 한 대화 세션에서의 최대 대화 턴 수.OpenAI API 기반 설정을 하려면 아래와 같이 작성합니다.Hugging Face 모델 기반 설정은 엔진에 허깅페이스를 넣어주고 허깅페이스에서 지원하는 모델을 넣습니다.• None 엔진 및 모델 이름 일치: 엔진(engine)과 모델(model)의 이름은 지원되는 플랫폼의 정확한 모델 이름이어야 합니다.• None 파라미터 설정 유효성: 사용 중인 엔진에 따라 지원되지 않는 파라미터를 지정하면 에러가 발생할 수 있습니다.• None 환경 변수 활용: API 키와 같은 민감한 정보는 코드에서 직접 설정하지 않고, 환경 변수로 설정하여 os.environ 등을 통해 사용할 수 있습니다.yaml 파일은 RailsConfig로 읽어 Guardrails 설정에 활용됩니다:yaml은 Guardrails 동작의 유연성과 확장성을 제공합니다.필요에 따라 다양한 엔진과 설정을 조합해 활용할 수 있습니다. rules.yaml 을 아래 내용을 작성합니다."죄송합니다. 폭력적인 영화 추천은 도와드릴 수 없습니다." "가족과 함께 즐길 수 있는 영화 추천: 1. Finding Nemo 2. Toy Story 3. Coco" replace_response "죄송합니다
1/17/2025
NVIDIA가 개발한 오픈 소스 툴킷: NeMo Guardrails 소개
NeMo Guardrails는 NVIDIA가 개발한 오픈 소스 툴킷으로, 대규모 언어 모델(LLM)을 사용하는 AI 애플리케이션의 안전성과 유용성을 보장하기 위해 설계되었습니다.이 툴킷은 AI가 비윤리적이거나 유해한 콘텐츠를 생성하지 않도록 제한하며, 특정 비즈니스 규칙을 따르도록 제어할 수 있습니다.사용자는 YAML 또는 Python 파일을 통해 대화 규칙(Rails)을 정의하고, 이를 기반으로 AI 응답을 필터링하거나 수정할 수 있습니다.Amazon Bedrock에서 AI 안전 기능으로도 제공합니다.간단한 네모 가드레일 사용 방법에 대해 알아보겠습니다.Guardrails에서 사용되는 AI 모델과 작업 환경을 정의하는 데 yaml을 사용됩니다.이 파일은 Guardrails의 동작 방식을 설정하는 핵심 구성 요소로, AI 모델 유형, 엔진, 파라미터 등을 정의합니다.• Rails는 특정 시나리오에 대해 AI가 따라야 하는 규칙입니다.• Python 및 YAML 파일을 사용하여 대화 규칙을 정의합니다.• None models: Guardrails에서 사용할 AI 모델을 정의합니다. 여러 개의 모델을 지정할 수 있으며, 각 모델은 역할에 따라 구분됩니다.• None type: 주로 대화를 생성하거나 질문에 답변하는 주요 모델 정보• None engine: Guardrails가 사용할 API 또는 플랫폼을 지정합니다.• None model: 사용할 모델 이름을 지정합니다.• None parameters (선택 사항):모델의 동작을 제어하는 추가 파라미터를 정의합니다.• None temperature: 응답의 다양성을 제어 (0.0 ~ 1.0).• None app : Guardrails 애플리케이션 전반의 동작을 설정합니다.• None• None max_turns: 한 대화 세션에서의 최대 대화 턴 수.OpenAI API 기반 설정을 하려면 아래와 같이 작성합니다.Hugging Face 모델 기반 설정은 엔진에 허깅페이스를 넣어주고 허깅페이스에서 지원하는 모델을 넣습니다.• None 엔진 및 모델 이름 일치: 엔진(engine)과 모델(model)의 이름은 지원되는 플랫폼의 정확한 모델 이름이어야 합니다.• None 파라미터 설정 유효성: 사용 중인 엔진에 따라 지원되지 않는 파라미터를 지정하면 에러가 발생할 수 있습니다.• None 환경 변수 활용: API 키와 같은 민감한 정보는 코드에서 직접 설정하지 않고, 환경 변수로 설정하여 os.environ 등을 통해 사용할 수 있습니다.yaml 파일은 RailsConfig로 읽어 Guardrails 설정에 활용됩니다:yaml은 Guardrails 동작의 유연성과 확장성을 제공합니다.필요에 따라 다양한 엔진과 설정을 조합해 활용할 수 있습니다. rules.yaml 을 아래 내용을 작성합니다."죄송합니다. 폭력적인 영화 추천은 도와드릴 수 없습니다." "가족과 함께 즐길 수 있는 영화 추천: 1. Finding Nemo 2. Toy Story 3. Coco" replace_response "죄송합니다
2025.01.17
좋아요
별로에요
지상무기체계 개방형 시스템 아키텍처 알아보기 (4)
안녕하세요! 현대자동차그룹의 현대로템 전기전자시스템팀에서 전차의 전장품을 개발하고 있는 송혜진 책임연구원입니다.지난 시간에는 NGVA 표준의 2장, 전원 및 하부시스템이 연결되는 전력 인터페이스에 대한 이야기를 나눠봤습니다. 전력의 설계를 일정하게 유지하고, 연결된 커넥터나 하부 시스템을 동일하게 유지할 수 있는 내용이었죠.오늘은 3장, 데이터 연동에 대한 내용을 알아보겠습니다.1) NGVA 3장: 데이터 연동3장은 NGVA의 데이터를 형성하는 인터페이스 및 프로토콜에 대한 설계 제약에 대해 정의하고 있습니다. 케이블, 플러그, 데이터 교환 및 미들웨어까지의 패킷 레이어 및 데이터 네트워크로 구성되어있습니다. 구성은 아래와 같습니다.-1개 이상의 LAN-QoS(Quality of Service, 적합한 서비스 품질)을 갖춘 유선 프로토콜과 NGVA 데이터 모델-네트워크 서비스, 물리적 인터페이스-오디오 및 비디오 스트리밍 데이터 및 제어 프로토콜, 디지털 음성 유형별 제어 및 코덱-레거시 시스템(기존 전장품)은 필요시 게이트웨이를 통해 설계 적용 (ex.데이터 컨버터, 영상 컨버터)NGVA 시스템을 적용하기 위해서는 체계 내 연동되는 데이터의 성격을 분류하고, 그에 따른 데이터 버스를 구축합니다. 대표적인 예로 데이터는 영상&오디오 데이터, 제어 데이터, 세이프티 데이터, 시큐어 데이터 등으로 나누어서 각각에 대한 데이터 버스를 각각 구축합니다. 이처럼 데이터 버스를 분리하는 이유는 영상&오디오 데이터나 기타 데이터 들의 트래픽을 분리하기 위해서입니다. 또한 NGVA 시스템을 적용한다고 해도 모든 하위 전장품이 그 표준을 따를 수는 없기 때문에 NGVA 미적용 전장품들은 아래 그림의 Internal Gateways를 구성하여 이더넷 프로토콜로 바꾼 후, 이더넷 버스에 올리게 됩니다.그림1. NGVA 적용 데이터 버스 예시2) 데이터 버스 분리NGVA를 적용하기 전에는 카메라 영상 데이터를 예를 들면 직접적으로 카메라와 연결된 전시기에서만 볼 수 있었지만 NGVA 표준을 적용하면 영상&음성 버스에 올라간 데이터 들은, 버스와 연결된 다른 전시기에서도 똑같은 데이터를 볼 수 있게 됩니다.특히나 전투체계에서 카메라가 점점 발달하고 있는 지금, 영상 데이터용 데이터 버스는 360도 상황인식 시스템 등 영상 기반의 대용량 데이터를 공유하기 위해서 필요하게 됩니다. 또한 보안이 필요한 데이터도 특히 중요해져서 보안 데이터를 위한 별도의 버스를 추가로 구성하여 네트워크를 이중화할 수도 있습니다. 데이터는 각기 다른 네트워크를 사용하거나 VLAN(Virtual Local Area Nwtwork,가상랜)을 사용하여 실시간 데이터와 비실시간 데이터를 분리할 수도 있습니다. 많은 양의 실시간 데이터를 위해서 네트워크를 분리한다고 생각하시면 이해가 쉬울까요?3) 기존 장비와의 연동 방안위에서 설명 드렸던 Internal Gateways는 개방형 시스템 아키텍처를 처음 도입하는 체계에서 매우 중요한 요소입니다. 개방형 시스템 아키텍처를 적용한다고 해서 모든 장비를 동시에 한꺼번에 교체하는 일은 매우 어렵습니다. 모두 동일한 프로토콜이나 인터페이스를 맞추어 제작한다면 좋겠지만, 그 일은 기존 장비를 대체하는 데에 시간이 매우 많이 걸릴뿐만 아니라 개발 리스크도 굉장히 크게 증가합니다.그래서 Internal Gateways, 일명 데이터 변환 장치라는 제품을 구축하게 됩니다. 1)에서 설명했던 구성 중 마지막에 따라 레거시 시스템(기존 전장품)은 필요시 게이트웨이를 통해 설계 적용 (ex.데이터 컨버터, 영상 컨버터)을 하게 됩니다. 기존에 있는 데이터를 주고받을 수도 있고, 새롭게 추가된 전장품의 데이터를 저장하고 보내주는 심장같은 역할을 하죠. 기존 중앙컴퓨터에 집중되어 있던 데이터를 분산 처리하는 역할도 하며, NGVA 표준을 적용하기 위한 DDS(Data Distribution Service) 미들웨어 사용에 필요한 이더넷 규격 이외의 통신을 수행하는 장비의 데이터를 실시간으로 수집하고 가공하여 데이터 버스 전체에 공유될 수 있도록 합니다. DDS가 무엇인지에 대해서는 다음 시간에 조금 더 살펴보도록 하겠습니다.[출처]지상무기체계 성능개량을 위한 개방형 시스템 아키텍처 및 데이터 모델 설계, 한동휘 외, 한국정보기술학회논문NATO Generic Vehicle Architecture NATO Generic Vehicle Architecture (natogva.org)Generic Vehicle Architecture (GVA)-Generic Vehicle Architecture (GVA) - Think Defence
1/17/2025
지상무기체계 개방형 시스템 아키텍처 알아보기 (4)
안녕하세요! 현대자동차그룹의 현대로템 전기전자시스템팀에서 전차의 전장품을 개발하고 있는 송혜진 책임연구원입니다.지난 시간에는 NGVA 표준의 2장, 전원 및 하부시스템이 연결되는 전력 인터페이스에 대한 이야기를 나눠봤습니다. 전력의 설계를 일정하게 유지하고, 연결된 커넥터나 하부 시스템을 동일하게 유지할 수 있는 내용이었죠.오늘은 3장, 데이터 연동에 대한 내용을 알아보겠습니다.1) NGVA 3장: 데이터 연동3장은 NGVA의 데이터를 형성하는 인터페이스 및 프로토콜에 대한 설계 제약에 대해 정의하고 있습니다. 케이블, 플러그, 데이터 교환 및 미들웨어까지의 패킷 레이어 및 데이터 네트워크로 구성되어있습니다. 구성은 아래와 같습니다.-1개 이상의 LAN-QoS(Quality of Service, 적합한 서비스 품질)을 갖춘 유선 프로토콜과 NGVA 데이터 모델-네트워크 서비스, 물리적 인터페이스-오디오 및 비디오 스트리밍 데이터 및 제어 프로토콜, 디지털 음성 유형별 제어 및 코덱-레거시 시스템(기존 전장품)은 필요시 게이트웨이를 통해 설계 적용 (ex.데이터 컨버터, 영상 컨버터)NGVA 시스템을 적용하기 위해서는 체계 내 연동되는 데이터의 성격을 분류하고, 그에 따른 데이터 버스를 구축합니다. 대표적인 예로 데이터는 영상&오디오 데이터, 제어 데이터, 세이프티 데이터, 시큐어 데이터 등으로 나누어서 각각에 대한 데이터 버스를 각각 구축합니다. 이처럼 데이터 버스를 분리하는 이유는 영상&오디오 데이터나 기타 데이터 들의 트래픽을 분리하기 위해서입니다. 또한 NGVA 시스템을 적용한다고 해도 모든 하위 전장품이 그 표준을 따를 수는 없기 때문에 NGVA 미적용 전장품들은 아래 그림의 Internal Gateways를 구성하여 이더넷 프로토콜로 바꾼 후, 이더넷 버스에 올리게 됩니다.그림1. NGVA 적용 데이터 버스 예시2) 데이터 버스 분리NGVA를 적용하기 전에는 카메라 영상 데이터를 예를 들면 직접적으로 카메라와 연결된 전시기에서만 볼 수 있었지만 NGVA 표준을 적용하면 영상&음성 버스에 올라간 데이터 들은, 버스와 연결된 다른 전시기에서도 똑같은 데이터를 볼 수 있게 됩니다.특히나 전투체계에서 카메라가 점점 발달하고 있는 지금, 영상 데이터용 데이터 버스는 360도 상황인식 시스템 등 영상 기반의 대용량 데이터를 공유하기 위해서 필요하게 됩니다. 또한 보안이 필요한 데이터도 특히 중요해져서 보안 데이터를 위한 별도의 버스를 추가로 구성하여 네트워크를 이중화할 수도 있습니다. 데이터는 각기 다른 네트워크를 사용하거나 VLAN(Virtual Local Area Nwtwork,가상랜)을 사용하여 실시간 데이터와 비실시간 데이터를 분리할 수도 있습니다. 많은 양의 실시간 데이터를 위해서 네트워크를 분리한다고 생각하시면 이해가 쉬울까요?3) 기존 장비와의 연동 방안위에서 설명 드렸던 Internal Gateways는 개방형 시스템 아키텍처를 처음 도입하는 체계에서 매우 중요한 요소입니다. 개방형 시스템 아키텍처를 적용한다고 해서 모든 장비를 동시에 한꺼번에 교체하는 일은 매우 어렵습니다. 모두 동일한 프로토콜이나 인터페이스를 맞추어 제작한다면 좋겠지만, 그 일은 기존 장비를 대체하는 데에 시간이 매우 많이 걸릴뿐만 아니라 개발 리스크도 굉장히 크게 증가합니다.그래서 Internal Gateways, 일명 데이터 변환 장치라는 제품을 구축하게 됩니다. 1)에서 설명했던 구성 중 마지막에 따라 레거시 시스템(기존 전장품)은 필요시 게이트웨이를 통해 설계 적용 (ex.데이터 컨버터, 영상 컨버터)을 하게 됩니다. 기존에 있는 데이터를 주고받을 수도 있고, 새롭게 추가된 전장품의 데이터를 저장하고 보내주는 심장같은 역할을 하죠. 기존 중앙컴퓨터에 집중되어 있던 데이터를 분산 처리하는 역할도 하며, NGVA 표준을 적용하기 위한 DDS(Data Distribution Service) 미들웨어 사용에 필요한 이더넷 규격 이외의 통신을 수행하는 장비의 데이터를 실시간으로 수집하고 가공하여 데이터 버스 전체에 공유될 수 있도록 합니다. DDS가 무엇인지에 대해서는 다음 시간에 조금 더 살펴보도록 하겠습니다.[출처]지상무기체계 성능개량을 위한 개방형 시스템 아키텍처 및 데이터 모델 설계, 한동휘 외, 한국정보기술학회논문NATO Generic Vehicle Architecture NATO Generic Vehicle Architecture (natogva.org)Generic Vehicle Architecture (GVA)-Generic Vehicle Architecture (GVA) - Think Defence
2025.01.17
좋아요
별로에요
디자인 시스템 이전으로 돌아가실래요? (1)
글. 김지영(Terna) / Platform Design Team Lead부제. 디자인 시스템 운영의 명암디자인 시스템이 없던 시절로 돌아간다고 생각해보세요. 그때는 대체 어떻게 그 많은 반복 작업을 해냈을까요? 가끔 피그마 라이브러리가 사라지는 상상을 하면 정말 아찔해지곤 해요. 그만큼 지금은 디자인 시스템이 없어서는 안 될 존재가 됐죠. 요즘은 대부분의 서비스가 일관성과 효율성을 위해 디자인 시스템을 구축하고 운영하고 있는데, 여기어때 역시 ‘YDS(Yeogi Design System)’라는 이름으로 자체 디자인 시스템을 운영하고 있어요.저는 23년 하반기부터 YDS를 맡아 운영하게 되었는데요, 그 과정에서 새로운 비효율을 마주하게 됐고, 이를 개선하기 위해 다양한 시도를 하게 되었어요. 이번 글에서는 비효율을 발견했던 과정과, 그걸 개선해나간 경험을 나눠보려 합니다.디자인 시스템 = 새로운 프로덕트제가 YDS 업무를 맡았을 때, 여기어때는 이미 앱 내 UI 패턴을 기반으로 한 피그마 라이브러리가 있었고, 본격적으로 컴포넌트도 개발 중이었어요.완전한 무에서 시작하는 건 아니어서 다행이었지만, 애매한 시점에 인볼브된 것 같다는 생각이 들더라고요. 단순히 개발 대응을 넘어 YDS에 어떤 기여를 할 수 있을지 고민이 많았죠.지금 돌아보면 그런 고민이 생긴 이유는 제가 디자인 시스템을 그저 구조적이고 일관된 UI 라이브러리로만 봤기 때문인 것 같아요. ‘컴포넌트를 잘 만들면 당연히 잘 쓰이겠지’라고 단순하게 생각했던 거죠. 물론, 그게 디자인 시스템에 핵심인 건 맞지만, 한 달 동안 초심자의 마음으로 기존 가이드랑 컴포넌트를 뜯어보고, UX Designerr와 개발자의 문의에 대응하면서 그게 전부는 아니라는 걸 깨달았어요.컴포넌트를 잘 만들어도 효율적으로 쓰이는 것은 완전히 다른 문제더라구요. 결국, 초기 라이브러리 구축 이후의 디자인 시스템은 단순히 리소스를 모아놓은 게 아니라 하나의 새로운 프로덕트가 된다는 결론에 다다르게 됐어요.효율 속의 비효율효율성을 높이고자 만든 디자인 시스템인데 정작 운영하는 과정에 많은 비효율이 존재했는데요. 그 중에서도 당장 해결이 필요하다 느껴지는 부분은 크게 네 가지였어요.1. 버전 추척의 어려움당시 피그마 라이브러리는 계속 업데이트되고 있었지만, 개발은 버전 단위로 업데이트되는게 아니라 필요한 컴포넌트를 그때그때 피처 단위로 개발하는 방식이었어요. 문제는 이렇게 하다 보니 실제 개발된 컴포넌트가 피그마 라이브러리의 어떤 버전에 해당하는지 알 수 있는 방법이 없었어요.그렇다 보니 피그마 라이브러리를 수정할 때마다 개발팀에 넘겨야할 체인지로그를 정리하기가 애매했어요. 일부 스펙이 누락되거나 피그마와 싱크가 안 맞아도 바로 앱에 적용되지 않으니 쉽게 드러나지 않았고요. 개발이 완료됐다는 상태값은 있었지만, 그걸 보고도 이 컴포넌트가 정말 제대로 만들어졌는지 퀄리티를 보장할 수 없는 상황이었죠.2. A/B 테스트와 실험 UI 관리의 문제A/B 테스트로 프로덕트를 고도화하는 조직 특성상, 실험안을 만들 때 피그마
1/17/2025
디자인 시스템 이전으로 돌아가실래요? (1)
글. 김지영(Terna) / Platform Design Team Lead부제. 디자인 시스템 운영의 명암디자인 시스템이 없던 시절로 돌아간다고 생각해보세요. 그때는 대체 어떻게 그 많은 반복 작업을 해냈을까요? 가끔 피그마 라이브러리가 사라지는 상상을 하면 정말 아찔해지곤 해요. 그만큼 지금은 디자인 시스템이 없어서는 안 될 존재가 됐죠. 요즘은 대부분의 서비스가 일관성과 효율성을 위해 디자인 시스템을 구축하고 운영하고 있는데, 여기어때 역시 ‘YDS(Yeogi Design System)’라는 이름으로 자체 디자인 시스템을 운영하고 있어요.저는 23년 하반기부터 YDS를 맡아 운영하게 되었는데요, 그 과정에서 새로운 비효율을 마주하게 됐고, 이를 개선하기 위해 다양한 시도를 하게 되었어요. 이번 글에서는 비효율을 발견했던 과정과, 그걸 개선해나간 경험을 나눠보려 합니다.디자인 시스템 = 새로운 프로덕트제가 YDS 업무를 맡았을 때, 여기어때는 이미 앱 내 UI 패턴을 기반으로 한 피그마 라이브러리가 있었고, 본격적으로 컴포넌트도 개발 중이었어요.완전한 무에서 시작하는 건 아니어서 다행이었지만, 애매한 시점에 인볼브된 것 같다는 생각이 들더라고요. 단순히 개발 대응을 넘어 YDS에 어떤 기여를 할 수 있을지 고민이 많았죠.지금 돌아보면 그런 고민이 생긴 이유는 제가 디자인 시스템을 그저 구조적이고 일관된 UI 라이브러리로만 봤기 때문인 것 같아요. ‘컴포넌트를 잘 만들면 당연히 잘 쓰이겠지’라고 단순하게 생각했던 거죠. 물론, 그게 디자인 시스템에 핵심인 건 맞지만, 한 달 동안 초심자의 마음으로 기존 가이드랑 컴포넌트를 뜯어보고, UX Designerr와 개발자의 문의에 대응하면서 그게 전부는 아니라는 걸 깨달았어요.컴포넌트를 잘 만들어도 효율적으로 쓰이는 것은 완전히 다른 문제더라구요. 결국, 초기 라이브러리 구축 이후의 디자인 시스템은 단순히 리소스를 모아놓은 게 아니라 하나의 새로운 프로덕트가 된다는 결론에 다다르게 됐어요.효율 속의 비효율효율성을 높이고자 만든 디자인 시스템인데 정작 운영하는 과정에 많은 비효율이 존재했는데요. 그 중에서도 당장 해결이 필요하다 느껴지는 부분은 크게 네 가지였어요.1. 버전 추척의 어려움당시 피그마 라이브러리는 계속 업데이트되고 있었지만, 개발은 버전 단위로 업데이트되는게 아니라 필요한 컴포넌트를 그때그때 피처 단위로 개발하는 방식이었어요. 문제는 이렇게 하다 보니 실제 개발된 컴포넌트가 피그마 라이브러리의 어떤 버전에 해당하는지 알 수 있는 방법이 없었어요.그렇다 보니 피그마 라이브러리를 수정할 때마다 개발팀에 넘겨야할 체인지로그를 정리하기가 애매했어요. 일부 스펙이 누락되거나 피그마와 싱크가 안 맞아도 바로 앱에 적용되지 않으니 쉽게 드러나지 않았고요. 개발이 완료됐다는 상태값은 있었지만, 그걸 보고도 이 컴포넌트가 정말 제대로 만들어졌는지 퀄리티를 보장할 수 없는 상황이었죠.2. A/B 테스트와 실험 UI 관리의 문제A/B 테스트로 프로덕트를 고도화하는 조직 특성상, 실험안을 만들 때 피그마
2025.01.17
좋아요
별로에요
토스 피플: 비전공자에서 디자인 리드가 되기까지
이번 토스 피플에서는 쇼핑 탭을 맡고 있는 이혜인님의 인터뷰를 공유드려요. 토스는 금융 앱이기도 하지만 다양한 혜택 기능들로 ‘앱테크’로서 사랑을 받고 있기도 한데요. 받은 혜택으로 할인을 받아 구매하기도 하고, 혜택 구조를 활용해서 제휴사와 협의해 좋은 물건을 저렴하게 판매하고, 토스 밖에서도 토스 페이를 쓰고 있죠. 토스 쇼핑은 토스의 세계관을 완성하는 일이라고 할 수 있어요.혜인님은 원래 디자인을 전공하진 않으셨다고 들었어요. 어쩌다 UX 디자인을 시작하게 되신 거예요?처음에는 공대에 다니다가 나중에 미대에 들어갔어요. 제 전공은 제품 디자인이었는데, 일찍 재능이 없다는 걸 알았어요. 고등학교 때, 한창 뇌가 말랑말랑할 때부터 미술을 공부한 친구들을 절대 못 따라 잡겠는 거예요. 저는 계속 현실적인 얘기를 하는데, 그 친구들은 되게 열린 사고를 하는 거죠. 막 하늘을 날아다니는 자동차 얘기를 하는 동안 저는… (웃음)그러다 우연히 UX 수업을 듣게 됐는데, 그게 저한테는 너무 쉬운 거예요. ‘어떻게 그렇게 쉽게 화면을 그려?’하고 같은 수업 듣는 친구가 물어봐서 ‘어, 내가 이건 잘하나?’ 생각하게 됐어요. 재능 발견 이런 느낌.그렇게 처음으로 UX 디자이너로 입사하게 되신 거군요.맞아요. 2013년도 쯤? 휴학하고 스타트업에 취업했었어요. 그런데 학교에서 와이어프레임 만드는 건 쉬웠는데, 아름다운 화면을 만드는 건 또 다른 문제더라고요. 당시엔 스큐어모피즘이 대세였는데, 화면 위에서 실제 물체와 유사한 디테일과 텍스쳐를 재현해야 했거든요. 원하는 디자인을 만들고 싶으면 그래픽을 잘하는 것도 중요했지만 그걸 어떻게 구현할지에 대한 이해도 필요했었어요.그래서 개발을 배우는 프로그램에 참여했었어요. 거기서 또 재능이 없다는 걸 깨달았어요. 프로그램의 목표는 풀스택 개발자로 양성하는 거였는데, ‘나는 개발 짱 못해.’하면서 프론트 엔드까지만 배우고 나왔어요. 그런데 그게 두고두고 도움이 되더라고요. 화면이 그려지는 동작 방식을 이해하니까 개발자 분들과 협업하면서 가이드를 드릴 때 효과적으로 드릴 수 있게 됐어요. 예전에는 그림 그리듯이 화면을 드렸거든요.와, 졸업하기도 전인데 정말 많은 경험을 하셨었네요.그렇게 졸업하고서 취업 준비를 하는데… 다 떨어지는 거예요. 좋은 UX를 하는 회사가 없기도 했어요. 디자이너가 갈 수 있는 회사가 카카오, 네이버, 삼성 디자인 멤버십 정도가 전부였던 것 같아요. 대기업도 넣어봤는데 다 떨어졌고요. 그러다 쿠팡에서 경력직을 채용하고 있었는데, 스타트업 다녔을 때의 포트폴리오로 입사하게 됐어요. 회사에서도 베팅으로 주니어를 한 번 채용해볼까?해서 운좋게 들어가게 된 것 같아요.거기서 오래 근무하시기도 했고, 그때의 경험이 지금 제품에도 영향을 끼치고 있는 것 같아요.맞아요. 당시 엄청 가고 싶은 회사 중 하나였어요. 그래서 만족도가 급상승했었죠. 데이터를 중요하게 생각하는 회사였는데, 지금 생각해보면 데이터로 일하는 환경이 쉽게 주어지는 게 아니었더라고요. 아름다운 화면을 추구하는 건 아니었지만 사용자
1/16/2025
토스 피플: 비전공자에서 디자인 리드가 되기까지
이번 토스 피플에서는 쇼핑 탭을 맡고 있는 이혜인님의 인터뷰를 공유드려요. 토스는 금융 앱이기도 하지만 다양한 혜택 기능들로 ‘앱테크’로서 사랑을 받고 있기도 한데요. 받은 혜택으로 할인을 받아 구매하기도 하고, 혜택 구조를 활용해서 제휴사와 협의해 좋은 물건을 저렴하게 판매하고, 토스 밖에서도 토스 페이를 쓰고 있죠. 토스 쇼핑은 토스의 세계관을 완성하는 일이라고 할 수 있어요.혜인님은 원래 디자인을 전공하진 않으셨다고 들었어요. 어쩌다 UX 디자인을 시작하게 되신 거예요?처음에는 공대에 다니다가 나중에 미대에 들어갔어요. 제 전공은 제품 디자인이었는데, 일찍 재능이 없다는 걸 알았어요. 고등학교 때, 한창 뇌가 말랑말랑할 때부터 미술을 공부한 친구들을 절대 못 따라 잡겠는 거예요. 저는 계속 현실적인 얘기를 하는데, 그 친구들은 되게 열린 사고를 하는 거죠. 막 하늘을 날아다니는 자동차 얘기를 하는 동안 저는… (웃음)그러다 우연히 UX 수업을 듣게 됐는데, 그게 저한테는 너무 쉬운 거예요. ‘어떻게 그렇게 쉽게 화면을 그려?’하고 같은 수업 듣는 친구가 물어봐서 ‘어, 내가 이건 잘하나?’ 생각하게 됐어요. 재능 발견 이런 느낌.그렇게 처음으로 UX 디자이너로 입사하게 되신 거군요.맞아요. 2013년도 쯤? 휴학하고 스타트업에 취업했었어요. 그런데 학교에서 와이어프레임 만드는 건 쉬웠는데, 아름다운 화면을 만드는 건 또 다른 문제더라고요. 당시엔 스큐어모피즘이 대세였는데, 화면 위에서 실제 물체와 유사한 디테일과 텍스쳐를 재현해야 했거든요. 원하는 디자인을 만들고 싶으면 그래픽을 잘하는 것도 중요했지만 그걸 어떻게 구현할지에 대한 이해도 필요했었어요.그래서 개발을 배우는 프로그램에 참여했었어요. 거기서 또 재능이 없다는 걸 깨달았어요. 프로그램의 목표는 풀스택 개발자로 양성하는 거였는데, ‘나는 개발 짱 못해.’하면서 프론트 엔드까지만 배우고 나왔어요. 그런데 그게 두고두고 도움이 되더라고요. 화면이 그려지는 동작 방식을 이해하니까 개발자 분들과 협업하면서 가이드를 드릴 때 효과적으로 드릴 수 있게 됐어요. 예전에는 그림 그리듯이 화면을 드렸거든요.와, 졸업하기도 전인데 정말 많은 경험을 하셨었네요.그렇게 졸업하고서 취업 준비를 하는데… 다 떨어지는 거예요. 좋은 UX를 하는 회사가 없기도 했어요. 디자이너가 갈 수 있는 회사가 카카오, 네이버, 삼성 디자인 멤버십 정도가 전부였던 것 같아요. 대기업도 넣어봤는데 다 떨어졌고요. 그러다 쿠팡에서 경력직을 채용하고 있었는데, 스타트업 다녔을 때의 포트폴리오로 입사하게 됐어요. 회사에서도 베팅으로 주니어를 한 번 채용해볼까?해서 운좋게 들어가게 된 것 같아요.거기서 오래 근무하시기도 했고, 그때의 경험이 지금 제품에도 영향을 끼치고 있는 것 같아요.맞아요. 당시 엄청 가고 싶은 회사 중 하나였어요. 그래서 만족도가 급상승했었죠. 데이터를 중요하게 생각하는 회사였는데, 지금 생각해보면 데이터로 일하는 환경이 쉽게 주어지는 게 아니었더라고요. 아름다운 화면을 추구하는 건 아니었지만 사용자
2025.01.16
좋아요
별로에요
Ingress Nginx Controller의 Prometheus Metric 병목 현상: 원인 분석과 해결 (2부)
광고추천 조직에서 타게팅 광고 서빙 시스템을 담당하고 있는 에이든입니다.안녕하세요. 카카오 광고추천팀에서 광고 추천 개발 업무를 담당하고 있는 aiden.song입니다. 이번 글은 ingress nginx controller의 대용량 트래픽 환경에서의 병목 현상 분석의 두 번째 글로 1부에서 문제 발생의 배경과 ingress-nginx-controller의 구조적인 측면에서 발생했던 원인에 대해 파악 했다면, 2부에서는 controller에서 병목이 발생한 근본적인 원인을 찾는 과정과 이를 해결하는 방법에 대해 정리해보겠습니다.본론에 들어가기에 앞서 본 글은 golang과 kubernetes 그리고 prometheus에 대한 기본적인 이해가 필요합니다. golang은 자체적인 문법이 간단해서 초보자가 코드를 봐도 이해하기 어렵지 않으나 kubernetes와 prometheus에 대해서는 사용해본 경험이 있는 수준의 배경 지식이 있어야 본론을 이해하기 수월합니다. 각 기술셋에 대한 자세한 내용을 모두 설명하기는 어려우나 설명 중간중간에 최대한 이해를 도울 수 있게 설명을 해보도록 해보겠습니다.1부에서 간단하게 설명했던 Ingress Nginx Controller(이하 IC)에 대해 조금 더 설명을 해보겠습니다. IC는 kubernetes에서 Pod 형태로 실행됩니다. IC Pod 내부에는 크게 세 종류의 프로세스가 실행되며 IC, Nginx master, Nginx worker가 이에 해당합니다. 이 세 종류의 프로세스는 Pod의 리소스를 공유합니다. 이런 구조 때문에 Nginx Master나 Worker 프로세스 뿐만 아니라 IC 프로세스 메모리 사용량이 늘어나게 되면 IC Pod의 메모리 사용량이 증가하게됩니다. 마지막으로 IC 프로세스의 주요 역할은 아래와 같습니다• Nginx의 master, worker 프로세스를 실행하고 관리• kubernetes 리소스로 관리되는 Nginx 관련 설정들을 Nginx 프로세스와 동기화이번 트러블 슈팅 과정에서 중심적으로 살펴볼 IC 프로세스의 동작은 마지막 항목인 메트릭 수집 부분입니다.1부에서 nginx worker가 생성하는 메트릭들을 소켓 통신을 통해 IC 프로세스로 전달되고, 이 메트릭들을 처리하는 과정에서 병목이 발생할것으로 추정하며 마무리 했었습니다. 이번에는 해당 추정이 맞았는지 확인하는 과정, 그리고 병목 현상을 해결하는 방법을 찾는 과정을 자세히 정리해보겠습니다.go는 자체적으로 프로세스를 진단할 수 있는 프로파일 기능을 풍부하게 지원하고 있고 간단한 설정 및 CLI을 활용해 모니터링이 가능합니다. 관련해서 프로파일 설정 및 자세한 활용 방법에 대해서는 카카오 테크 블로그의 “Golang GC 튜닝 가이드 포스트”(https://tech.kakao.com/posts/618)를 참고하시면 좋습니다. 앞서 안에 고루틴 영역을 병목지점으로 추정했으니, 실제로 해당 지점에 병목이 있는지를 goroutin 프로파일을 통해서 확인해 봤습니다.goroutine 프로파일에서 가장 많은(4309개
go
kubernetes
prometheus
1/16/2025
Ingress Nginx Controller의 Prometheus Metric 병목 현상: 원인 분석과 해결 (2부)
광고추천 조직에서 타게팅 광고 서빙 시스템을 담당하고 있는 에이든입니다.안녕하세요. 카카오 광고추천팀에서 광고 추천 개발 업무를 담당하고 있는 aiden.song입니다. 이번 글은 ingress nginx controller의 대용량 트래픽 환경에서의 병목 현상 분석의 두 번째 글로 1부에서 문제 발생의 배경과 ingress-nginx-controller의 구조적인 측면에서 발생했던 원인에 대해 파악 했다면, 2부에서는 controller에서 병목이 발생한 근본적인 원인을 찾는 과정과 이를 해결하는 방법에 대해 정리해보겠습니다.본론에 들어가기에 앞서 본 글은 golang과 kubernetes 그리고 prometheus에 대한 기본적인 이해가 필요합니다. golang은 자체적인 문법이 간단해서 초보자가 코드를 봐도 이해하기 어렵지 않으나 kubernetes와 prometheus에 대해서는 사용해본 경험이 있는 수준의 배경 지식이 있어야 본론을 이해하기 수월합니다. 각 기술셋에 대한 자세한 내용을 모두 설명하기는 어려우나 설명 중간중간에 최대한 이해를 도울 수 있게 설명을 해보도록 해보겠습니다.1부에서 간단하게 설명했던 Ingress Nginx Controller(이하 IC)에 대해 조금 더 설명을 해보겠습니다. IC는 kubernetes에서 Pod 형태로 실행됩니다. IC Pod 내부에는 크게 세 종류의 프로세스가 실행되며 IC, Nginx master, Nginx worker가 이에 해당합니다. 이 세 종류의 프로세스는 Pod의 리소스를 공유합니다. 이런 구조 때문에 Nginx Master나 Worker 프로세스 뿐만 아니라 IC 프로세스 메모리 사용량이 늘어나게 되면 IC Pod의 메모리 사용량이 증가하게됩니다. 마지막으로 IC 프로세스의 주요 역할은 아래와 같습니다• Nginx의 master, worker 프로세스를 실행하고 관리• kubernetes 리소스로 관리되는 Nginx 관련 설정들을 Nginx 프로세스와 동기화이번 트러블 슈팅 과정에서 중심적으로 살펴볼 IC 프로세스의 동작은 마지막 항목인 메트릭 수집 부분입니다.1부에서 nginx worker가 생성하는 메트릭들을 소켓 통신을 통해 IC 프로세스로 전달되고, 이 메트릭들을 처리하는 과정에서 병목이 발생할것으로 추정하며 마무리 했었습니다. 이번에는 해당 추정이 맞았는지 확인하는 과정, 그리고 병목 현상을 해결하는 방법을 찾는 과정을 자세히 정리해보겠습니다.go는 자체적으로 프로세스를 진단할 수 있는 프로파일 기능을 풍부하게 지원하고 있고 간단한 설정 및 CLI을 활용해 모니터링이 가능합니다. 관련해서 프로파일 설정 및 자세한 활용 방법에 대해서는 카카오 테크 블로그의 “Golang GC 튜닝 가이드 포스트”(https://tech.kakao.com/posts/618)를 참고하시면 좋습니다. 앞서 안에 고루틴 영역을 병목지점으로 추정했으니, 실제로 해당 지점에 병목이 있는지를 goroutin 프로파일을 통해서 확인해 봤습니다.goroutine 프로파일에서 가장 많은(4309개
2025.01.16
go
kubernetes
prometheus
좋아요
별로에요
Ingress Nginx Controller의 Prometheus Metric 병목 현상: 원인 분석과 해결 (1부)
안녕하세요 광고추천 조직에서 타게팅 광고 서빙 시스템을 당당하고 있는 푸입니다.안녕하세요. 카카오 광고 추천팀에서 광고 추천 개발 업무를 담당하는 pooh.duck입니다. 이 글에서는 Ingress Nginx Controller에서 발생한 Prometheus metric 병목 현상에 대한 원인 분석과 해결 방법을 소개합니다. 본 글은 1부와 2부로 구성되어 있으며, 실무에서 Trouble Shooting을 어떻게 하는지, Ingress Nginx Controller, Go 프로파일링에 관한 내용을 담고 있습니다. 1부에서는 문제 발생의 배경과 원인 분석 과정을 상세히 설명하고, 2부에서는 이를 바탕으로 한 해결 방법을 소개합니다. 단계별로 우리 팀이 겪었던 실제 사례와 적용했던 방법들을 공유하며, 비슷한 문제를 겪고 있는 다른 분들께 도움이 되기를 기대합니다.우리는 웹사이트를 방문할 때마다 다양한 광고를 접하게 됩니다. 이러한 광고가 사용자에게 노출되기까지 여러 카카오 광고 API 서버들이 상호작용을 하게 되고, 이에 따라 대부분의 광고 API 서버들은 평균적으로 매우 높은 트래픽을 받게 됩니다. 제가 담당하는 API 서버 중 하나는 피크 시간대에 최대 약 16만 req/sec의 요청을 처리하고 있습니다.대용량 트래픽을 처리하기 위해서, 저희 API 서버는 Kubernetes 위에서 다수 Pod를 실행 중입니다. 이 서버들에 HTTP(S) 트래픽을 라우팅하기 위해 Ingress를 사용하고 있으며, 구현체로는 가장 범용적으로 사용되는 Ingress Nginx Controller를 채택하고 있습니다.현재 저희는 재해 복구(Disaster Recovery)와 부하 분산을 위해 두 개의 Region에 걸쳐 다수의 Ingress Nginx Controller를 구성해 운영하고 있습니다.저희는 서비스 모니터링을 위해 서버에서 발생하는 Metric들을 Prometheus로 수집하고, Grafana를 통해 모니터링하고 있습니다. 그러던 어느 날 모든 Nginx 'request volume’이 No Data라는 알람이 발생했습니다. 또한, 간헐적으로 기록되는 Metric도 정상치에 비해 매우 낮게 기록되는 것을 확인할 수 있었습니다.Request Volume은 Nginx의 Prometheus Metric 중 하나로, 현재 Nginx가 처리하는 Request Count를 뜻합니다. 이 값이 Null이라는 것은 현재 Nginx 자체에 문제가 발생해 트래픽을 제대로 처리하지 못하고 있거나, Nginx가 처리하는 요청에 대한 metric이 정상적으로 수집되지 않는 상태임을 뜻합니다. 이에, 서비스를 점검해 보니 서버는 요청을 정상적으로 처리하고 있었습니다. 만약 Nginx에 문제가 생겼다면 이는 불가능한 일입니다.이러한 현상은 트래픽이 일정 기준치를 상회하면 재현된다는 것을 확인할 수 있었습니다. 아래와 그래프와 같이 Metric이 요동치다, Metric이 유실되고 이후 트래픽이 감소하면 Metric이 복구되는 것을 관찰할 수 있었습니다. 아래 그래프는 Ing
go
1/16/2025
Ingress Nginx Controller의 Prometheus Metric 병목 현상: 원인 분석과 해결 (1부)
안녕하세요 광고추천 조직에서 타게팅 광고 서빙 시스템을 당당하고 있는 푸입니다.안녕하세요. 카카오 광고 추천팀에서 광고 추천 개발 업무를 담당하는 pooh.duck입니다. 이 글에서는 Ingress Nginx Controller에서 발생한 Prometheus metric 병목 현상에 대한 원인 분석과 해결 방법을 소개합니다. 본 글은 1부와 2부로 구성되어 있으며, 실무에서 Trouble Shooting을 어떻게 하는지, Ingress Nginx Controller, Go 프로파일링에 관한 내용을 담고 있습니다. 1부에서는 문제 발생의 배경과 원인 분석 과정을 상세히 설명하고, 2부에서는 이를 바탕으로 한 해결 방법을 소개합니다. 단계별로 우리 팀이 겪었던 실제 사례와 적용했던 방법들을 공유하며, 비슷한 문제를 겪고 있는 다른 분들께 도움이 되기를 기대합니다.우리는 웹사이트를 방문할 때마다 다양한 광고를 접하게 됩니다. 이러한 광고가 사용자에게 노출되기까지 여러 카카오 광고 API 서버들이 상호작용을 하게 되고, 이에 따라 대부분의 광고 API 서버들은 평균적으로 매우 높은 트래픽을 받게 됩니다. 제가 담당하는 API 서버 중 하나는 피크 시간대에 최대 약 16만 req/sec의 요청을 처리하고 있습니다.대용량 트래픽을 처리하기 위해서, 저희 API 서버는 Kubernetes 위에서 다수 Pod를 실행 중입니다. 이 서버들에 HTTP(S) 트래픽을 라우팅하기 위해 Ingress를 사용하고 있으며, 구현체로는 가장 범용적으로 사용되는 Ingress Nginx Controller를 채택하고 있습니다.현재 저희는 재해 복구(Disaster Recovery)와 부하 분산을 위해 두 개의 Region에 걸쳐 다수의 Ingress Nginx Controller를 구성해 운영하고 있습니다.저희는 서비스 모니터링을 위해 서버에서 발생하는 Metric들을 Prometheus로 수집하고, Grafana를 통해 모니터링하고 있습니다. 그러던 어느 날 모든 Nginx 'request volume’이 No Data라는 알람이 발생했습니다. 또한, 간헐적으로 기록되는 Metric도 정상치에 비해 매우 낮게 기록되는 것을 확인할 수 있었습니다.Request Volume은 Nginx의 Prometheus Metric 중 하나로, 현재 Nginx가 처리하는 Request Count를 뜻합니다. 이 값이 Null이라는 것은 현재 Nginx 자체에 문제가 발생해 트래픽을 제대로 처리하지 못하고 있거나, Nginx가 처리하는 요청에 대한 metric이 정상적으로 수집되지 않는 상태임을 뜻합니다. 이에, 서비스를 점검해 보니 서버는 요청을 정상적으로 처리하고 있었습니다. 만약 Nginx에 문제가 생겼다면 이는 불가능한 일입니다.이러한 현상은 트래픽이 일정 기준치를 상회하면 재현된다는 것을 확인할 수 있었습니다. 아래와 그래프와 같이 Metric이 요동치다, Metric이 유실되고 이후 트래픽이 감소하면 Metric이 복구되는 것을 관찰할 수 있었습니다. 아래 그래프는 Ing
2025.01.16
go
좋아요
별로에요
브라우저 기반 IPFS 네트워크 동향 (2025년 1월 기준)
브라우저 기반 IPFS 네트워크에 관심이 많습니다.웹브라우저만으로 IPFS 네트워크를 구축할 수 있다면, 서버 없는 서비스(웹3 서비스)가 가능해질 것입니다.IPFS 블로그(https://blog.ipfs.tech/)에서 이와 관련된 기사를 엄선하여 요약합니다.• None SPA 또는 MPA 형태로 개발된 Dapp은 IPFS로 쉽게 배포할 수 있다• None Helia는 브라우저를 IPFS 노드로 만들어주는 라이브러리다• None Helia가 브라우저에서 제공하는 기능은 'CID 데이터 관리'와 'CID 데이터에 대한 Verified Retrieval' 2가지다• None CID 데이터 관리: 데이터를 CID 데이터로 만들고 해석하는 기능을 제공한다• None CID 데이터에 대한 Verified Retrieval: CID로 지정된 데이터를 Bitswap 또는 IPFS Gateway를 통해 가져올 수 있다• None 브라우저 IPFS 노드는 보통 수명주기가 짧기 때문에, CID 데이터를 업로드할 때 pinning 서비스를 이용하거나 직접 운영하는 IPFS 노드(서버)를 이용하는 것이 좋다• None IPFS Gateway는 브라우저에서 IPFS 데이터를 가져올 때 특히 유용한 기술이다• None IPFS 데이터에 대한 검증(Verification: IPFS Gateway가 전송한 데이터가 내가 요구한 그 데이터가 맞는가에 대한 검증)을 브라우저가 수행한다면, 브라우저는 IPFS Gateway를 신뢰하지 않더라도 문제 없이 이용할 수 있다 (Trustless Gateway 사용이 가능하다)• None 이를 위해 Interplanetary Shipyard팀(프로토콜랩으로부터 분사한 개발조직)이 @helia/verified-fetch 라이브러리를 개발/배포한다• None Shipyard팀의 다음 목표는 WebRTC와 WebTransport 프로토콜을 이용해서 브라우저에서 직접 Kubo IPFS 노드와 통신하는 것이다• None 우리(Interplanetary Shipyard)가 관심을 갖는 주제는 웹에서 IPFS를 사용하는 것이다• None 다시 말해 웹브라우저에서 다른 IPFS 노드에 연결할 수 있게 만드는 것이다• None 이를 위해 다음과 같은 프로젝트를 진행하고 있다• None Verified Fetch: 브라우저의 fetch API와 유사한 API를 제공, 이를 통해 IPFS 데이터를 검증/수신하는 기능을 제공한다• None Browser Transport: 브라우저에서 사용할 수 있는 WebRTC와 WebTransport 프로토콜을 기반으로 외부 IPFS 노드와 통신하는 기능을 제공한다• None AutoTLS: 브라우저는 보안 통신을 위해 CA 공인 인증서를 요구하나 IPFS 노드는 통상 인증서 없이 운영된다. AutoTLS는 이 갭을 메꾸는 기능을 한다• None Delegated Routing: 브라우저가 IPFS 기능을 호출할 때 이용할 수 있는 https://delegated-ipfs.dev/routing/v1 엔드포인트를
nodejs
relay
webrtc
1/16/2025
브라우저 기반 IPFS 네트워크 동향 (2025년 1월 기준)
브라우저 기반 IPFS 네트워크에 관심이 많습니다.웹브라우저만으로 IPFS 네트워크를 구축할 수 있다면, 서버 없는 서비스(웹3 서비스)가 가능해질 것입니다.IPFS 블로그(https://blog.ipfs.tech/)에서 이와 관련된 기사를 엄선하여 요약합니다.• None SPA 또는 MPA 형태로 개발된 Dapp은 IPFS로 쉽게 배포할 수 있다• None Helia는 브라우저를 IPFS 노드로 만들어주는 라이브러리다• None Helia가 브라우저에서 제공하는 기능은 'CID 데이터 관리'와 'CID 데이터에 대한 Verified Retrieval' 2가지다• None CID 데이터 관리: 데이터를 CID 데이터로 만들고 해석하는 기능을 제공한다• None CID 데이터에 대한 Verified Retrieval: CID로 지정된 데이터를 Bitswap 또는 IPFS Gateway를 통해 가져올 수 있다• None 브라우저 IPFS 노드는 보통 수명주기가 짧기 때문에, CID 데이터를 업로드할 때 pinning 서비스를 이용하거나 직접 운영하는 IPFS 노드(서버)를 이용하는 것이 좋다• None IPFS Gateway는 브라우저에서 IPFS 데이터를 가져올 때 특히 유용한 기술이다• None IPFS 데이터에 대한 검증(Verification: IPFS Gateway가 전송한 데이터가 내가 요구한 그 데이터가 맞는가에 대한 검증)을 브라우저가 수행한다면, 브라우저는 IPFS Gateway를 신뢰하지 않더라도 문제 없이 이용할 수 있다 (Trustless Gateway 사용이 가능하다)• None 이를 위해 Interplanetary Shipyard팀(프로토콜랩으로부터 분사한 개발조직)이 @helia/verified-fetch 라이브러리를 개발/배포한다• None Shipyard팀의 다음 목표는 WebRTC와 WebTransport 프로토콜을 이용해서 브라우저에서 직접 Kubo IPFS 노드와 통신하는 것이다• None 우리(Interplanetary Shipyard)가 관심을 갖는 주제는 웹에서 IPFS를 사용하는 것이다• None 다시 말해 웹브라우저에서 다른 IPFS 노드에 연결할 수 있게 만드는 것이다• None 이를 위해 다음과 같은 프로젝트를 진행하고 있다• None Verified Fetch: 브라우저의 fetch API와 유사한 API를 제공, 이를 통해 IPFS 데이터를 검증/수신하는 기능을 제공한다• None Browser Transport: 브라우저에서 사용할 수 있는 WebRTC와 WebTransport 프로토콜을 기반으로 외부 IPFS 노드와 통신하는 기능을 제공한다• None AutoTLS: 브라우저는 보안 통신을 위해 CA 공인 인증서를 요구하나 IPFS 노드는 통상 인증서 없이 운영된다. AutoTLS는 이 갭을 메꾸는 기능을 한다• None Delegated Routing: 브라우저가 IPFS 기능을 호출할 때 이용할 수 있는 https://delegated-ipfs.dev/routing/v1 엔드포인트를
2025.01.16
nodejs
relay
webrtc
좋아요
별로에요
AI와 엔터테인먼트가 만났다! 제 3회 카카오엔터 해커톤, "ENTERTHON 2024" 현장 이야기✨
안녕하세요! 카카오엔터테인먼트의 DevRel, Sienna입니다. 2024년 12월, 뜨거운 열정과 즐거움으로 가득했던 ENTERTHON 2024가 성황리에 막을 내렸습니다. 엔터톤에서는 과연 어떤 흥미진진한 일들이 벌어졌을까요? 지금부터 생생한 순간들과 웃음이 넘쳤던 현장 이야기를 공유해 드릴게요. ENTERTHON(엔터톤)이란? 카카오엔터테인먼트의 사내 해커톤(해킹과 마라톤의 합성어로, 다양한 직군들이 함께 모여 제한된 시간 내 결과물을 만들어내는 행사)으로, 카카오엔터 크루들이 치열하게 개발하고 즐겁게 교류하면서 새로운 아이디어를 제안하고 실행할 수 있는 채널입니다. 올해 엔터톤은 'Entertainment with AI'라는 주제로 열렸어요. 지난 9월에 진행된 사내 테크 컨퍼런스 'ENsighT: Working with AI'와 '4주 챌린지: Playing with AI'에 이어, 2024년 카카오엔터 AI 행사의 대미를 장식하는 하이라이트가 되었습니다. 이번 엔터톤에서는 아래 세 가지 분야 중 하나를 선택해, AI와 함께하는 카카오엔터테인먼트의 새로운 가치를 선보이는 무대로 펼쳐졌어요. ENTRTHON 2024 : Entertainment with AI • AI로 더하는 엔터테인먼트 경험 (서비스/기능 개선)• AI로 혁신하는 엔터테인먼트 비즈니스 (신사업 발굴)• AI와 함께 일하는 카카오엔터테인먼트 (업무 효율화) 3회째를 맞은 이번 엔터톤은 더욱 특별해요 ⭐️ 이번 엔터톤의 본선은 카카오 AI 캠퍼스에서 진행되었어요. 크루들은 이 곳에서 무박 2일 간 함께 모여 열정과 즐거움 속에서 작업에 몰입하였다고 하는데요, 24시간 동안 이어진 뜨거운 순간들을 ENTERTHON 2024 스케치 영상에서 만나보세요! 그럼 이제 엔터톤의 빛나는 순간들을 더 자세히 확인해 볼까요? ✨ 카엔터 크루들! 캠퍼스로 모두 모이세요 2024년 12월 5일, 오전 10시. 카카오 AI 캠퍼스는 카카오엔터 크루들을 맞이하기 위해 설렘 가득한 분위기로 문을 열었어요. 바로 잠시 뒤 ENTERTHON 2024의 본선이 이곳에서 펼쳐질 예정이기 때문입니다. 현장은 크루들을 맞이할 완벽한 준비를 마치고 기대감으로 가득 차 있었어요. 현장에 도착한 참가자들을 가장 먼저 반긴 것은 웰컴키트였어요! 엔터톤 굿즈와 파트너사의 후원 상품들로 채워진 토트백을 받아 든 크루들은 설렘 가득한 표정으로 자리에 앉았습니다. 엔터톤 후드집업으로 갈아입은 크루들이 하나둘 늘어나며, 현장은 점점 활기로 채워져 갔어요. ENTERTHON 2024, 시작합니다! 오전 11시가 되자 크루들의 뜨거운 기대 속에서 오프닝이 시작되었어요! 파트너사 소개를 시작으로, CTO 마커스가 엔터톤의 의미와 목표를 이야기하며, "이번 엔터톤이 엔터테인먼트와 AI 기술을 결합해 카카오엔터만의 차별화된 아이디어를 창출해 낼 수 있는 기회가 되길 바란다"며 크루들에게 응원의 메시지를 전했어요. 이어 37건의 아이디어 중 치열한 예선을 통과해 본선에 올라온 19팀의
1/16/2025
AI와 엔터테인먼트가 만났다! 제 3회 카카오엔터 해커톤, "ENTERTHON 2024" 현장 이야기✨
안녕하세요! 카카오엔터테인먼트의 DevRel, Sienna입니다. 2024년 12월, 뜨거운 열정과 즐거움으로 가득했던 ENTERTHON 2024가 성황리에 막을 내렸습니다. 엔터톤에서는 과연 어떤 흥미진진한 일들이 벌어졌을까요? 지금부터 생생한 순간들과 웃음이 넘쳤던 현장 이야기를 공유해 드릴게요. ENTERTHON(엔터톤)이란? 카카오엔터테인먼트의 사내 해커톤(해킹과 마라톤의 합성어로, 다양한 직군들이 함께 모여 제한된 시간 내 결과물을 만들어내는 행사)으로, 카카오엔터 크루들이 치열하게 개발하고 즐겁게 교류하면서 새로운 아이디어를 제안하고 실행할 수 있는 채널입니다. 올해 엔터톤은 'Entertainment with AI'라는 주제로 열렸어요. 지난 9월에 진행된 사내 테크 컨퍼런스 'ENsighT: Working with AI'와 '4주 챌린지: Playing with AI'에 이어, 2024년 카카오엔터 AI 행사의 대미를 장식하는 하이라이트가 되었습니다. 이번 엔터톤에서는 아래 세 가지 분야 중 하나를 선택해, AI와 함께하는 카카오엔터테인먼트의 새로운 가치를 선보이는 무대로 펼쳐졌어요. ENTRTHON 2024 : Entertainment with AI • AI로 더하는 엔터테인먼트 경험 (서비스/기능 개선)• AI로 혁신하는 엔터테인먼트 비즈니스 (신사업 발굴)• AI와 함께 일하는 카카오엔터테인먼트 (업무 효율화) 3회째를 맞은 이번 엔터톤은 더욱 특별해요 ⭐️ 이번 엔터톤의 본선은 카카오 AI 캠퍼스에서 진행되었어요. 크루들은 이 곳에서 무박 2일 간 함께 모여 열정과 즐거움 속에서 작업에 몰입하였다고 하는데요, 24시간 동안 이어진 뜨거운 순간들을 ENTERTHON 2024 스케치 영상에서 만나보세요! 그럼 이제 엔터톤의 빛나는 순간들을 더 자세히 확인해 볼까요? ✨ 카엔터 크루들! 캠퍼스로 모두 모이세요 2024년 12월 5일, 오전 10시. 카카오 AI 캠퍼스는 카카오엔터 크루들을 맞이하기 위해 설렘 가득한 분위기로 문을 열었어요. 바로 잠시 뒤 ENTERTHON 2024의 본선이 이곳에서 펼쳐질 예정이기 때문입니다. 현장은 크루들을 맞이할 완벽한 준비를 마치고 기대감으로 가득 차 있었어요. 현장에 도착한 참가자들을 가장 먼저 반긴 것은 웰컴키트였어요! 엔터톤 굿즈와 파트너사의 후원 상품들로 채워진 토트백을 받아 든 크루들은 설렘 가득한 표정으로 자리에 앉았습니다. 엔터톤 후드집업으로 갈아입은 크루들이 하나둘 늘어나며, 현장은 점점 활기로 채워져 갔어요. ENTERTHON 2024, 시작합니다! 오전 11시가 되자 크루들의 뜨거운 기대 속에서 오프닝이 시작되었어요! 파트너사 소개를 시작으로, CTO 마커스가 엔터톤의 의미와 목표를 이야기하며, "이번 엔터톤이 엔터테인먼트와 AI 기술을 결합해 카카오엔터만의 차별화된 아이디어를 창출해 낼 수 있는 기회가 되길 바란다"며 크루들에게 응원의 메시지를 전했어요. 이어 37건의 아이디어 중 치열한 예선을 통과해 본선에 올라온 19팀의
2025.01.16
좋아요
별로에요
분산 시스템에서 로컬 캐시 활용하기
jerry.this 규모가 있는 서비스에서 캐싱 전략에 대한 고민은 꼭 필요한 것 같아요! 그 부분에 대해 너무 이해하기 쉽게 설명해 주셔서 캐싱을 적용해보고자 하는 분들은 꼭 읽어보셨으면 좋겠어요. 🙂geuru.geon 더 빠른 데이터 조회를 위해 캐시 시스템을 구현한 경험을 잘 풀어낸 글입니다. 평소 Spring 애플리케이션의 캐시 도입에 관심 있으셨다면 입문서로 읽어보는 것은 어떨까요?안녕하세요, 플랫폼서비스파티에서 통신중개 플랫폼 서버 개발을 맡고 있는 로이입니다. 통신중개 플랫폼은 사용자와 통신사 사이를 중개하는 서비스입니다. 여러 통신사의 요금제 상품을 나열해 보여주며, 사용자는 자신의 요구에 맞는 요금제를 선택하고 가입할 수 있습니다. 사용자는 요금제 구분, 데이터양, 통화량, 가격, 혜택 등 다양한 선택지를 비교하며 자신에게 맞는 요금제를 선택합니다. 이러한 특성으로 인해 상품, 통신사, 혜택 등에 대해 빈번한 조회 요청이 발생합니다.하지만, 이러한 단순 조회 작업에서 매번 데이터베이스를 호출하는 것은 비효율적일 수 있습니다. 이때 저희가 흔히 사용하는 캐시(Cache)를 조금 더 유용하게 사용하는 방법에 대해 다뤄보려고 합니다. 도입 배경부터 유연한 캐싱 시스템 및 데이터 최신화를 위한 메시지 시스템 구축 방법까지, 실제 구현 코드를 활용해 구체적으로 설명드리겠습니다.본격적으로 캐시 구현 방법을 살펴보기에 앞서 캐시란 무엇인지 정의를 우선 살펴보겠습니다. 캐시는 데이터를 더 빠르게 접근할 수 있는 고속 저장소입니다. 자주 사용하는 데이터나 반복적으로 조회되는 데이터를 캐시에 저장하면, 데이터베이스를 호출하지 않고도 데이터를 빠르게 반환할 수 있습니다. 이를 통해 조회 속도가 빨라지고 데이터베이스 부하가 크게 줄어들어 전체적인 서비스 성능이 향상됩니다.흔히 캐시를 이야기할 때, 우리는 Redis를 자주 언급하곤 합니다. 그렇다면, 왜 웹 애플리케이션 서버에 저장하는 방식의 로컬 캐시가 아닌 글로벌 캐시인 Redis를 먼저 떠올릴까요?근래의 서비스는 고가용성을 위해 Scale-Out 하여 동일한 서버를 2대 이상 운영하는 경우가 많습니다. 이때, 로컬 캐시만을 사용한다면 다음 그림에서 볼 수 있듯이 각 서버 간 데이터 정합성 문제로 인해 서비스 운영에 문제를 일으킬 수 있습니다.글로벌 캐시인 Redis를 사용할 경우, 서버 간 데이터 공유가 가능하므로 두 Client 모두 같은 데이터를 바라봅니다. 하지만 로컬 캐시를 사용할 경우, 서버 간 데이터 공유가 불가능하기 때문에 캐싱된 데이터에 따라 서버 간 데이터 불일치 문제가 발생할 수 있습니다.그럼에도 불구하고, 로컬 캐시는 다음과 같은 장점이 있어 무시할 수 없습니다.• 웹 서버가 조회를 위해 네트워크를 트래픽을 사용하지 않기 때문에 빠른 응답 속도• 외부 서비스의 지연 의존도 감소저희 서비스는 앞서 말씀드린 것처럼 중개 서비스이기 때문에 한번 등록된 통신사 정보나 상품과 같은 자주 변화하지 않는 데이터에 대한 잦은 조회가 발생합니다. 또한, 데이터가 변경되더라도 각 서버
redis
1/15/2025
분산 시스템에서 로컬 캐시 활용하기
jerry.this 규모가 있는 서비스에서 캐싱 전략에 대한 고민은 꼭 필요한 것 같아요! 그 부분에 대해 너무 이해하기 쉽게 설명해 주셔서 캐싱을 적용해보고자 하는 분들은 꼭 읽어보셨으면 좋겠어요. 🙂geuru.geon 더 빠른 데이터 조회를 위해 캐시 시스템을 구현한 경험을 잘 풀어낸 글입니다. 평소 Spring 애플리케이션의 캐시 도입에 관심 있으셨다면 입문서로 읽어보는 것은 어떨까요?안녕하세요, 플랫폼서비스파티에서 통신중개 플랫폼 서버 개발을 맡고 있는 로이입니다. 통신중개 플랫폼은 사용자와 통신사 사이를 중개하는 서비스입니다. 여러 통신사의 요금제 상품을 나열해 보여주며, 사용자는 자신의 요구에 맞는 요금제를 선택하고 가입할 수 있습니다. 사용자는 요금제 구분, 데이터양, 통화량, 가격, 혜택 등 다양한 선택지를 비교하며 자신에게 맞는 요금제를 선택합니다. 이러한 특성으로 인해 상품, 통신사, 혜택 등에 대해 빈번한 조회 요청이 발생합니다.하지만, 이러한 단순 조회 작업에서 매번 데이터베이스를 호출하는 것은 비효율적일 수 있습니다. 이때 저희가 흔히 사용하는 캐시(Cache)를 조금 더 유용하게 사용하는 방법에 대해 다뤄보려고 합니다. 도입 배경부터 유연한 캐싱 시스템 및 데이터 최신화를 위한 메시지 시스템 구축 방법까지, 실제 구현 코드를 활용해 구체적으로 설명드리겠습니다.본격적으로 캐시 구현 방법을 살펴보기에 앞서 캐시란 무엇인지 정의를 우선 살펴보겠습니다. 캐시는 데이터를 더 빠르게 접근할 수 있는 고속 저장소입니다. 자주 사용하는 데이터나 반복적으로 조회되는 데이터를 캐시에 저장하면, 데이터베이스를 호출하지 않고도 데이터를 빠르게 반환할 수 있습니다. 이를 통해 조회 속도가 빨라지고 데이터베이스 부하가 크게 줄어들어 전체적인 서비스 성능이 향상됩니다.흔히 캐시를 이야기할 때, 우리는 Redis를 자주 언급하곤 합니다. 그렇다면, 왜 웹 애플리케이션 서버에 저장하는 방식의 로컬 캐시가 아닌 글로벌 캐시인 Redis를 먼저 떠올릴까요?근래의 서비스는 고가용성을 위해 Scale-Out 하여 동일한 서버를 2대 이상 운영하는 경우가 많습니다. 이때, 로컬 캐시만을 사용한다면 다음 그림에서 볼 수 있듯이 각 서버 간 데이터 정합성 문제로 인해 서비스 운영에 문제를 일으킬 수 있습니다.글로벌 캐시인 Redis를 사용할 경우, 서버 간 데이터 공유가 가능하므로 두 Client 모두 같은 데이터를 바라봅니다. 하지만 로컬 캐시를 사용할 경우, 서버 간 데이터 공유가 불가능하기 때문에 캐싱된 데이터에 따라 서버 간 데이터 불일치 문제가 발생할 수 있습니다.그럼에도 불구하고, 로컬 캐시는 다음과 같은 장점이 있어 무시할 수 없습니다.• 웹 서버가 조회를 위해 네트워크를 트래픽을 사용하지 않기 때문에 빠른 응답 속도• 외부 서비스의 지연 의존도 감소저희 서비스는 앞서 말씀드린 것처럼 중개 서비스이기 때문에 한번 등록된 통신사 정보나 상품과 같은 자주 변화하지 않는 데이터에 대한 잦은 조회가 발생합니다. 또한, 데이터가 변경되더라도 각 서버
2025.01.15
redis
좋아요
별로에요
FastAPI 프로젝트의 결합도 낮추기 전략
소프트웨어 개발에서 결합도(Coupling)를 낮추고 응집도(Cohesion)를 높이는 것은 유지보수성과 확장성을 향상시키는 핵심 전략입니다.특히 웹 애플리케이션 개발에서 모듈간의 결합도를 낮추면 코드의 재사용성과 테스트 용이성이 크게 향상됩니다.이번 글에서는 FastAPI 프로젝트에서 파일들을 service 구현 그룹과 router 구현 그룹으로 그룹핑하여 결합도를 낮추는 방법을 살펴보겠습니다.결합도를 낮추는 아키텍처의 필요성높은 결합도가 초래하는 위험아키텍처 설계를 소홀히 하거나 결합도를 낮추는 전략을 고려하지 않으면 다음과 같은 문제들이 발생할 수 있습니다:• None 유지보수성 저하: 한 모듈의 변경이 다른 모듈에 연쇄적으로 영향을 미쳐 수정 범위가 넓어집니다.• None 예시: 데이터베이스 스키마 변경 시, 비즈니스 로직과 API 레이어 모두를 수정해야 하는 상황이 발생합니다.• None 확장성 제한: 새로운 기능을 추가하거나 변경하기 어려워집니다.• None 예시: 새로운 API 엔드포인트를 추가하려면 기존 모듈들을 대폭 수정해야 합니다.• None 재사용성 감소: 특정 기능을 다른 프로젝트나 모듈에서 재사용하기 어렵습니다.• None 예시: 다른 프로젝트에서 비슷한 기능이 필요해도 기존 코드를 활용할 수 없습니다.• None 협업 장애: 팀원 간 작업이 겹치거나 충돌하여 생산성이 떨어집니다.• None 예시: 여러 개발자가 동일한 파일을 수정하면서 충돌이 빈번하게 발생합니다.• None 테스트 어려움: 모듈간 의존성이 높아 개별적인 단위 테스트가 어렵습니다.• None 예시: 서비스 레이어를 테스트하려면 데이터베이스와 API 레이어까지 모두 설정해야 합니다.이러한 문제를 해결하기 위해 결합도를 낮추는 아키텍처가 필요합니다.FastAPI는 Python의 최신 기능과 표준을 활용하여 빠르고 효율적인 API를 구축할 수 있게 해주는 프레임워크입니다. 주요 특징은 다음과 같습니다:• None 고성능: 비동기 지원으로 높은 성능을 제공합니다.• None 타입 힌트 기반 개발: Python의 타입 힌트를 활용하여 코드의 가독성과 안정성을 높입니다.• None 자동 문서화: Swagger UI 및 ReDoc을 통한 자동 API 문서 생성을 지원합니다.• None 개발 생산성 향상: 최소한의 코드로 강력한 기능을 구현할 수 있습니다.하지만 이러한 장점을 최대한 활용하려면, 모듈 간 결합도를 낮추고 응집도를 높이는 아키텍처 설계가 필요합니다.역할: 비즈니스 로직과 데이터 처리를 담당하는 핵심 그룹입니다. 데이터베이스와의 상호 작용 및 데이터 가공 로직을 포함합니다.역할: 클라이언트와의 통신을 담당하는 그룹입니다. 클라이언트의 요청을 받아 서비스 그룹의 기능을 호출하여 데이터를 처리하고, 결과를 클라이언트에 응답합니다.결합도를 낮추는 아키텍처의 이점개발자 민수는 비즈니스 로직에 새로운 할인 정책을 적용해야 했습니다.서비스 레이어에서 로직을 수정했지만, router 레이어와 독립적이기 때문에 다른 팀원들이 작업 중인 API 엔드포인트 코드에는
fastapi
1/14/2025
FastAPI 프로젝트의 결합도 낮추기 전략
소프트웨어 개발에서 결합도(Coupling)를 낮추고 응집도(Cohesion)를 높이는 것은 유지보수성과 확장성을 향상시키는 핵심 전략입니다.특히 웹 애플리케이션 개발에서 모듈간의 결합도를 낮추면 코드의 재사용성과 테스트 용이성이 크게 향상됩니다.이번 글에서는 FastAPI 프로젝트에서 파일들을 service 구현 그룹과 router 구현 그룹으로 그룹핑하여 결합도를 낮추는 방법을 살펴보겠습니다.결합도를 낮추는 아키텍처의 필요성높은 결합도가 초래하는 위험아키텍처 설계를 소홀히 하거나 결합도를 낮추는 전략을 고려하지 않으면 다음과 같은 문제들이 발생할 수 있습니다:• None 유지보수성 저하: 한 모듈의 변경이 다른 모듈에 연쇄적으로 영향을 미쳐 수정 범위가 넓어집니다.• None 예시: 데이터베이스 스키마 변경 시, 비즈니스 로직과 API 레이어 모두를 수정해야 하는 상황이 발생합니다.• None 확장성 제한: 새로운 기능을 추가하거나 변경하기 어려워집니다.• None 예시: 새로운 API 엔드포인트를 추가하려면 기존 모듈들을 대폭 수정해야 합니다.• None 재사용성 감소: 특정 기능을 다른 프로젝트나 모듈에서 재사용하기 어렵습니다.• None 예시: 다른 프로젝트에서 비슷한 기능이 필요해도 기존 코드를 활용할 수 없습니다.• None 협업 장애: 팀원 간 작업이 겹치거나 충돌하여 생산성이 떨어집니다.• None 예시: 여러 개발자가 동일한 파일을 수정하면서 충돌이 빈번하게 발생합니다.• None 테스트 어려움: 모듈간 의존성이 높아 개별적인 단위 테스트가 어렵습니다.• None 예시: 서비스 레이어를 테스트하려면 데이터베이스와 API 레이어까지 모두 설정해야 합니다.이러한 문제를 해결하기 위해 결합도를 낮추는 아키텍처가 필요합니다.FastAPI는 Python의 최신 기능과 표준을 활용하여 빠르고 효율적인 API를 구축할 수 있게 해주는 프레임워크입니다. 주요 특징은 다음과 같습니다:• None 고성능: 비동기 지원으로 높은 성능을 제공합니다.• None 타입 힌트 기반 개발: Python의 타입 힌트를 활용하여 코드의 가독성과 안정성을 높입니다.• None 자동 문서화: Swagger UI 및 ReDoc을 통한 자동 API 문서 생성을 지원합니다.• None 개발 생산성 향상: 최소한의 코드로 강력한 기능을 구현할 수 있습니다.하지만 이러한 장점을 최대한 활용하려면, 모듈 간 결합도를 낮추고 응집도를 높이는 아키텍처 설계가 필요합니다.역할: 비즈니스 로직과 데이터 처리를 담당하는 핵심 그룹입니다. 데이터베이스와의 상호 작용 및 데이터 가공 로직을 포함합니다.역할: 클라이언트와의 통신을 담당하는 그룹입니다. 클라이언트의 요청을 받아 서비스 그룹의 기능을 호출하여 데이터를 처리하고, 결과를 클라이언트에 응답합니다.결합도를 낮추는 아키텍처의 이점개발자 민수는 비즈니스 로직에 새로운 할인 정책을 적용해야 했습니다.서비스 레이어에서 로직을 수정했지만, router 레이어와 독립적이기 때문에 다른 팀원들이 작업 중인 API 엔드포인트 코드에는
2025.01.14
fastapi
좋아요
별로에요