🐯
경민민 IT 핸드북
  • Orientation
    • 전달사항
    • 복습방법
    • 수료한 선배의 한마디
    • 간단 자기소개
    • 스터디
  • 백엔드
    • Java
      • 1장 프로그래밍 기초
      • 2장 자바 메모리구조
        • 1. Stack
        • 2. Heap
      • 6장 객체
      • 8장 상속
      • 9장 다형성
      • 10장 추상클래스와 인터페이스
      • 13장 Generic
      • 14장 Thread
      • 15장 Network
      • 16장 Lamda
        • 1. 내부 클래스 (Inner Class)
          • DTO , VO, Builder Pattern
        • 2. 람다 표현식 (Lambda Expression)
        • 3. 스트림 API (Stream API)
          • Optional
      • 17장 Enum
  • 프론트
    • Node.js
    • Java Script
      • ES6+
        • Node.js로 자바스크립트 실행
        • let , const , var
        • Destructuring문법
          • Rest(...) 문법
        • Arrow Function
        • 모듈
        • ETC
    • Type Script
      • 개요
      • TS설치 및 환경설정
      • 타입스크립트 기본
        • 기본 자료형들과 타입추론
        • Object, Array , Tuple
        • Any, Unknown, Union Type
        • Function Type
          • Type Assertion && Narrowing
          • Never type
        • Type Aliases와 Interface
        • 리터럴 타입
        • 함수 추가 문법
        • Class문법
        • 객체 타입 추가 문법
        • 실습문제 1차
        • 실습문제 2차
        • 실습문제 3차
    • React
      • 개요
      • SPA 와 MPA
        • SEO(작성예정)
      • 리액트 프로젝트 생성(18.3.1.ver)
        • HTML + react 샘플
        • CRA 와 Vite 비교
      • 리액트 개념들
        • Component
          • 클래스 컴포넌트(작성예정)
          • 함수형 컴포넌트(작성예정)
        • JSX
        • React Virtual Dom
          • Reconciliation
        • hook
          • useState
        • 리액트 데이터 전달
          • FLUX
      • 백엔드 서버 연동
        • 비동기요청
        • 웹소켓
        • Promise(작성예정)
      • 실습문제 1
      • 실습문제 2
      • 실습문제3
      • 실습문제4
  • 프레임워크
    • Spring
      • Spring 개발환경 구축
        • 프로젝트 환경설정
        • 프로젝트 생성
          • MVC Project 생성이슈
        • Maven 설정
        • web.xml 설정
        • Spring Bean Configuration.xml 설정
      • Spring Legacy Project
        • Spring 요청 및 응답 흐름
        • Spring 주요 Annotation
          • 의존성 주입방식의 차이점
          • @ModelAttribute와 유효성검사
          • 비동기처리
          • 스프링 예외처리
        • Logging
        • Pagination
        • Spring File 업로드 및 다운로드
        • Spring WebSocket
        • Spring AOP
      • Spring 라이브러리들(작성예정)
        • Lombok
        • Maven
        • MyBatis
      • Spring 구성 모듈(작성예정)
      • 스프링 과제
    • Spring Boot
      • Spring Boot 개발환경 구축
      • 스프링 부트 프로젝트 생성방법들
        • 프로젝트에서 사용하는 의존성들
      • 스프링 프로젝트 구조
        • SpringBootApplication
      • application.properties
      • Cross Origin
        • CORS
      • WebSocket
        • Stomp(작성중)
      • 로그인(작성중)
      • Spring Security(작성중)
      • 실습문제 Select
      • 실습문제 Update
      • 실습문제 Delete
  • 형상관리(Git)
    • GitHub설정
    • SourceTree를 활용한 깃허브 연동
      • 소스트리 설치
      • Clone
      • Branch
        • Branch Protection rules
          • Branch Protection Rules 상세규칙
        • Rebase 와 Squash (작성예정)
      • Team Project 설정
        • 팀장 프로젝트 셋팅
          • Collaborator
          • .gitignore 설정
        • 팀원 프로젝트 셋팅
        • 공통 프로젝트 진행
  • 프로젝트
    • 진행순서
      • 요구사항 분석 단계
        • 유용한 사이트
      • 프로그램 설계 단계
        • 유용한 사이트
      • 프로그램 구현단계
        • SourceTree를 활용한 Team Project설정
      • 테스트 단계
  • 배포
    • AWS-EC2 배포 연습
    • DevOps
      • IT시스템의 변화와 DevOps
      • DevOps 라이프사이클
    • 젠킨스
      • 도커
        • 도커 설치 방법
        • 도커 기본 명령어들
      • 젠킨스 설치
      • 젠킨스 프로젝트 생성
      • 젠킨스 소스코드 통합 - Github
      • 젠킨스 빌드 설정 - Maven
      • 배포 서버 구축하기
      • 파이프라인 구축
      • AWS 서버 생성
        • AWS 인스턴스 생성
        • AWS - Zenkins 연동
        • AWS - 배포서버 연동
        • AWS - Jenkins CI/CD파이프라인 구축
  • 유용한 사이트 모음
  • SQL
    • SQLD
      • 데이터 모델링의 이해 - 스키마
      • 데이터 모델링의 이해 - ERD
      • 데이터 모델링의 이해 - 정규화
      • 데이터 모델링의 이해 - NULL
      • SQL 기본 및 활용 - WINDOW FUNCTION
    • Oracle
      • 1장 개요
      • 2장 SQL
  • LLM 서비스
    • 1장 LLM에 대한 이해
    • 2장 프롬프트 엔지니어링
      • 프롬프트와 프롬프트 엔지니어링
      • GPT PlayGround
      • 프롬프트 작문 유형
      • 기본 프롬프트 엔지니어링 태크닉
      • 고급 프롬프트 엔지니어링 태크닉
        • ReAct Prompting
        • Active-Prompt
        • Reflexion
        • Graph Prompt
      • OpenAI API설정
      • OpenAI를 활용한 프롬프트 엔지니어링 실습
        • 실습 프롬프트
    • 3장 Lang Chain 프레임워크
      • LangSmith 프레임워크
        • LangSmith를 활용한 LangChain 모니터링 설정
      • LangChain 실습 1 - Prompt
        • 실습 코드
      • LangChain 실습 2 - LLM 캐시와 메모리
    • 4장 RAG
      • Document Loader - 문서 로더
      • Text Splitter - 텍스트 분할
      • Embedding - 임베딩
      • Vector Store - 벡터 저장소
      • Retriever - 검색기
      • ReRanker - 재평가자
      • RAG
