-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathnotes.txt
162 lines (90 loc) · 5.31 KB
/
notes.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
一.创建版本库
①初始化一个Git仓库:git init
②添加文件到Git仓库:1.git add<file> ; 2.git commit
二.时光机穿梭
①查看工作区状态,文件是否被修改过:git status
②查看修改的内容:git diff
1.版本回退
①HEAD:当前版本
②HEAD^:上个版本
③定位版本:git reset --hard commit_id
④git log:穿梭前,用git log可以查看提交历史,以便确定要回退到哪个版本
⑤git reflog:要重返未来,用git reflog查看命令历史,以便确定要回到未来的哪个版本。
2.工作区和暂存区
①工作区:就是你在电脑里能看到的目录,比如我的learngit文件夹就是一个工作区
②版本库:工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库。
③暂存区:Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区。
第一步是用git add把文件添加进去,实际上就是把文件修改添加到暂存区;
第二步是用git commit提交更改,实际上就是把暂存区的所有内容提交到当前分支。
3.管理修改
①每次修改,如果不add到暂存区,就不会加入到commit中
4.撤销修改
①git checkout -- file:丢弃工作区的修改
②git reset HEAD file:把暂存区的修改撤销掉,重新放回工作区
5.删除文件
①git rm:从版本库中删除文件
三.远程仓库
1.添加远程库
①关联一个远程库:git remote add origin git@server-name:path/repo-name.git
②关联后第一次推送master分支的所有内容:git push -u origin master
③此后,每次本地提交后,只要有必要,就可以使用命令git push origin master推送最新修改
ps:由于远程库是空的,我们第一次推送master分支时,加上了-u参数,Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令。
2.从远程库克隆
①要克隆一个仓库,首先必须知道仓库的地址,然后使用git clone命令克隆
②Git支持多种协议,包括https,但通过ssh支持的原生git协议速度最快
四.分支管理
1.创建与合并分支
①查看分支:git branch
②创建分支:git branch<name>
③切换分支:git cheakout<name>
④创建+切换分支:git cheakout -b <name>
⑤合并某分支到当前分支:git merge<name>
⑥删除分支:git branch - d <name>
2.解决冲突
①查看分支合并图:git log -- graph
eg:git log --graph --pretty =oneline --abbrev -commit
3.分支管理策略
①合并分支时加--no-ff参数:普通模式合并,合并后的历史有分支,禁用fast forward
eg:git log --no-ff-m"merge with no--ff"dev
4.Bug分支
①git stash:把当前工作现场隐藏起来,去修复bug
②git stash pop:恢复工作现场同时删除stash内容
5.Feature分支
①开发一个新feature,最好新建一个分支;
②如果要丢弃一个没有被合并过的分支,可以通过git branch -D <name>强行删除
6.多人协作
①git remote -v:查看远程库信息
②git push origin branch-name:从本地推送分支
③git pull:推送失败时,抓取远程的新提交
④git checkout -b branch-name origin/branch-name:在本地创建和远程分支对应的分支(本地和远程分支的名称最好一致)
⑤git branch --set-upstream branch-name origin/branch-name:建立本地分支和远程分支的关联
五.标签管理
1.创建标签
①git tag <name>:新建一个标签(默认为HEAD,也可以指定commit id)
②git tag -a <tagname> -m "blablabla...":可以指定标签信息
③git tag -s <tagname> -m "blablabla...":可以用PGP签名信息
④git tag:查看所有标签
2.操作标签
①git push origin <tagname>:推送一个本地标签
②git push origin --tags:推送全部未推送过的本地标签
③git tag -d <tagname>:删除一个本地标签
④git push origin :refs/tags/<tagname>:删除一个远程标签
六.使用GitHub
①在GitHub上,可以任意Fork开源仓库;
②自己拥有Fork后的仓库的读写权限;
③可以推送pull request给官方仓库来贡献代码。
七.自定义Git
1.忽略特殊文件
①忽略某些文件时,需要编写.gitignore;
2.配置别名
①我们只需要敲一行命令,告诉Git,以后st就表示status:git config --global alias.st status
eg:
$ git config --global alias.co checkout
$ git config --global alias.ci commit
$ git config --global alias.br branch
$ git config --global alias.unstage 'reset HEAD'
$ git config --global alias.last 'log -1'
git config --global alias.lg "log --color --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit"
3.搭建Git服务器
GitHub就是一个免费托管开源代码的远程仓库。但是对于某些视源代码如生命的商业公司来说,既不想公开源代码,又舍不得给GitHub交保护费,那就只能自己搭建一台Git服务器作为私有仓库使用。
例如大众点评code.dianpingoa.com