📖 개발 공부
-
[Flutter] .env 파일 이용하여 환경변수 관리하기📖 개발 공부/flutter 2023. 10. 2. 09:00
Flutter에서 .env 파일을 이용하여 환경변수를 쉽게 관리할 수 있다. 방법은 flutter_dotenv 패키지를 사용하는 것이다! flutter_dotenv | Flutter Package Easily configure any flutter application with global variables using a `.env` file. pub.dev (나는 flutter pub get 명령어를 이용해서 설치했다.) 1. assets 폴더 하위에 .env 파일을 생성한다. 애플리케이션에 사용할 값들을 .env 파일에 다음과 같은 형태로 저장한다. AUTH_TOKEN_KEY=auth_token_value 2. 그리고 pubspec.yaml에 다음과 같이 .env 파일 경로를 추가한다. assets:..
-
[MongoDB] Replica Set (레플리카셋)📖 개발 공부 2023. 9. 5. 23:36
Replica Set 구성 Replica Set의 사용 목적이 HA이기 때문에, 각 멤버들이 각 다른 서버에 위치해있어야 목적에 맞게 효과를 볼 수 있다. Status Description Primary • Read/Write 요청 모두 처리할 수 있다. • Write를 처리하는 유일한 멤버이다. • Replica Set에 하나만 존재할 수 있다. Secondary • Read에 대한 요청만 처리할 수 있다. • 복제를 통해 Primary와 동일한 데이터 셋을 유지한다. • Replica Set에 여러개가 존재할 수 있다. 아무런 설정없이 읽기/쓰기 요청을 하면 기본적으로 Primary가 처리한다. readPreference 옵션을 넣어 요청해야한다. Replica Set Election (Fail-Ov..
-
[MongoDB] MongoDB 배포형태 (Standalone/Replica Set/Shared Cluster)📖 개발 공부 2023. 9. 5. 00:17
Standalone study용 test용 의 배포 형태이다. 운영 환경에서 Standalone 배포 형태는 위험하다. 데이터베이스 점검을 하는 경우, 서비스 또한 중단이 되어야 하기 때문이다. Replica Set 동일한 데이터를 갖고있는 몽고 DB 서버를 여러 대 가지고 있는 형태이다. 한쪽으로 write를 하면 다른 서버에 데이터를 복제시킨다. 위의 그림을 예시로 들면, 3대 중에 1대가 죽더라도 나머지 2대가 살아있어서 점검이 있더라도 지속적으로 점검이 가능하다. 실제 현업에서 가장 많이 사용되는 배포 형태이다. → HA (High Availabilty) 고가용성 보장 하지만 갑자기 서비스의 인기가 급격히 늘어나서 데이터 쓰기양이 많아진다고 해보자. scale-up을 통해 서버의 스토리지를 계속해..
-
MSA와 Event-Driven 아키텍처📖 개발 공부 2023. 9. 3. 16:03
MSA(Microservice Architecture)는 무엇인가 시스템을 독립적인 단위의 작은 서비스들로 분리한다. (크기보다는 독립성이 중요) ⇒ 독립적인 단위: 다른 서비스와 다른 이유로 변경되고, 다른 속도로 변경되는 단위 격리된 환경에서 각자의 역할을 수행한다. 각 서비스들은 API(인터페이스)를 통해서만 통신한다.(다른 서비스의 DB 접근 불가) 기존의 Monolithic 아키텍처 모든 기능들이 한 서버 안에 들어가 있고, 공유 데이터베이스를 사용한다. MSA 아키텍처 기능 별로(도메인 별로) 서버가 나뉘어있고, 각자의 데이터베이스를 사용하며 API를 이용하여 통신한다. MSA로 얻으려는 것 모듈성(높은 응집도, 낮은 결합도) 서비스 별로 독립적인 개발과 배포가 가능하다. 서비스(코드) 크기가..
-
[개발일지] MongoSocketException 이슈 해결기📖 개발 공부 2023. 8. 30. 22:38
갑자기 내가 작업했던 rpc에서 이유없는 INTERNAL 에러가 내려왔다. 데이터독을 보니 MongoSocketWriteException MongoSocketReadException: Prematurely reached end of stream (after a period of inactivity) 요 에러들이 지속적으로 발생하고 있었다. Elasticsearch가 복병일 줄 알았더니,, 그 전에 데이터를 조회하기 위해 Mongo에 접근할 때 에러가 났다. 아무런 변화가 없었는데 갑자기 왜 이런 에러가 났을까? 원인 파악 추측1: 커넥션풀 이슈? 추측2: 유휴 커넥션 이슈? 해결 원인 파악 정말 변화가 없었을까.. 파악해보았다. 생각해본 변화는 기능 개선 코드 리팩토링 이뿐이었다.. 그런데 확인해보니 이..
-
[Cloud Design Patterns] Asynchronous Request-Reply pattern 비동기 요청/응답 패턴 (feat. HTTP 폴링, 웹소켓)📖 개발 공부 2023. 8. 29. 01:54
최신 애플리케이션 개발에서 클라이언트 애플리케이션이 비즈니스 로직을 제공하기 위해 원격 API에 의존한다. 대부분의 경우 클라이언트 애플리케이션에 대한 API는 100ms 이하로 신속하게 응답하도록 설계되었다. 다음과 같은 요인들이 응답 대기 시간에 영향 줄 수 있다. 애플리케이션 호스팅 스택 보안 구성 요소 클라이언트와 백엔드 시스템의 위치 네트워크 인프라 현재 부하 요청 페이로드 크기 큐 처리 길이 백엔드에서 요청을 처리하는 시간 이미지를 검수하는 웹 애플리케이션의 시나리오를 상상해보자. 이미지 검수하는 과정은 과정은 몇 초에서 몇 분이 걸릴 수 있다. API는 보통 100ms 이하로 응답이 설계되었다고 했는데, 위의 그림에서는 최대 몇분까지 걸릴 수 있는 구조이다. 서버에서는 다음과 같이 이미지 검..
-
What's Wrong with Layers? (계층형 아키텍처의 문제점)📖 개발 공부 2023. 8. 23. 00:30
계층형 아키텍처 계층형 아키텍처는 견고한 아키텍처 패턴이다. 계층을 잘 이해한다면 web과 persistance 계층에 독립적으로 도메인 로직을 작성할 수 있다. 도메인 로직에 영향을 주지 않고 웹 계층이나 영속성 계층의 기술을 변경할 수 있다. 계층형 아키텍처의 문제점 하지만 현재에 이르러서는 계층형 아키텍처 때문에 문제가 생기는 곳이 많아졌다. 계층화된 아키텍처에는 나쁜 습관이 들어 시간이 지남에 따라 소프트웨어를 변경하기가 점점 더 어려워지는 열린 측면들이 있다. 어떤 이유들이 있는지 알아보자. 1. It promotes Database-Driven Design 기존 계층 구조의 기초는 데이터베이스이다. 웹 계층은 도메인 계층에 따라 달라지며, 도메인 계층은 지속성 계층과 데이터베이스에 종속된다. ..
-
[Go] Go로 초간단 웹서버 만들어보기📖 개발 공부/go 2023. 8. 19. 14:31
나는 Go 언어를 처음 접한다. 요번에 사이드 프로젝트할 때 새로운 언어를 도전해보고 싶어서 핫한 Go 언어로 해보려고 한다. Go 언어의 특성, 문법, 라이브러리를 차근차근 살펴보면서 사이드 프로젝트를 만들어볼 계획이다! 많관부~ Go의 첫번째 글로, 단 몇 줄로 Go 간단 웹서버를 만들어보는 실습을 해보자! 컴파일러는 패키지 이름이 main 인 것부터 찾아낸다. main 패키지 안에서 main() 함수가 go 프로그램의 시작이 된다. 간단 웹서버를 본격적으로 만들어보기 전에, “hello world!”를 출력하는 간단한 프로그램을 짜보자. // hello.go package main import ( "fmt" ) func main() { fmt.Println("hello world!") } 여기서 잠..