在Linux系统上,使用git提交代码~~
2016-09-25 19:30
274 查看
$mkdirlearngit
$cdlearngit
$pwd
初始化一个Git仓库
gitinit,把这个目录变成Git可以管理的仓库(目录下多了一个.git的目录ls-a)
添加文件到Git仓库:
gitadd把文件添加到仓库
gitcommit-m"xxx"文件提交到仓库
gitstatus工作区的状态,让我们时刻掌握仓库当前的状态
gitdiff查看修改内容
版本回退
gitlog(--pretty=online)查看提交历史,显示从最近到最远的提交日志,以便确定要回退到哪个版本。
用HEAD表示当前版本,也就是最新的提交3628164...882e1e0,上一个版本就是HEAD^,上上一个版本就是HEAD^^,当然
往上100个版本写100个^比较容易数不过来,所以写成HEAD~100
gitreset--hardHEAD^回退到上一个版本
gitreset--hard(3628164)指定回到某个版本(版本号没必要写全,前几位就可以了,Git会自动去找。
当然也不能只写前一两位)
gitreflog查看命令历史,以便确定要回到未来的哪个版本。
工作区和暂存区
工作区(WorkingDirectory)
暂存区(stage或index)
版本库(Repository)工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库
前面讲了我们把文件往Git版本库里添加的时候,是分两步执行的:
第一步是用gitadd把文件添加进去,实际上就是把文件修改添加到暂存区;
第二步是用gitcommit提交更改,实际上就是把暂存区的所有内容提交到当前分支。
gitdiffHEAD--readme.txt查看工作区和版本库里面最新版本的区别
撤销修改
gitcheckout--readme.txt当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时
当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改
第一步:gitresetHEADreadme.txt把暂存区的修改回退到工作区
第二部:gitcheckout--readme.txt
提交分支错误,复制分支:
删除文件
一、rm只删除工作区信息;使用gitcheckout--file即可恢复;
二、gitrm删除工作区和stage信息;
1、使用gitresetHEAD--file即可恢复;
2、恢复步骤:
1)先使用gitresetHeAD--file从master中把已删除信息copy到到stage区;
2)再使用gitcheckout--file从stage区把已删除信息copy到工作区。over!!!
3)这时你就看到删除的文件又回来啦。啦啦
三、gitcommit-m“file”删除工作区,stage和master信息;
1、使用gitreset--hardHEAD^即可恢复。
2、恢复步骤:1)先使用gitreset--hardHEAD^从master回收处恢复到master中;2)再使用gitresetHeAD--file从
master中把已删除信息copy到到stage区;
3)最后,使用gitcheckout--file从stage区把已删除信息copy到工作区
4)这时你就看到删除的文件又回来啦。啦啦啦!
远程仓库
1.注册一个GitHub账号,就可以免费获得Git远程仓库。
2.本地Git仓库和GitHub仓库之间的传输是通过SSH加密的
1)建SSHKey。在用户主目录下,看看有没有.ssh目录,如果有,再看看这个目录下有没有
2)登陆GitHub,打开“Accountsettings”,“SSHKeys”页面:点“AddSSHKey”,填上任意Title,在Key文本框里粘贴
添加远程库:
点击按钮createanewrepository创建一个新的仓库
关联一个远程库
由于远程库是空的,我们第一次推送
从远程库克隆:
gitclonegit@github.com:jialechun/learngit1.git
分支管理
查看分支:
创建分支:
切换分支:
创建+切换分支:
合并某分支到当前分支:
删除分支:
[/b]
[code]gitstashapplystash@{0}多次stash,切回分支指定恢复修改的内容,stash内容不删除
查看远程库信息,使用
本地新建的分支如果不推送到远程,对其他人就是不可见的;
从本地推送分支,使用
在本地创建和远程分支对应的分支,使用
建立本地分支和远程分支的关联,使用
从远程抓取分支,使用
创建标签
命令
gittagv0.96224937找到历史提交的commitid新建一个标签
命令
gittag-r查看远程标签
命令
$gitpullorigin--tags合并远程仓库的tag到本地:
命令
命令
标签已经推送到远程,先从本地删除,从远程删除:
命令
命令
配置别名
gitconfig--globalalias.ststatus
gitconfig--globalalias.cocheckout
gitconfig--globalalias.cicommit
gitconfig--globalalias.brbranch
每个仓库的Git配置文件都放在
[core]
repositoryformatversion=0
filemode=truebare=false
logallrefupdates=trueignorecase=true
precomposeunicode=true
[remote"origin"]
url=git@github.com:michaelliao/learngit.git
fetch=+refs/heads/*:refs/remotes/origin/*
[branch"master"]
remote=origin
merge=refs/heads/master[alias]last=log-1
co=checkout
ci=commitbr=branch
st=status
[user]
name=YourName
email=your@email.com
gitrebasehea~1
gitfetch:相当于是从远程获取最新版本到本地,不会自动merge
gitpull:相当于是从远程获取最新版本并merge到本地,相当于gitfetch和gitmerge
$cdlearngit
$pwd
初始化一个Git仓库
gitinit,把这个目录变成Git可以管理的仓库(目录下多了一个.git的目录ls-a)
添加文件到Git仓库:
gitadd把文件添加到仓库
gitcommit-m"xxx"文件提交到仓库
gitstatus工作区的状态,让我们时刻掌握仓库当前的状态
gitdiff查看修改内容
版本回退
gitlog(--pretty=online)查看提交历史,显示从最近到最远的提交日志,以便确定要回退到哪个版本。
用HEAD表示当前版本,也就是最新的提交3628164...882e1e0,上一个版本就是HEAD^,上上一个版本就是HEAD^^,当然
往上100个版本写100个^比较容易数不过来,所以写成HEAD~100
gitreset--hardHEAD^回退到上一个版本
gitreset--hard(3628164)指定回到某个版本(版本号没必要写全,前几位就可以了,Git会自动去找。
当然也不能只写前一两位)
gitreflog查看命令历史,以便确定要回到未来的哪个版本。
工作区和暂存区
工作区(WorkingDirectory)
暂存区(stage或index)
版本库(Repository)工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库
前面讲了我们把文件往Git版本库里添加的时候,是分两步执行的:
第一步是用gitadd把文件添加进去,实际上就是把文件修改添加到暂存区;
第二步是用gitcommit提交更改,实际上就是把暂存区的所有内容提交到当前分支。
gitdiffHEAD--readme.txt查看工作区和版本库里面最新版本的区别
撤销修改
gitcheckout--readme.txt当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时
当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改
第一步:gitresetHEADreadme.txt把暂存区的修改回退到工作区
第二部:gitcheckout--readme.txt
提交分支错误,复制分支:
删除文件
一、rm只删除工作区信息;使用gitcheckout--file即可恢复;
二、gitrm删除工作区和stage信息;
1、使用gitresetHEAD--file即可恢复;
2、恢复步骤:
1)先使用gitresetHeAD--file从master中把已删除信息copy到到stage区;
2)再使用gitcheckout--file从stage区把已删除信息copy到工作区。over!!!
3)这时你就看到删除的文件又回来啦。啦啦
三、gitcommit-m“file”删除工作区,stage和master信息;
1、使用gitreset--hardHEAD^即可恢复。
2、恢复步骤:1)先使用gitreset--hardHEAD^从master回收处恢复到master中;2)再使用gitresetHeAD--file从
master中把已删除信息copy到到stage区;
3)最后,使用gitcheckout--file从stage区把已删除信息copy到工作区
4)这时你就看到删除的文件又回来啦。啦啦啦!
远程仓库
1.注册一个GitHub账号,就可以免费获得Git远程仓库。
2.本地Git仓库和GitHub仓库之间的传输是通过SSH加密的
1)建SSHKey。在用户主目录下,看看有没有.ssh目录,如果有,再看看这个目录下有没有
id_rsa和
id_rsa.pub这两个文件,如果没有,创建sshkey:
$ssh-keygen-trsa-C"youremail@example.com"
2)登陆GitHub,打开“Accountsettings”,“SSHKeys”页面:点“AddSSHKey”,填上任意Title,在Key文本框里粘贴
id_rsa.pub文件的内容:
添加远程库:
点击按钮createanewrepository创建一个新的仓库
关联一个远程库
,把本地仓库的内容推送到GitHub仓库
$gitremoteaddorigingit@github.com:michaelliao/learngit.git
把本地库的所有内容推送到远程库上
$gitpush-uoriginmaster
由于远程库是空的,我们第一次推送
master分支时,加上了
-u参数,Git不但会把本地的
master分支内容推送的远程新的
master分支,还会把本地的
master分支和远程的
master分支关联起来,在以后的推送或者拉取时就可以简化命令。
从远程库克隆:
gitclonegit@github.com:jialechun/learngit1.git
分支管理
查看分支:
gitbranch
创建分支:
gitbranch<name>
切换分支:
gitcheckout<name>
创建+切换分支:
gitcheckout-b<name>
合并某分支到当前分支:
gitmerge<name>
gitmerge--no-ff-m"mergedbugfix101"issue-101
删除分支:
gitbranch-d<name>
看到分支合并图
[b]:gitlog--graph
[/b]
gitstash切换分支前把修改的内容存在某个地方
gitstashlist查看存储的内容
gitstashapply切回分支恢复修改的内容,stash内容不删 除
[code]gitstashapplystash@{0}多次stash,切回分支指定恢复修改的内容,stash内容不删除
gitstashpop恢复同时stash的内容也删除
gitbranch-D<name>强行删除。要丢弃一个没有被合并过的分支
查看远程库信息,使用
gitremote-v;
本地新建的分支如果不推送到远程,对其他人就是不可见的;
从本地推送分支,使用
gitpushoriginbranch-name,如果推送失败,先用
gitpull抓取远程的新提交;
在本地创建和远程分支对应的分支,使用
gitcheckout-bbranch-nameorigin/branch-name,本地和远程分支的名称最好一致;
建立本地分支和远程分支的关联,使用
gitbranch--set-upstreambranch-nameorigin/branch-name;
从远程抓取分支,使用
gitpull,如果有冲突,要先处理冲突。
创建标签
命令
gittagv1.0用于新建一个标签,默认为
HEAD,也可以指定一个commitid;
gittagv0.96224937找到历史提交的commitid新建一个标签
gittag-av0.1-m"说明文字"可以指定标签信息;
gittag-s<tagname>-m"blablabla..."可以用PGP签名标签;
命令
gittag可以查看所有标签。
gittag-r查看远程标签
命令
gitshowv0.9可以看到说明文字
$gitpullorigin--tags合并远程仓库的tag到本地:
命令
gitpushorigin<tagname>可以推送一个本地标签;
命令
gitpushorigin--tags可以推送全部未推送过的本地标签;
标签已经推送到远程,先从本地删除,从远程删除:
命令
gittag-d<tagname>可以删除一个本地标签;
命令
gitpushorigin:refs/tags/<tagname>可以删除一个远程标签。
配置别名
gitconfig--globalalias.ststatus
gitconfig--globalalias.cocheckout
gitconfig--globalalias.cicommit
gitconfig--globalalias.brbranch
每个仓库的Git配置文件都放在
.git/config文件中
[core]
repositoryformatversion=0
filemode=truebare=false
logallrefupdates=trueignorecase=true
precomposeunicode=true
[remote"origin"]
url=git@github.com:michaelliao/learngit.git
fetch=+refs/heads/*:refs/remotes/origin/*
[branch"master"]
remote=origin
merge=refs/heads/master[alias]last=log-1
co=checkout
ci=commitbr=branch
st=status
[user]
name=YourName
email=your@email.com
gitrebasehea~1
gitfetch:相当于是从远程获取最新版本到本地,不会自动merge
gitpull:相当于是从远程获取最新版本并merge到本地,相当于gitfetch和gitmerge
相关文章推荐
- ubuntu16系统中pycharm下使用git将代码提交到github仓库
- ubuntu16系统中pycharm下使用git将代码提交到github仓库
- git+github创建分支&提交并贡献代码(linux环境)
- 开始使用Git工具进行代码管理--记在CSDN空间提交项目的开始
- 使用 Python 获取 Linux 系统信息的代码
- 使用 Python 获取 Linux 系统信息的代码
- Ubuntu下使用git提交代码至GitHub
- 使用Git进行版本控制:(2)在OS X系统上开始使用Git代码仓储
- git使用补丁方式进行软件代码提交
- Linux 命令行git提交代码到github基本步骤
- 第一次使用GIT,创建仓库并提交项目代码
- git使用补丁方式进行软件代码提交
- Git使用教程(一)——Git提交代码到远程服务器
- 一、git工具使用手册--提交代码
- Git使用、Git配置、Git提交代码、Git上传
- Git使用SSH提交代码到服务器出现 permission denied (publickey).
- Java代码在Window或Linux系统下使用通用分割符来分割路径
- linux下git使用记录1 git 提交
- 如何使用git工具向github提交代码
- Linux内核分析:使用库函数API和C代码中嵌入汇编代码两种方式使用同一个系统调用