forked from c2y2/git-command
-
Notifications
You must be signed in to change notification settings - Fork 0
/
常用的命令.txt
104 lines (82 loc) · 3.82 KB
/
常用的命令.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
$ git status //查看当前项目下所有文的状态,如果第一次,你会发现都红颜色的,因为它还没有交给git/github管理。
$ git add . //(.)点表示当前目录下的所有内容,交给git管理,也就是提交到了git的本地仓库。
Ps:git的强大之处就是有一个本地仓库的概念,在没有网络的情况下可以先将更新的内容提交到本地仓库。
$ git commit –m”new natter ” //对你更新或修改了哪些内容做一个描述。
$ git remote add origin [email protected]:defnngj/hibernate-demo.git
//如果你是第一次提交项目,这一句非常重要,这是你本地的当前的项目与远程的哪个仓库建立连接。
Ps: origin可以改为别人的名字,但是在你下一次push(提交)时,也要用你修改之后的名字。
$ git remote -v //查看你当前项目远程连接的是哪个仓库地址。
$ git push -u origin master //将本地的项目提交到远程仓库中。
如果你是第一次想把github上面的项目克隆到本地或者要克隆别人的项目到地。
$ git clone [email protected]:defnngj/hibernate-demo.git //在git下面切换到想存放此项目的文件目录下,运行这条命令就可以将项目克隆下来。
假如本地已经存在了这个项目,而仓库中又有一新的更新,如何把更的合并到本地的项目中?
$ git fetch origin //取得远程更新,这里可以看做是准备要取了
$ git merge origin/master //把更新的内容合并到本地分支/master
$ git rm aaa.java //移除我们删除的那个文件,不然git不允许我们往远程仓库提交。
$ git rm bbb/ -r // -r 会把bbb/目录下的所有内容一次性移除。
5 继续
1. .gitIgnore 文件忽略哪些不被Git跟踪的文件
在根目录下生成 .gitignore 文件,
例子1:
# Can ignore specific files
.DS_Store
# Use wildcards as well
*~
*.swp
# Can also ignore all directories and files in a directory.
tmp/**/*
例子2:
# Ignore all dotfiles...
.*
# except for .gitignore
!.gitignore
2. 使用GitHub进行多人协同开发
GitHub上大的项目如Ruby有多个Branch
(0) 克隆GitHub项目
git clone git://github.com/xxx/xxx.git
(1) 分支的创建和合并
# git branch local
# git checkout local 切换到local
# ... 开发local分支
与master分支合并
# git checkout master
# git merge local
# git branch -d local 合并完后删除local
(2) 最佳方式的GitHub多人协作,每个人建立自己分支
假定有项目创建者A (主力开发者和代码合并)和其他开发者B, C , D, E ...
创建者A将其他开发者加到项目的Collaborator里 ,如下图所示(项目Admin菜单)
其他开发者B, C , D, E...,配置好Git和GitHub的证书:
# git clone [email protected]: xxx/xxx.git ( private 链接)
# git pull 从服务器更新
# git log 查看其他成员更新日志
其他开发者建议在开发时建立自己的分支,不要在master上整了
B开发者(当然主力开发者也适用)
# git branch dev-b
# git checkout dev-b
.... 开发
将分支push到github
# git push origin dev-b (如果不通过github,通过自己机器上的路径也可以)
主开发者A
# git pull origin dev-b 即可合并其他开发者的Branch
为了保险起见,主开发者可以在新的Branch中测试B的开发成果,测试稳定后再合并进Master
# git branch newexp
# git checkout newexp
# git pull origin dev-b
... (testing...)
....
# git checkout master
# git merge newexp
3. 建立自己的Git服务器进行多人协同开发
服务器server1:
# mkdir myproject.git
# cd myproject.git
# git --bare init --shared
开发者A 初始化服务器上项目
# cd myproject
# git push user@server1:myproject.git master
开发者N可获得初始项目文件
# git clone user@server1:myproject.git
改动
# git commit
# git pull
# git push