红联Linux门户
Linux帮助

Git使用小记

发布时间:2014-12-21 15:18:18来源:linux网站作者:u012457196

前言:

我们写代码写完后总要进行管理,以前写的很多代码虽然写的不是很好,但因为没有一个比较好的代码管理习惯,所以很多都遗失掉了,为此现在都还觉得很可惜,近来在学习使用git来进行代码管理,git是一个很强大的分布式版本控制系统。


(1)远程仓库操作命令

从远程仓库克隆仓库到本地:$ git clone git://github.com/******.git

查看远程仓库别名以及地址:$ git remote -v

添加远程仓库:$ git remote add [name] [url]

删除远程仓库:$ git remote rm [name]

修改远程仓库:$ git remote set-url --push [name] [newUrl]

拉取远程仓库:$ git pull [remoteName] [localBranchName]

推送远程仓库:$ git push [remoteName] [localBranchName]

提交本地test分支作为远程的master分支:$git push origin test:master

提交本地test分支作为远程的test分支:$git push origin test:test


(2)分支操作命令--branch

查看远程和本地所有分支:$ git branch -a

创建本地分支:$ git branch [name]

切换分支:$ git checkout [name]

创建新分支并且切换到新的分支:$ git check -b [name]

复制远程的分支并且以此来创建新分支:$ git check -t /remotes/origin/branch1  //这样就能在本地创建一个复制来自远程branch1分支

删除分支:$ git branch -d [name]  //-d选项只能删除已经参与了合并的分支,对于未有合并的分支是无法删除的。如果想强制删除一个分支,可以使用-D选项

合并分支:$git merge [name]  //将名称为[name]的分支与当前的分支合并

创建远程分支:(本地分支push到远程):$ git push origin [name]

删除远程分支:$ git push origin :heads/[name] 或 $ git push origin :[name]


(3)版本(tag)操作相关命令

查看版本:$ git tag

创建版本:$ git tag [name]

删除版本:$ git tag -d [name]

查看远程版本:$ git tag -r

创建远程版本(本地版本push到远程):$ git push origin [name]

删除远程版本:$ git push origin :refs/tags/[name]

合并远程仓库的tag到本地:$ git pull origin --tags

上传本地tag到远程仓库:$ git push origin --tags

创建带注释的tag:$ git tag -a [name] -m 'yourMessage'


(4) 子模块(submodule)相关操作命令

添加子模块:$ git submodule add [url] [path]

如:$git submodule add git://github.com/soberh/ui-libs.git src/main/webapp/ui-libs

初始化子模块:$ git submodule init ----只在首次检出仓库时运行一次就行

更新子模块:$ git submodule update ----每次更新或切换分支后都需要运行一下

删除子模块:(分4步走哦)

1) $ git rm --cached [path]

2) 编辑“.gitmodules”文件,将子模块的相关配置节点删除掉

3) 编辑“ .git/config”文件,将子模块的相关配置节点删除掉

4) 手动删除子模块残留的目录

添加子模块:$ git submodule add [url] [path]

如:$git submodule add git://github.com/soberh/ui-libs.git src/main/webapp/ui-libs

初始化子模块:$ git submodule init  ----只在首次检出仓库时运行一次就行

更新子模块:$ git submodule update ----每次更新或切换分支后都需要运行一下

删除子模块:(分4步走哦)

1) $ git rm --cached [path]

2) 编辑“.gitmodules”文件,将子模块的相关配置节点删除掉

3) 编辑“ .git/config”文件,将子模块的相关配置节点删除掉

4) 手动删除子模块残留的目录


(5)忽略一些文件、文件夹不提交

在仓库根目录下创建名称为“.gitignore”的文件,写入不需要的文件夹名或文件,每个元素占一行即可,如

target

bin

*.db


(6)删除缓存区的文件

不怎么进行删除操作,所以就常用这一个命令:$ git rm -r --cached .

一般的代码管理流程:

(1)远程已经建完仓库后直接克隆到本地: $ git clone [仓库地址]

(2)查看本地和远程的branch:$ git branch -a

(3)如果远程的branch更新了的话运行:$ git fetch -p      //这样会将远程的分支列表重新拉取

(3)将远程的branch复制到本地并且切换到这个分支下面:$ git checkout -t [远程分支名字]

(4)这是看到自己已经在新建的branch下面了,然后看一下有没有文件。

(5)若没有的话试一下:$ git pull

(6)做完修改以后的话先add:$ git add .      //这样会将除了在.gitignore中写入的文件都加入进要提交的文件内

(7)然后进行提交到本地仓库:$ git commit - m "提交"

(8)可以查看状态:$ git status 或者 $git diff

(9)如果没什么问题的话就进行提交到远程库: $ git push    //如果加入-f的话是强制提交。