Skip to content

Commit 7fd7d19

Browse files
committed
1
1 parent 4aa52de commit 7fd7d19

File tree

6 files changed

+236
-222
lines changed

6 files changed

+236
-222
lines changed

web/page-git/page1.md

Lines changed: 6 additions & 170 deletions
Original file line numberDiff line numberDiff line change
@@ -1,177 +1,13 @@
1-
# git 명령어
1+
# git 설명서
22

33

4-
## 최초 git 설정
5-
6-
* https://git-scm.com/ 설치
7-
* git bash 열기
8-
9-
```
10-
git config --global user.name "{사용자-이름}"
11-
git config --global user.email "{사용자-이메일}"
12-
git config --list
13-
```
14-
![gitbash](./page1-gitbash.png "git bash")
15-
16-
17-
18-
19-
## 새 저장소 만들기
20-
21-
```
22-
echo "# test" >> README.md
23-
git init
24-
git add README.md
25-
git commit -m "first commit"
26-
git branch -M master
27-
git remote add origin https://github.com/code1009/{저장소-이름}.git
28-
git push -u origin master
29-
```
30-
31-
32-
## 기존 저장소 푸시
33-
34-
```
35-
git remote add origin https://github.com/code1009/{저장소-이름}.git
36-
git branch -M master
37-
git push -u origin master
38-
```
39-
40-
41-
42-
## 원격 연결 확인
43-
44-
* 명령어
45-
```
46-
git remote -v
47-
```
48-
49-
* 출력결과
50-
```
51-
origin https://github.com/code1009/{저장소-이름}.git (fetch)
52-
origin https://github.com/code1009/{저장소-이름}.git (push)
53-
```
54-
55-
56-
## 복제(clone)
57-
58-
```
59-
git clone {저장소-주소} {로컬-폴더}
60-
```
61-
62-
63-
64-
## 로컬에서 브랜치 생성 및 전환
65-
66-
```
67-
git checkout -b {브랜치-이름}
68-
```
69-
> `-b` 생성 옵션
70-
71-
72-
## 로컬에서 브랜치 생성 및 전환 후 푸쉬
73-
74-
```
75-
git push --set-upstream origin {브랜치-이름}
76-
```
77-
78-
> 최초 푸시 시 필요함
79-
80-
81-
82-
## 원격 동기화
83-
84-
```
85-
git fetch origin
86-
```
87-
88-
89-
90-
## 로컬에서 브랜치 전환
91-
92-
```
93-
git checkout {브랜치-이름}
94-
```
95-
96-
97-
## 충돌(conflict) 이후 해결 예시
98-
99-
* develop 브랜치 최신 내용 feature 브랜치에 병합
100-
101-
```
102-
git checkout develop
103-
git pull origin develop
104-
git checkout feature
105-
git merge develop
106-
```
107-
108-
* 충돌 해결 후 커밋 및 푸시
109-
110-
```
111-
git add .
112-
git commit -m "resolve conflicts"
113-
git push
114-
```
115-
116-
117-
118-
## 서로 다른 저장소 이력 병합
119-
120-
```
121-
git pull origin {브랜치-이름} --allow-unrelated-histories
122-
```
123-
124-
125-
126-
## 저장소 초기화
127-
128-
```
129-
{.git 폴더 삭제(`rmdir /s /q .git`}
130-
git init
131-
git add --all
132-
git commit -m "init"
133-
git remote add origin https://github.com/code1009/{저장소-이름}.git
134-
git push -f origin master
135-
```
136-
137-
138-
139-
## 커밋 이력 확인
140-
141-
```
142-
git log
143-
```
144-
145-
146-
147-
## 저장소 상태 확인
148-
149-
```
150-
git status
151-
```
152-
153-
154-
155-
## 덮어쓰기
156-
157-
```
158-
git reset --hard origin
159-
git reset --soft origin
160-
git reset --soft HEAD~{커밋수}
161-
git reset --hard origin/{브랜치-이름}
162-
```
163-
164-
165-
166-
## 커밋 합치기
167-
168-
```
169-
git rebase -i HEAD~{커밋수}
170-
```
171-
> 가급적 금지
172-
> > 협업 중인 브랜치에서 rebase는 충돌 및 이력 꼬임 위험
4+
## 레퍼런스
1735

6+
* https://git-scm.com/docs
1747

8+
## 링크
1759

10+
* https://www.youtube.com/watch?v=Z9dvM7qgN9s&t=309s
17611

12+
* https://www.youtube.com/watch?v=tkkbYCajCjM
17713

web/page-git/page2.md

Lines changed: 167 additions & 29 deletions
Original file line numberDiff line numberDiff line change
@@ -1,39 +1,177 @@
1-
# git rebase
1+
# git 명령어
22

3-
## `git rebase develop`
4-
- `git rebase develop` 명령어는 현재 작업 중인 브랜치를 develop 브랜치의 최신 커밋 위에 다시 적용하는 명령어입니다.
5-
즉, develop 브랜치의 변경 사항을 현재 브랜치에 반영하면서,
6-
마치 현재 브랜치가 develop 브랜치에서 분기된 것처럼 커밋 기록을 정리하는 것입니다.
73

