[쿠버네티스 스터디.1-2] 확장성, 고가용성, 안정성
·
스터디/Cloud & k8s
1.모던 애플리케이션 특징고가용성 high availability을 통해 서비스가 장애 발생시에도 중단되지 않도록 설계됨확장성을 갖추어 수직적/수평적 확장 가능복원력을 통해 빠르게 복구 가능자동화된 ci/cd pipeline과 container 기술을 통해 빠른 배포 주기와 일관된 품질 보장데이터 복제, 샤딩, Failover 와 같은 분산 시스템 적극 활용됨2.고가용성 (High Availability, HA)Why?서비스 다운은 매출손실, 사용자 이탈, 신뢰도 하락으로 이어짐. 무중단 서비스가 이루어져야 됨.3.고가용성의 핵심 개념1) Single Point of Failure (SPOF)하나의 장애로 인해 전체 시스템이 멈추는 지점e.g. 서버 1대로 운영하면 서버가 다운될 경우 서비스도 중단됨 2..
코틀린의 Error Handling - runCatching
·
스터디/Kotlin
코틀린의 runCatching자바의 try~catch 와 동일하게 지원하지만 조금 다른 방법으로 핸들링 할 수도 있습니다! 예를들어 아래와 같은 요구사항이 있다고 가정해봅니다.LoginApiClient 호출 시 LoginException 발생errorCode = INVALID_PASSWORD인 경우 예외를 발생하지 않고 null을 리턴한다.그 외 에러는 모두 예외를 발생시킨다. try ~ catch 를 사용한 코드try { loginApiClient.login(request)} catch (e: LoginException) { if (e.errorCode == "INVALID_PASSWORD") { return null } else { throw e }}  Java 에서는 익숙하게 위처..
[쿠버네티스 스터디.1-1] 모던 애플리케이션의 특징
·
스터디/Cloud & k8s
전통적인 애플리케이션 vs 모던 애플리케이션전통적인 애플리케이션이란?모놀리식 구조로 수동 배포하는 구조의 애플리케이션모던 애플리케이션이란?빠르게 변화하는 기술 환경과 비즈니스 요구에 맞춰 설계된 애플리케이션- 특징: 클라우드 네이티브 (cloud-native) 전통적 애플리케이션모던 애플리케이션모놀리식 구조마이크로서비스 아키텍처 MSA수동 배포CI/CD 자동화 배포물리 서버 기반클라우드 및 컨테이너 기반낮은 확장성높은 확장성(scale- in, out)다운타임 발생 가능고가용성 및 무중단 배포  클라우드 네이티브애플리케이션을 클라우드 환경에서 효과적으로 개발, 배포, 운영할 수 있도록 설계하는 방법클라우드 환경에서 애플리케이션이 더 잘 동작하도록 만들어진 것 특징유연한 확장성빠른 배포 및 업데이트자동화:..
[LeetCode] 3191. Minimum Operations to Make Binary Array Elements Equal to One I (Python)
·
코딩 테스트
Problem Solutionsliding window 연속된 3개 숫자를 뒤집어서 모두 1로 바꿀 수 있는 최소한의 횟수를 구하는 문제.당연히 2중포문을 쓰면 시간초과가 발생한다.n-2까지만 검사해서 nums[i] == 0 이면 i ~ i+2까지 비트연산으로 1, 0을 뒤집는다.연산이 끝나면 answer+=1비트연산 파이선으로 ^= 이더라? 괜히 if~else 구문으로 바꾸고있었네 마지막에 2개숫자가 0이면 연속된 3자리가 아니라 못바꾸므로 바로 리턴 -1아니면 answer return Codeclass Solution: def minOperations(self, nums: List[int]) -> int: n = len(nums) ans = 0 for i i..
[LeetCode] 3208. Alternating Groups II (Python)
·
코딩 테스트
Problem Solutionsliding window 처음에 구현으로 2중 포문 돌렸다가 time limit exceeded 났던 문제.이 문제도 똑같이 sliding window 기법으로 풀어야된다.원형 배열이라서 colors[: k-1]개만큼 기존 배열에 더해준다.그리고 이전 원소와 값을 비교하며 (index 범위는 1 부터 시작) count 를 증가한다.count가 k 이상이면 조건을 만족하므로 answer ++만족하지않으면 count = 1 로 초기화하여 다시 리셋해준다. Codeclass Solution: def numberOfAlternatingGroups(self, colors: List[int], k: int) -> int: n = len(colors) ..
[LeetCode] 2379. Minimum Recolors to Get K Consecutive Black Blocks (Python)
·
코딩 테스트
ProblemSolutionstringsliding window blocks string에서 연속된 B의 개수가 k개가 될 수 있도록 가장 최소한의 변경해야되는 W 수를 구하는 문제.substring에서 힌트를 얻어서 k길이만큼 substring을 구하고 W의 개수를 구한뒤 가장 최소값을 리턴하였다. 나는 구현으로 일일이 string을 검사하는 방식으로 풀이했는데 슬라이딩 윈도우 기법을 사용하면 더 최적화된 알고리즘 O(N)으로 해결할 수 있다. Codeclass Solution: def minimumRecolors(self, blocks: str, k: int) -> int: n = len(blocks) answer = 999 if 'W' in blocks a..