+ 개발

Git과 GitHub 사용법: 기본 개념부터 실전 활용까지

AI.Logger 2024. 10. 11. 00:10
  • 수업 내용 리마인드 및 아카이빙 목적의 업로드


 

오늘은 개발자라면 반드시 알아야 할 두 가지 도구, GitGitHub에 대해 알아보려 합니다. 이 글에서는 Git과 GitHub의 기본 개념부터 설치 방법, 실전 사용법까지 차근차근 설명해드릴 예정이니, 끝까지 읽고 여러분의 개발 역량을 한 단계 끌어올리세요!

 

Git이란?

Git은 소스 코드의 버전 관리 시스템입니다. 쉽게 말해, 소스 코드의 변경 이력을 기록하고 팀원들과 협업하는 데 매우 유용한 도구입니다. Git을 사용하면 코드의 변경사항을 손쉽게 추적하고, 여러 명의 개발자가 동시에 작업하더라도 충돌 없이 협업이 가능합니다.

Git은 개발자들이 여러 버전의 파일을 관리하고, 필요할 때 과거 버전으로 되돌아갈 수 있게 해줍니다. 이를 통해 오류나 충돌이 발생했을 때 빠르게 복구할 수 있어 개발 과정에서의 생산성을 높여줍니다.

 

Git의 주요 기능

  1. 버전 관리: 수정한 기록을 언제, 무엇을 변경했는지 구체적으로 관리할 수 있습니다. 이를 통해 작업의 이력을 정확히 파악하고 문제 발생 시 특정 시점으로 되돌아갈 수 있습니다.
  2. 백업: 현재 컴퓨터의 데이터를 다른 컴퓨터로 복제하는 기능도 지원해 데이터를 안전하게 보관할 수 있습니다. 특히 팀 프로젝트에서는 여러 장치에 데이터를 백업해두면 데이터를 잃어버릴 위험을 줄일 수 있습니다.
  3. 협업: 팀원들과 파일을 주고받으며 편리하게 협업할 수 있습니다. Git을 통해 여러 개발자가 동시에 작업해도 충돌을 최소화하고 각자의 변경 사항을 쉽게 합칠 수 있습니다.

 

Git 설치 방법

- Windows에서 Git 설치하기

  1. Git 공식 웹사이트에 접속해 설치 파일을 다운로드합니다.
  2. 설치 파일을 실행한 후, 기본 설정을 유지하며 Next를 클릭해 설치를 완료합니다.
  3. 편집기로 VSCode를 설정하면 편리하게 사용할 수 있습니다.

설치가 완료되면, Windows 작업표시줄에서 git bash를 검색해 실행하고, 제대로 설치되었는지 확인할 수 있습니다.

 

- Mac에서 Git 설치하기

  1. Homebrew 패키지 관리자를 통해 Git을 설치할 수 있습니다. Homebrew 공식 사이트에서 설치 방법을 참고하세요.
  2. 터미널에서 다음 명령어를 실행하여 Git을 설치합니다.

설치가 완료되면, 터미널에서 git --version 명령어를 입력해 설치가 완료되었는지 확인할 수 있습니다.

 

Git의 기본 사용법

- Git 저장소 생성하기

Git 저장소는 프로젝트의 버전을 관리하는 공간입니다. 다음과 같은 명령어로 쉽게 Git 저장소를 생성할 수 있습니다.

  1. 저장소 생성: Git을 초기화하여 저장소를 만듭니다.
  2. 이 명령어는 현재 디렉토리에 .git이라는 숨김 폴더를 생성하여 Git 저장소로 초기화합니다.
  3. 파일 추가 및 커밋하기:
    • add 명령어로 파일을 스테이지에 추가합니다.
    • commit 명령어로 파일을 저장소에 버전으로 등록합니다.
    스테이징된 파일들은 커밋을 통해 저장소에 버전으로 기록되며, 이때 작성한 메시지를 통해 변경 내역을 쉽게 파악할 수 있습니다.

- Git의 작업 영역 이해하기

Git의 작업 영역은 크게 세 부분으로 나뉩니다.

  • 작업 트리(Working Tree): 현재 작업 중인 디렉토리입니다. 파일을 생성하거나 수정할 수 있는 공간입니다.
  • 스테이지(Stage): 커밋을 위한 대기 공간입니다. git add 명령어를 통해 파일을 스테이지에 올릴 수 있습니다.
  • 저장소(Repository): 커밋된 파일들이 저장되는 공간입니다. 이곳에 저장된 파일들은 버전으로 관리됩니다.

이 구조를 통해 파일의 수정 내역을 체계적으로 관리할 수 있으며, 작업 중인 파일을 원하는 시점으로 되돌릴 수 있습니다.

 

Git의 버전 관리와 되돌리기

