mirror of
https://github.com/MichaelCade/90DaysOfDevOps.git
synced 2025-01-19 16:57:53 +07:00
b6340966bc
Translated 2022 day35 to korean Rename the world "파워셸" to "PowerShell" Translated 2022 day36 to korean Fixed unnatural translation in 2022 day36 ko Fixed unnatural translation in 2022 day38 ko Fixed unnatural translation in 2022 day31 ko Translated 2022 day37 to korean Rename the word "병합" to "merge" Rename the word "디렉터리" to "디렉토리" Translated 2022 day39 to korean wip Translated 2022 day40 to korean Translated 2022 day41 to korean Translated 2022 day42 to korean Translated 2022 day43 to korean Rename the word "브랜치" to "branch" Translated 2022 day44 to korean Translated 2022 day45 to korean Translated 2022 day46 to korean Translated 2022 day47 to korean Translated 2022 day48 to korean Fixed image link in 2022 day48 ko Translated 2022 day49 to korean Translated 2022 day50 to korean Rename the word "명령줄" to "커맨드라인" Translated 2022 day51 to korean Translated 2022 day52 to korean Translated 2022 day53 to korean Translated 2022 day54 to korean Translated 2022 day55 to korean
155 lines
7.2 KiB
Markdown
155 lines
7.2 KiB
Markdown
---
|
|
title: '#90DaysOfDevOps - Installing & Configuring Git - Day 36'
|
|
published: false
|
|
description: 90DaysOfDevOps - Installing & Configuring Git
|
|
tags: 'devops, 90daysofdevops, learning'
|
|
cover_image: null
|
|
canonical_url: null
|
|
id: 1048738
|
|
---
|
|
|
|
## Git 설치 및 구성
|
|
|
|
Git은 버전 관리를 위한 오픈 소스 크로스 플랫폼 도구입니다. 저처럼 우분투 또는 대부분의 Linux 환경을 사용하는 경우 이미 Git이 설치되어 있을 수 있지만 설치 및 구성 과정을 살펴보겠습니다.
|
|
|
|
시스템에 이미 git이 설치되어 있더라도 최신 버전인지 확인하는 것도 좋은 방법입니다.
|
|
|
|
### Git 설치하기
|
|
|
|
이미 언급했듯이 Git은 크로스 플랫폼이므로 Windows와 Linux를 통해 실행할 것이지만 [여기](https://git-scm.com/book/en/v2/Getting-Started-Installing-Git)에서 macOS도 찾을 수 있습니다.
|
|
|
|
[Windows](https://git-scm.com/download/win)의 경우 공식 사이트에서 설치할 수 있습니다.
|
|
|
|
Windows 컴퓨터에서 `winget`을 사용할 수도 있는데, 이것을 Windows 애플리케이션 패키지 관리자라고 생각하면 됩니다.
|
|
|
|
설치하기 전에 Windows 머신에 어떤 버전이 있는지 확인해 보겠습니다. PowerShell 창을 열고 `git --version`을 실행합니다.
|
|
|
|
![](/2022/Days/Images/Day36_Git1.png)
|
|
|
|
WSL 우분투 버전의 Git도 확인할 수 있습니다.
|
|
|
|
![](/2022/Days/Images/Day36_Git2.png)
|
|
|
|
이 글을 쓰는 시점에 최신 Windows 릴리스는 `2.35.1`이므로 업데이트해야 할 사항이 몇 가지 있는데 이를 살펴보겠습니다. 리눅스도 마찬가지일 것으로 예상합니다.
|
|
|
|
저는 최신 설치 프로그램을 다운로드하고 마법사를 실행했으며 여기에 이를 문서화할 것입니다. 주의해야 할 중요한 점은 최신 버전을 설치하기 전에 git이 이전 버전을 제거한다는 것입니다.
|
|
|
|
즉, 아래에 표시된 프로세스도 대부분 git을 사용하지 않고 설치하는 것과 동일한 프로세스입니다.
|
|
|
|
매우 간단한 설치입니다. 다운로드가 완료되면 두 번 클릭하고 시작하세요. GNU 라이선스 계약을 읽어보세요. 하지만 이 소프트웨어는 무료 오픈소스 소프트웨어라는 점을 기억하세요.
|
|
|
|
![](/2022/Days/Images/Day36_Git3.png)
|
|
|
|
이제 추가로 설치할 컴포넌트를 선택해 git과 연결할 수 있습니다. 저는 Windows에서 bash 스크립트를 실행할 수 있는 Git Bash를 항상 설치합니다.
|
|
|
|
![](/2022/Days/Images/Day36_Git4.png)
|
|
|
|
그런 다음 사용할 SSH 실행 파일을 선택할 수 있습니다. 리눅스 섹션에서 보셨을 번들 OpenSSH를 그대로 두겠습니다.
|
|
|
|
![](/2022/Days/Images/Day36_Git5.png)
|
|
|
|
그다음에는 실험적인 기능을 활성화할 수 있는데, 저는 필요하지 않으므로 활성화하지 않고 나중에 설치를 통해 돌아와서 언제든지 활성화할 수 있습니다.
|
|
|
|
![](/2022/Days/Images/Day36_Git6.png)
|
|
|
|
설치가 완료되었으므로 이제 Git Bash 및 최신 릴리스 노트를 열도록 선택할 수 있습니다.
|
|
|
|
![](/2022/Days/Images/Day36_Git7.png)
|
|
|
|
마지막 확인은 PowerShell 창에서 현재 어떤 버전의 git이 있는지 살펴보는 것입니다.
|
|
|
|
![](/2022/Days/Images/Day36_Git8.png)
|
|
|
|
매우 간단하며 이제 최신 버전을 사용하고 있습니다. 리눅스 머신에서는 업데이트가 조금 늦은 것 같아서 업데이트 과정을 안내해 드리겠습니다.
|
|
|
|
`sudo apt-get install git` 명령을 실행하기만 하면 됩니다.
|
|
|
|
![](/2022/Days/Images/Day36_Git9.png)
|
|
|
|
다음을 실행하여 소프트웨어 설치를 위한 git 저장소를 추가할 수도 있습니다.
|
|
|
|
```
|
|
sudo add-apt-repository ppa:git-core/ppa -y
|
|
sudo apt-get update
|
|
sudo apt-get install git -y
|
|
git --version
|
|
```
|
|
|
|
### Git 구성하기
|
|
|
|
처음 git을 사용할 때는 몇 가지 설정을 정의해야 합니다,
|
|
|
|
- Name
|
|
- Email
|
|
- 기본 에디터
|
|
- Line Ending
|
|
|
|
이 설정은 세 가지 수준에서 수행할 수 있습니다.
|
|
|
|
- System = 모든 사용자
|
|
- Global = 현재 사용자의 모든 리포지토리
|
|
- Local = 현재 리포지토리
|
|
|
|
예제
|
|
`git config --global user.name "Michael Cade"`
|
|
`git config --global user.email Michael.Cade@90DaysOfDevOPs.com"`
|
|
운영 체제에 따라 기본 텍스트 편집기가 결정됩니다. 다음 명령을 설정하지 않은 제 우분투 머신에서는 Nano를 사용하고 있습니다. 아래 명령은 이를 비주얼 스튜디오 코드로 변경합니다.
|
|
|
|
`git config --global core.editor "code --wait"`
|
|
|
|
이제 모든 git 구성을 보려면 다음 명령을 사용하면 됩니다.
|
|
|
|
`git config --global -e`
|
|
|
|
![](/2022/Days/Images/Day36_Git10.png)
|
|
|
|
어떤 머신에서든 이 파일의 이름은 `.gitconfig`입니다. 제 Windows 머신에서는 사용자 계정 디렉토리에서 이 파일을 찾을 수 있습니다.
|
|
|
|
![](/2022/Days/Images/Day36_Git11.png)
|
|
|
|
### Git 이론
|
|
|
|
어제 포스트에서 다른 버전 관리 유형이 있으며 이를 두 가지 유형으로 나눌 수 있다고 언급했습니다. 하나는 "클라이언트-서버"이고 다른 하나는 "분산"입니다.
|
|
|
|
### 클라이언트-서버 버전 제어
|
|
|
|
git이 등장하기 전에는 클라이언트-서버가 버전 관리를 위한 사실상 유일한 방법이었다. 그 예로 2000년에 설립된 오픈소스 버전 관리 시스템인 [Apache Subversion](https://subversion.apache.org/)을 들 수 있습니다.
|
|
|
|
이 클라이언트-서버 버전 제어 모델에서는 개발자가 서버에서 소스 코드와 실제 파일을 다운로드하는 것이 첫 번째 단계입니다. 이렇게 한다고 해서 충돌이 예방되는 것은 아니지만 충돌의 복잡성과 해결 방법이 예방됩니다.
|
|
|
|
![](/2022/Days/Images/Day36_Git12.png)
|
|
|
|
예를 들어 두 명의 개발자가 같은 파일을 작업하고 있는데 한 개발자가 새로운 변경 사항을 먼저 커밋하거나 서버에 파일을 다시 업로드한다고 가정해 보겠습니다. 두 번째 개발자가 업데이트를 하려고 할 때 충돌이 발생합니다.
|
|
|
|
![](/2022/Days/Images/Day36_Git13.png)
|
|
|
|
이때, 첫 번째 개발자의 코드 변경 사항을 가져와서 자신의 작업과 충돌하는 부분을 모두 처리한 다음, 커밋해야 합니다.
|
|
|
|
![](/2022/Days/Images/Day36_Git15.png)
|
|
|
|
### 분산 버전 제어
|
|
|
|
Git이 유일한 분산 버전 제어 시스템은 아닙니다. 하지만 사실상 거의 유일한 시스템입니다.
|
|
|
|
Git의 주요 이점은 다음과 같습니다:
|
|
|
|
- 빠름
|
|
- 스마트
|
|
- 유연함
|
|
- 안전 및 보안
|
|
|
|
클라이언트-서버 버전 제어 모델과 달리 각 개발자는 커밋 히스토리, 모든 branch 등을 의미하는 소스 리포지토리를 다운로드합니다.
|
|
|
|
![](/2022/Days/Images/Day36_Git16.png)
|
|
|
|
## 자료
|
|
|
|
- [What is Version Control?](https://www.youtube.com/watch?v=Yc8sCSeMhi4)
|
|
- [Types of Version Control System](https://www.youtube.com/watch?v=kr62e_n6QuQ)
|
|
- [Git Tutorial for Beginners](https://www.youtube.com/watch?v=8JJ101D3knE&t=52s)
|
|
- [Git for Professionals Tutorial](https://www.youtube.com/watch?v=Uszj_k0DGsg)
|
|
- [Git and GitHub for Beginners - Crash Course](https://www.youtube.com/watch?v=RGOj5yH7evk&t=8s)
|
|
- [Complete Git and GitHub Tutorial](https://www.youtube.com/watch?v=apGV9Kg7ics)
|
|
|
|
[Day 37](day37.md)에서 봐요!
|