Nginx LB 서버 - nginx.conf
·
DevOps
프로젝트를 진행하면서 서버 이중화를 위해 LB서버로 Nginx를 이용하여 구성한 내용을 정리했습니다.이전 글에서 Nginx 컴파일 설치 과정을 정리했습니다.이번 글에서는 proxy 설정과 서버 이중화를 위한 설정을 정리해보겠습니다.이전 글에서 nginx 컴파일 설치를 하며 주..
Git-Flow 브랜치 전략
·
Backend
프로젝트에 CI/CD를 적용하면서 브랜치의 용도를 나눠야 할 필요성을 느끼게 되었습니다. 프로젝트를 진행하면서 기능의 우선순위를 나눠 버전 관리를 위해 Git-Flow 전략을 참고하여 브랜치를 5종류로 나눠 관리하려고 합니다. 다양한 브랜치 관리 방법 중에 Git-Flow 방식을 도입한 이유는 앱 런칭을 위해 기획한 내용을 처음부터 완벽한 상태로 출시하기엔 어려운 점이 많았고, 이를 해결하기 위해 기능의 우선순위를 두어 버전별로 서버를 배포하는 방식으로 진행하기로 했습니다. Git-Flow 전략 간단하게 살펴보기 Git-Flow에는 5가지 종류의 브랜치가 존재합니다. 항상 유지되는 메인 브랜치들(master, develop)과 일정 기간 동안만 유지되는 보조 브랜치들(feature, release, ho..
GitHub Action CI/CD 파이프라인 구축하기(1)
·
DevOps
이전에 프로젝트 배포를 할 때는 jar 파일만을 올리는 git repository를 이용하여 push 한 후, EC2 서버에 접속한 뒤 jar 파일을 pull 받아 실행시키는 방식으로 배포를 했습니다.이 방식을 여러 번 진행한 결과 수동으로 매번 빌드를 하고 파일을 옮겨야 하는 방식이 매우 비효율적으로 느껴졌고, 이 과정을 자동화 할 방법을 찾아보게 되었습니다.불편함을 해소하고자 빌드/배포 자동화 방식들을 알아보게 되었고, 여러 방식들을 찾게 되었습니다.그 중 간단하게 적용할 수 있는 방법인 Github Actions를 사용하여 다양한 배포 방식을 적용하기로 했습니다.Github Action은 워크플로우를 통해 빌드와 배포의 자동화가 가능하며, 서버의 상태를 확인하고 배포하는 과정을 순차적으로 실행시킬 ..
Github Action이란
·
DevOps
Github Action이란 GitHub Actions는 빌드, 테스트 및 배포 파이프라인을 자동화할 수 있는 지속적 통합 및 지속적 배포(CI/CD) 플랫폼이다. 레포지토리에 대한 모든 풀 리퀘스트를 빌드하고 테스트하는 워크플로를 만들거나 병합된 풀 리퀘스트를 프로덕션에 배포할 수 있다. GitHub Action을 사용하는 이유 Github와 하나로 통일된 환경에서 CI 수행이 가능하다. 중앙에서 관리하는 Github Actions Runner에 지속적으로 트러블 슈팅하여 원활한 CI 환경 구성이 가능하다. 프로젝트마다 개별 Runner를 통한 빌드 테스트가 가능하다. Github Actions Runner 기동을 하기 위해 친숙한 문법의 YAML 파일로 간단하게 파이프라인 구성이 가능하다. 깃허브가 ..
[AWS] ECR - Elastic Container Registry
·
DevOps
AWS에서 제공하는 Docker Hub와 비슷한 개념으로, 안전하고 확장 가능하고 신뢰할 수 있는 AWS 관리형 컨테이너 이미지 레지스트리 서비스이다. Docker Hub와 동일하다고 볼 수 있지만 장점으로는 S3로 Docker Image를 고나리하므로 고가용성을 보장하고, AWS IAM 인증을 통해 이미지 push/pull 에 대한 권한 관리가 가능하다는 장점이 있다. ECR의 구성요소 Registry Amazon ECR 프라이빗 레지스트리는 각 AWS 계정마다 제공되며, 레지스트리에 하나 이상의 리포지토리를 생성하고 이 리포지토리에 이미지를 저장함 Repository ECR 리포지토리에는 Docker 이미지, Open Container Initiative(OCI) 이미지 및 OCI 호환 아티팩트가 포..
Spring에서 기상청 API 사용하기
·
Backend
프로젝트 개발을 진행하면서 공공데이터 API를 사용하며 API 통신으로 받아온 Json 데이터를 변환하는 방법을 정리한 글입니다. 현재 날짜의 최고 기온과, 최저 기온, 현재 시각의 습도를 조회하기 위해 기상청 단기예보 조회서비스를 사용한다.단기예보조회 API의 상세기능명세는 다음과 같다. 상세기능명 단기예보조회상세기능 설명단기예보 정보를 조회하기 위해 발표일자, 발표시각, 예보지점 X좌표, 예보지점 Y 좌표의 조회 조건으로 발표일자, 발표시각, 자료구분문자, 예보 값, 예보일자, 예보시각, 예보지점 X 좌표, 예보지점 Y 좌표의 정보를 조회하는 기능Call Back URLhttp://apis.data.go.kr/1360000/VilageFcstInfoService_2.0/get..
Jackson 라이브러리란?
·
Backend
프로젝트 개발을 진행하면서 공공데이터 API를 사용하며 API 통신으로 받아온 Json 데이터를 변환하는 방법을 정리한 글입니다.Java Object를 JSON으로 변환하거나 JSON을 Java Object로 변환하는데 사용할 수 있는 라이브러리인 jackson을 사용했습니다.Jackson-databindJackson 라이브러리는 Java 객체와 JSON 간의 변환 및 직렬화/역직렬화 작업을 수행하는데 사용된다.Jackson은 Java의 JSON 처리를 단순화하고 유연성을 제공하여 다양한 애플리케이션에서 데이터를 효과적으로 다룰 수 있도록 도와준다.jackson 라이브러리 dependency추가implementation group: 'com.fasterxml.jackson.core', name:..
Vagrant란?
·
DevOps
IaC란?IAC(Infrastructure as Code)는 인프라를 코드로서 정의하고 관리하는 개념을 의미합니다.IAC를 사용하면 인프라를 코드로 작성하여 버전 관리 시스템과 같은 도구를 사용하여 변경 내역을 추적하고 관리할 수 있다. 이를 통해 기존의 수동적이고 반복적인 인프라스트럭처 관리 작업을 자동화하고 효율성을 높일 수 있다. IAC의 장점:일관성: 코드로 인프라를 정의하면 반복 가능하고 일관된 방식으로 인프라를 배포할 수 있다. 수동 작업에 의존하는 것보다 실수를 줄이고 일관성을 유지할 수 있다.자동화: 인프라 아키텍처 배포를 코드화하고 자동화하여 개발 수명주기 전체에 걸쳐 효율성과 생산성을 크게 향상할 수 있다.확장성: 코드 기반의 인프라는 확장성이 용이하다. 필요에 따라 인..
Raid의 정의와 구축 실습
·
DevOps
RAIDRAID(Redundant Array of Independent)는 여러개의 하드 디스크가 있을 때 동일한 데이터를 다른 위치에 중복해서 저장하는 방법이다.운영체제에서 하나의 RAID는 논리적으로 하나의 디스크로 인식하여 처리된다.RAID는 초기에 저용량 하드디스크를 하나의 디스크로 확장하여 사용했으나, 현재는 백업을 가능하게 하고 안정적인 데이터의 보존과 유지 기능, 속도 향상등에 사용된다.RAID에서 사용하는 기술스트라이핑(Striping)연속된 데이터를 여러 개의 디스크에 라운드로빈 방식으로 기록하는 기술이다.프로세서가 하나의 디스크에서 읽어들이는 것보다 더 빠르게 데이터를 읽거나 쓸 수 있다면 매우 유용하다.대표적으로 RAID-0에서 사용하는 기술이고, 최소 2개의 디스크가 필요하..
Jenkins Pipeline 구축부터 eks 클러스터 배포까지
·
프로젝트/클라우드
Jenkins Pipeline 구성 DevOps & 클라우드 환경을 구성한 프로세스의 구성도이다. 우선 CI(Continous Integration) 작업은 다음과 같다. 개발자가 깃허브로 커밋을 하게 되면 Jenkins에서 변경사항을 감지하여 소스코드를 pull 받아 gradle로 빌드한다. 빌드한 파일을 openSSH를 이용하여 Ansible 서버로 전달하게 되면 Ansible에서 jar 파일을 도커 컨테이너로 빌드하여 업로드 하고, 이미지화하여 도커 허브에 업로드한다. CD(Continous Deployment)작업은 다음과 같다. 쿠버네티스 클러스터를 실행하고 있는 환경에서 도커 허브에 업로드했던 이미지를 pull 받아 파드로 실행한다. 로드밸런서를 연결하여 외부에서 접근할 수 있는 주소를 연결한..
클라우드 리소스 관리를 위한 모니터링 시스템 구축, Prometheus와 Grafana
·
프로젝트/클라우드
Grafana & PrometheusGrafana란 메트릭, 로그 등을 모니터링하고 분석할 수 있는 오픈 소스 시각 및 분석 툴이다.데이터 소스 수집툴인 Cloud Watch, 프로메테우스등과 통합하여 대시보드에 다양한 그래프, 차트, 표 등으로 시각화할 수 있다.Prometheus는 오픈 소스 시계열 데이터베이스 및 모니터링 시스템이다. 서버, 애플리케이션, 네트워크 등 다양한 시스템의 상태를 실시간으로 수집하고 저장하는 기능을 제공한다.데이터 수집툴로는 DataDog, CloudWatch, Prometheus 등이 있지만 프로젝트에서의 구현을 위해 오픈소스인 Prometheus를 사용한다.구성 방법쿠버네티스 클러스터의 리소스를 모니터링하기 위해 Prometheus와 Grafana를 사용한다..
[kubernetes] 파드, 컨테이너, 도커, 쿠버네티스의 관계
·
DevOps
컨테이너 인프라 환경이란? 리눅스 운영체제의 커널 하나에서 여러개의 컨테이너가 격리된 상태로 실행되는 인프라 환경이다. 여기서 컨테이너는 목적을 위해 독립적으로 작동하는 프로세스이다. 다수의 관리자가 수백대의 서버를 함께 관리해야하는 기업의 경우 서버 관리의 일관성을 유지하는 것이 중요하기 때문에 각각의 프로그램을 컨테이너로 구현해야한다. 여러 사람이 만져서 설정의 일관성이 떨어진 서버를 snowFlake라고 하는데 이런 경우 컨테이너 인프라 환경을 구성하면 서버의 파편화를 방지하는데 효과적이다. *컨테이너 인프라 환경의 구성 요소 *: 컨테이너 엔진 : 컨테이너를 생성하고 관리하는 데 사용되는 소프트웨어입니다. 대표적인 컨테이너 엔진으로는 Docker, containerd, cri-o 등이 있습니다. ..
okbear3
'분류 전체보기' 카테고리의 글 목록