Powered by GitBook
On this page
  • Intro
  • Branch Protection rules
  • Branch Protection Rules 상세규칙 분석
  1. 형상관리(Git)
  2. SourceTree를 활용한 깃허브 연동
  3. Branch

Branch Protection rules

브랜치 보호에 대한 개념과 필요한 이유 및 설정방법에 대해 기술한 페이지

PreviousBranchNextBranch Protection Rules 상세규칙

Last updated 10 months ago

Intro

일반적으로 github를 통한 협업시 main/master 브랜치는 프로젝트의 메인이 되는 형상을 보관하는 중요한 브랜치이며 각 개발자는 main브랜치의 내용을 바탕으로 프로젝트를 시작하여 최종적으로 main브랜치에 코드를 병합하여 어플리케이션을 완성할 것이다.

즉 main브랜치로의 코드 병합은 각 개발자의 검토(review)과정을 통해 신중하게 진행되어야 한다.

하지만 개발자의 실수로 인해 main -> origin/main으로의 push나 feature/1 -> origin/main 로의 push로 main브랜치의 형상이 달라진다면 이를 공유해서 사용하고 있는 다른 개발자들은 예상치 못한 변경사항에 대해 인지 하지 못하고 있다가, 병합(merge)시 충돌(conflict)이 발생하거나 잘못된 프로세스로 인한 프로그램의 작동오류로 연결될 수 있다.

따라서 애초에 PR없는 main브랜치로의 merge는 원천 차단할 필요가 있고 이 기능은 Branch Protection rules로 설정 가능하다.

Branch Protection rules

  • 브랜치 보호를 위한 규칙들을 정의하는 공간.

  • Settings- Branches - Add branch ruleset에서 설정 가능하다.

  • 현재 문서에서는 main브랜치로의 직접적인 push를 방지하는 rule에대해서만 다룰 예정이다.

  • RulesetName : rule의 이름을 적는다.

  • Enforcement status : 현재 룰의 활성화 여부. Active로 전환해야 Rule이 적용된다.

  • Bypass list : 현재 rule의 규칙에서 우회 할 수 있는 사용자를 추가하는 공간. main의 푸시는 모든 사용자에 대해 빠짐없이 규칙을 적용시킬 예정이라 추가할 필요 없다.

브랜치 보호 룰을 적용할 target 브랜치를 설정한다.(정규식 패턴 지정가능)

Protection rules들 중에서 아래만 선택

  • Require a pull request before merging : main 브랜치에 merge 하기 전에 반드시 PR을 해야한다는 설정. 즉 main으로의 직접적인 push를 막을수 있다.

  • Required approvals : merge에 필요한 승인 회수. 각 참여자는 Review를 통해 PR을 승인처리 할 수 있다.

  • Dismiss stale pull request approvals when new commits are pushed : PR에 승인을 했더라도 merge를 요청한 브랜치에서추가 push가 발생했다면 승인을 무효화하는 설정.

보호규칙을 추가한 후 로컬 main에서 원격 main으로의 push는 더 이상 불가능하다. main에 내가 원하는 소스코드를 병합하기 위해서는 작업용 브랜치 생성 후 작업용 브랜치로부터 PR을 통해 merge해줘야한다.

PR 요청후 Review를 통해 해당 커밋에 대한 승인을 완료해야 merge가 가능하다

1) Files changed로 이동하여 코드의 수정사항을 검토한 후

2) Review Changes버튼을 눌러 코드에 대한 리뷰를 남기고,

3) Approve를 체크한 상태로 저장을 해야 승인이 완료된다. 이때 본인의 PR에는 승인을 할 수 없으므로 다른 팀원이 검토 후 승인을 해줘야 한다.

Branch Protection Rules 상세규칙 분석

Active로 해야된다
여기 클릭
main선정
Rules Rulesets에서 생성된 rule들 확인/수정/삭제/추가 가능함
룰 설정 후 main->origin/main push error
PR생성후 화면. 붉은 글씨로 merge가 blocked 된것을 확인해 볼 수 있다.
Managing a branch protection rule - GitHub DocsGitHub Docs
Logo