8-
- 예를 들어, feature/login 브랜치에서 작업 중이고,
9-
develop 브랜치의 최신 변경 사항을 반영하고 싶다면 아래와 같이 사용합니다.
4+
## 최초 git 설정
5+
6+
* https://git-scm.com/ 설치
7+
* git bash 열기
8+
9+
```
10+
git config --global user.name "{사용자-이름}"
11+
git config --global user.email "{사용자-이메일}"
12+
git config --list
13+
```
14+
![gitbash](./page1-gitbash.png "git bash")
15+
16+
17+
18+
19+
## 새 저장소 만들기
20+
21+
```
22+
echo "# test" >> README.md
23+
git init
24+
git add README.md
25+
git commit -m "first commit"
26+
git branch -M master
27+
git remote add origin https://github.com/code1009/{저장소-이름}.git
28+
git push -u origin master
29+
```
30+
31+
32+
## 기존 저장소 푸시
33+
34+
```
35+
git remote add origin https://github.com/code1009/{저장소-이름}.git
36+
git branch -M master
37+
git push -u origin master
38+
```
39+
40+
41+
42+
## 원격 연결 확인
43+
44+
* 명령어
45+
```
46+
git remote -v
47+
```
48+
49+
* 출력결과
50+
```
51+
origin https://github.com/code1009/{저장소-이름}.git (fetch)
52+
origin https://github.com/code1009/{저장소-이름}.git (push)
53+
```
54+
55+
56+
## 복제(clone)
57+
58+
```
59+
git clone {저장소-주소} {로컬-폴더}
60+
```
61+
62+
63+
64+
## 로컬에서 브랜치 생성 및 전환
65+
66+
```
67+
git checkout -b {브랜치-이름}
68+
```
69+
> `-b` 생성 옵션
70+
71+
72+
## 로컬에서 브랜치 생성 및 전환 후 푸쉬
73+
74+
```
75+
git push --set-upstream origin {브랜치-이름}
76+
```
77+
78+
> 최초 푸시 시 필요함
79+
80+
81+
82+
## 원격 동기화
83+
84+
```
85+
git fetch origin
86+
```
87+
88+
89+
90+
## 로컬에서 브랜치 전환
91+
92+
```
93+
git checkout {브랜치-이름}
94+
```
95+
96+
97+
## 충돌(conflict) 이후 해결 예시
98+
99+
* develop 브랜치 최신 내용 feature 브랜치에 병합
100+
101+
```
102+
git checkout develop
103+
git pull origin develop
104+
git checkout feature
105+
git merge develop
106+
```
107+
108+
* 충돌 해결 후 커밋 및 푸시
109+
110+
```
111+
git add .
112+
git commit -m "resolve conflicts"
113+
git push
114+
```
115+
116+
117+
118+
## 서로 다른 저장소 이력 병합
119+
120+
```
121+
git pull origin {브랜치-이름} --allow-unrelated-histories
122+
```
123+
124+
125+
126+
## 저장소 초기화
127+
128+
```
129+
{.git 폴더 삭제(`rmdir /s /q .git`}
130+
git init
131+
git add --all
132+
git commit -m "init"
133+
git remote add origin https://github.com/code1009/{저장소-이름}.git
134+
git push -f origin master
135+
```
136+
137+
138+
139+
## 커밋 이력 확인
140+
141+
```
142+
git log
143+
```
144+
145+
146+
147+
## 저장소 상태 확인
148+
149+
```
150+
git status
151+
```
152+
153+
154+
155+
## 덮어쓰기
156+
157+
```
158+
git reset --hard origin
159+
git reset --soft origin
160+
git reset --soft HEAD~{커밋수}
161+
git reset --hard origin/{브랜치-이름}
162+
```
163+
164+
165+
166+
## 커밋 합치기
10167

11168
```
12-
git checkout feature/login
13-
git rebase develop
169+
git rebase -i HEAD~{커밋수}
14170
```
171+
> 가급적 금지
172+
> > 협업 중인 브랜치에서 rebase는 충돌 및 이력 꼬임 위험
15173
16-
이렇게 하면 feature/login 브랜치의 커밋들은 **develop 브랜치의 최신 커밋 뒤에 붙게 됩니다.**
17174

18-
## 설명
19-
- Rebase는 브랜치의 base(기준점)를 다른 브랜치로 옮기는 Git 명령어입니다.
20-
- 현재 브랜치의 커밋들을 잠시 보류하고,
21-
목표 브랜치(develop)의 최신 커밋을 가져온 후,
22-
보류했던 커밋들을 목표 브랜치 위에 다시 적용합니다.
23-
- 결과적으로 현재 브랜치의 커밋 히스토리가 목표 브랜치(develop) 브랜치 위에 쌓이게 됩니다.
24175

25-
## 장점
26-
- 깔끔한 커밋 히스토리: develop 브랜치와 현재 브랜치의 변경 사항을 선형적인 커밋 히스토리로 관리할 수 있습니다.
27-
- 쉬운 병합: Rebase를 통해 develop 브랜치와 현재 브랜치를 병합할 때 충돌 가능성을 줄일 수 있습니다.
28-
- 의미 있는 커밋 기록 유지: Rebase를 통해 불필요한 병합 커밋 없이, 각 브랜치의 의미 있는 작업 내용을 명확하게 기록할 수 있습니다.
29176

30-
## 주의사항
31-
- Rebase는 로컬 저장소의 커밋 기록을 변경하므로,
32-
이미 원격 저장소에 push된 커밋에 대해서는 Rebase를 진행하지 않는 것이 좋습니다.
33-
- 만약 원격 저장소에 push된 커밋에 대해 Rebase를 진행해야 할 경우,
34-
`git push --force` 명령어를 사용하여 강제로 push해야 하지만,
35-
이 경우 다른 협업 개발자들에게 문제가 발생할 수 있으므로 주의해야 합니다.
36-
**강제 푸시 전에는 반드시 팀원과 충분히 소통하세요.**
37-
- Rebase 도중 충돌이 발생하면,
38-
충돌을 해결하고 `git rebase --continue` 명령어를 사용하여 Rebase를 계속 진행해야 합니다.
39177

0 commit comments

Comments
 (0)