전체 글
-
[SQL] 노선별 평균 역 사이 거리 조회하기Programmers 2024. 3. 10. 17:09
총 누계거리는 테이블 내 존재하는 역들의 역 사이 거리의 총 합을 뜻합니다. 총 누계 거리와 평균 역 사이 거리의 컬럼명은 각각 TOTAL_DISTANCE, AVERAGE_DISTANCE로 해주시고, 총 누계거리는 소수 둘째자리에서, 평균 역 사이 거리는 소수 셋째 자리에서 반올림 한 뒤 단위(km)를 함께 출력해주세요. 결과는 총 누계 거리를 기준으로 내림차순 정렬해주세요. SELECT A.ROUTE , CONCAT(ROUND(SUM(A.D_BETWEEN_DIST), 2), 'km')AS TOTAL_DISTANCE , CONCAT(ROUND(AVG(A.D_BETWEEN_DIST), 3), 'km') AS AVERAGE_DISTANCE FROM SUBWAY_DISTANCE A GROUP BY ROUTE ..
-
Git action - 이론Data Engineer 2024. 3. 8. 08:49
소프트웨어 workflow를 자동화할 수 있도록 도와주는 도구 Test Code 쿼리를 날리고 데이터가 맞는지 정합성 체크 배포 기타 자동화하고 싶은 스크립트 다양한 파이썬 버전에서 실행되는지 확인 Workflow는 하나의 Repo에 최대 20개까지 등록 가능 Workflow 안에 존재하는 Job은 6시간 동안 실행될 수 있고, 초과시 자동으로 중지됨 Github Free는 Storage 한도 500MB, 월에 실행 시간 3000분 Worflow, Event, Job, Step, Action, Runner 등 존재 Workflow Event Job Step Action Runner Git Action 생성하는 흐름 코드 작성 코드 작성 후 Workflow 정의 정상 작동하는지 Test Workflow 정..
-
App UpdateData Engineer 2024. 3. 8. 08:47
강제 업데이트 앱이 새로운 버전으로 올라가면서 기존 앱과 호환이 불가하거나, 치명적인 버그가 있어 기존 앱의 이용자를 모두 필수적으로 새로운 버전의 앱을 사용하도록 할 때 사용 앱 실행 시 강제 업데이트가 필요한지의 여부를 판단 후, 강제 업데이트가 필요하다면 앱 진입을 막고 앱스토어로 연결하여 업데이트 할 수 있도록 안내 강제 업데이트의 경우 기존 앱은 사용할 수 없게 되어, 기존 사용자들의 사용성은 떨어지게 되므로 꼭 사용해야 하는 경우가 아니라면 선택 업데이트 사용을 권장해야 한다 선택 업데이트 앱이 새로운 버전으로 올라가지만 큰 변화가 없어서, 기존 앱과 호환이 가능하여 새로운 업데이트가 있다고만 안내 업데이트 안내 로직 사용자가 앱을 실행 or 백그라운드에서 포어그라운드로 진입 서버에서 앱 최소..
-
프로메테우스Data Engineer 2024. 3. 3. 21:43
Prometheus K8s 환경에 들어오며, 전체 인프라 환경과 Application에 대한 모니터링을 하는 것이 매우 중요해졌다 인프라에 대한 전체적인 가시성을 확보해야 k8s 내에 돌아가는 Application에 대한 가용성과 안정성을 확보 모니터링 결과를 통해 고도화된 Cloud Native 시스템을 구축할 때 사용하는 지표로 활용 기존 레거시 환경은 고사양 서버에 application을 크게 운영하는 방식으로 운영 고사양 서버에 Monitoring Agent를 서버에 설치한 후, Agent가 OS의 메트릭을 수집하여 Backend에 직접 전송하는 방식을 사용 Cloud native : 컨테이너 기반의 Application을 작게 운영하고 필요할 때마다 확장, 파괴하는 방식 선택 동적으로 확장하는 ..
-
Dockerfile & Docker-composeData Engineer 2024. 2. 20. 14:12
Dockerfile Docker에서 이미지를 생성하기 위한 용도로 작성하는 파일 만들 이미지에 대한 정보를 기술해 둔 템플릿 Docker build [option] [작성한 dockerfile 경로] 위와 같이 명령어를 입력하면 작성한 도커파일의 내용을 기반으로 이미지 빌드 시작 FROM : 베이스 이미지를 지정하는 것 어느 정도 기본적인 구성 요소들이 갖추어진 상태의 이미지를 토대로 만드는 것 From 이미지, 태그 지정 시 registry에서 해당 이미지 pull RUN Command를 실행하여 새 이미지에 포함시키는 역할 컨테이너에 꼭 필요한 소프트웨어, 라이브러리를 포함시켜야 할 때 RUN 뒤에 소프트웨어/라이브러리 설치 명령어 , 파일/디렉토리 생성 명령어 작성 CMD 컨테이너가 시작될 때 실행..
-
[Security] Microsoft DefenderData Engineer 2024. 2. 19. 17:30
우리가 Azure에서 만든 서비스를 안전하게 보관하고자, Microsoft Defender를 도입하기로 하였다. 그와 관련해 공식문서를 찾아본 결과를 공유해보려 한다. Microsoft Defender 다양한 사이버 위협 및 취약성으로부터 클라우드 기반 애플리케이션을 보호하도록 설계된 보안 조치 및 사례로 구성된 CNAPP *CNAPP : Cloud Native Application Protection Platform 다중 클라우드 및 다중 파이프라인 환경에서 코드 수준에서 보안 관리를 통합하는 DevSecOps(개발 보안 작업) 솔루션 위반을 방지하기 위해 수행할 수 있는 작업을 표시하는 CSPM(클라우드 보안 태세 관리) 솔루션 서버, 컨테이너, 스토리지, 데이터베이스 및 기타 워크로드에 대한 특정 ..
-
Git Branch 전략Computer Science 2024. 2. 18. 23:31
Git flow Main Branch Feature Branch Release Branch Hotfix Branch 가장 중심이 되는 브랜치는 master와 develop 브랜치이며, Merge된 feature, release, hotfix 브랜치는 삭제하도록 한다. Main branch Master - 배포 가능한 상태만을 관리하는 브랜치 Develop - 다음에 배포할 것을 개발하는 브랜치 - 통합 브랜치의 역할을 하며, 평소에는 이 브랜치를 기반으로 개발을 진행 Supporting branch Feature - 기능을 개발하는 브랜치로, develop 브랜치로부터 분기 - 그 기능을 다 완성할 때까지 유지하고, 다 완성하면 develop 브랜치로 merge(다음 배포에 확실히 넣을 거라고 merge..
-
[Leet Code] Best time to Buy and Sell Stock IIProgrammers 2024. 2. 9. 15:40
class Solution(object): def maxProfit(self, prices): total = 0 buy = prices[0] # 산 주식을 리스트의 첫번째 원소로 지정 for i in range(1, len(prices)): if prices[i] - buy > 0: # 현재 인덱스에서 주식을 팔았을 때 이득이면 팔고, 총 수익에 더해준다 total += prices[i] - buy buy = prices[i] else: buy = min(buy, prices[i]) return total 최저 값을 buy로 선언 후, 리스트 내 원소들과 비교하며 양수면 더해주고, 아니면 최저값만 갱신해주는 연산을 처리한다 [1,2,3,4,5]를 예시로 든다면, # buy = 1 1 - 1 = 0 이므로..