Git은 변경된 파일의 모든 버전을 기록하므로 언제든지 이전 상태로 되돌릴 수 있습니다.

  • add와 commit:
    • git add 파일명 명령어를 통해 작업 트리에서 파일을 스테이지로 이동시킵니다.
    • git commit -m "메시지" 명령어를 통해 스테이지의 파일을 저장소에 기록합니다.
  • git restore 명령어를 사용하여 특정 파일을 이전 상태로 복원하거나, git reset을 통해 최근 커밋을 취소할 수 있습니다. 예를 들어, 잘못된 커밋을 되돌리고 싶다면 다음 명령어를 사용할 수 있습니다.
  • git log 명령어를 통해 저장소의 커밋 이력을 확인할 수 있습니다. 각 커밋에는 고유한 해시 값이 부여되어, 특정 버전으로 되돌아가거나 특정 시점의 이력을 확인하는 데 유용합니다.

 

GitHub란?

GitHub는 Git 저장소를 온라인에 업로드하여 다른 개발자와 협업할 수 있도록 도와주는 플랫폼입니다. GitHub를 통해 원격 저장소를 생성하고, 로컬 저장소의 코드를 공유하거나 협력할 수 있습니다. 이 과정에서 코드 리뷰, 이슈 관리 등 협업을 위한 다양한 도구도 제공됩니다.

 

GitHub 사용법

  1. 회원가입 및 저장소 생성: GitHub에 가입한 후, 새로운 레포지토리를 생성합니다.
  2. 로컬 저장소와 원격 저장소 연결:
  3. 이 명령어를 통해 로컬 저장소를 GitHub의 원격 저장소와 연결합니다.
  4. 원격 저장소에 업로드:
  5. 이 명령어를 사용하여 로컬 저장소의 커밋 내용을 원격 저장소에 업로드할 수 있습니다.

 

협업의 핵심: 브랜치와 병합

Git의 브랜치(branch) 기능은 새로운 기능을 개발하거나 버그를 수정할 때 매우 유용합니다. 브랜치는 마치 나뭇가지처럼 메인 코드에서 분기하여 독립적으로 작업할 수 있게 해줍니다.

  1. 브랜치 생성: 새로운 브랜치를 생성하여 독립적인 작업을 할 수 있습니다.
  2. 브랜치 전환: 생성된 브랜치로 전환하여 작업할 수 있습니다.
  3. 브랜치 병합: 작업이 완료된 브랜치를 메인 브랜치에 병합할 수 있습니다. 이를 통해 메인 코드에 새로운 기능이나 수정 사항을 추가하게 됩니다.
  4. 브랜치 삭제: 작업이 완료된 브랜치는 다음 명령어로 삭제할 수 있습니다.

브랜치를 활용하면 여러 명이 동시에 작업하면서도 코드의 안정성을 유지할 수 있어 협업에 매우 유용합니다.

 

GitHub로 협업하기

GitHub에서는 팀원들과의 협업이 매우 용이합니다. 이슈 트래킹, 코드 리뷰, 풀 리퀘스트 등을 통해 효율적인 협업이 가능합니다.

  • 이슈(Issue): 프로젝트에서 발생하는 문제나 새로운 기능 제안을 기록하고 관리할 수 있습니다.
  • 풀 리퀘스트(Pull Request): 브랜치에서 작업한 내용을 메인 브랜치에 병합하고자 할 때 요청을 보낼 수 있습니다. 팀원들은 이 요청을 검토하고 피드백을 남기며 코드를 개선할 수 있습니다.
  • 코드 리뷰: 팀원들이 작성한 코드를 검토하고 피드백을 남길 수 있는 기능으로, 코드 품질을 높이고 버그를 사전에 방지할 수 있습니다.

 

마크다운(Markdown) 사용하기

GitHub에서는 마크다운(Markdown)을 사용하여 README 파일을 작성하거나 이슈 및 풀 리퀘스트 설명을 작성할 수 있습니다. 마크다운은 간단한 문법으로 텍스트를 꾸미고 구조화할 수 있어 매우 유용합니다.

 

- 마크다운의 장점

  • 간결하고 사용하기 쉬움: 별도의 도구 없이 쉽게 작성 가능하며, 텍스트 기반이라 용량도 적습니다.
  • 변환 가능성: HTML로 쉽게 변환할 수 있어 웹에서도 활용할 수 있습니다.
  • 버전 관리: 텍스트 파일로 저장되기 때문에 Git을 사용해 변경 이력을 관리할 수 있습니다.

- 마크다운의 단점

  • 표준 없음: 도구에 따라 변환 방식이나 생성물이 다를 수 있습니다.
  • 제한된 기능: 모든 HTML 마크업을 대신하지 못하므로, 복잡한 레이아웃을 구성하기에는 한계가 있습니다.

 

GitHub Pages로 웹사이트 배포하기

GitHub는 단순한 버전 관리 도구를 넘어, GitHub Pages를 통해 정적 웹사이트를 배포할 수 있는 기능도 제공합니다. 이를 통해 프로젝트의 결과물을 간단히 공개하거나, 개인 블로그를 운영할 수도 있습니다.

  1. GitHub Pages 설정: 레포지토리의 Settings에서 Pages 항목을 클릭합니다.
  2. 브랜치 설정: Source 부분을 main 브랜치로 설정하고 Save를 클릭하면, 해당 브랜치의 내용을 기반으로 웹사이트가 배포됩니다.