Ⅰ 用什么 git 命令可以取得指定的历史版本
git co xxxxxxx 就是你git log的时候,看到的hash,也就是某指定版本。
Ⅱ 如何将SVN的版本库通过git导出代码
其实,很多人都不care谁写了Git,只在乎它是免费而且好用的!So do I!下面开始我们的学习:1.Git安装(略)。2.创建版本库首先,选择一个合适的地方(我选择了D盘,我的电脑是Win 7),常见一个空目录:$ mkdir Git$ cd Git$ pwd//显示当前的路径/d/Git注:Windows下,路径名不要包含中文,因为Git对中文支持不给力!第二步,通过git init命令把这个目录变成Git可以管理的仓库:12$ git initInitialized empty Git repository in /d/Git/.git/这样就创建了你的Git仓库。接下来,我们上传一个文件到Git。编辑一个readme.txt文件,内容如下:Git is a distributed version control system.Git is free software distributed under the GPL.Git has a mutable index called stage.Git tracks changes of files.将其放到/d/Git目录下,因为这是一个Git仓库,放到其他地方Git再厉害也找不到这个文件。将一个文件放到Git仓库需要两步:(1)使用git add将文件添加到仓库:1$ git add readme.txt(2)使用git commit将文件提交到仓库:git commit -m "wrote a readme file"[master 48b9a84] wrote a readme file1 file changed, 2 insertions(+)注:git commit命令,-m后面输入的是本次提交的说明,可以输入任意内容,当然最好是有意义的,这样你就能从历史记录里方便地找到改动记录。commit可以一次提交多个文件:$ git add file1.txt$ git add file2.txt$ git add file3.txt$ git commit -m "add 3 files."3.Git的命令很多,下面再学习几个吧!继续修改readme.txt文件:Git is a distributed version control system.Git is free software.git status命令看看结果:$ git status# On branch master# Changes not staged for commit:# (use "git add <file>…" to update what will be committed)# (use "git checkout — <file>…" to discard changes in working directory)## modified: readme.txt#no changes added to commit (use "git add" and/or "git commit -a")git status查看仓库当前的状态,上面的命令告诉我们,readme.txt被修改过了,但还没有准备提交的修改。虽然Git告诉我们readme.txt被修改了,但如果能看看具体修改了什么内容,自然是很好的。比如你休假两周从国外回来,第一天上班时,已经记不清上次怎么修改的readme.txt,所以,需要用git diff这个命令看看:123456789$ git diff readme.txtdiff –git a/readme.txt b/readme.txtindex 46d49bf..9247db6 100644— a/readme.txt+++ b/readme.txt@@ -1,2 +1,2 @@-Git is a version control system.+Git is a distributed version control system.Git is free software.git diff查看不同!在工作中,我们可能提交了几千个文件,如果想看历史记录,可以使用git log命令:123456789101112131415161718$ git logcommit Author: Michael Liao <[email protected]>Date: Tue Aug 20 15:11:49 2013 +0800append GPLcommit Author: Michael Liao <[email protected]>Date: Tue Aug 20 14:53:12 2013 +0800add distributedcommit Author: Michael Liao <[email protected]>Date: Mon Aug 19 17:51:55 2013 +0800wrote a readme file<br>………………………………………………………………………………<br>………………………………………………………………………………commit Author: lixiaolun <[email protected]qq.com>Date: Thu Jan 15 22:06:05 2015 +0800wrote a readme file(END)注:最后你可能会碰到这个(END),此后你怎么点都没有用。那么现在你要输入:wq或:q退出。这个命令同linux指令。git log命令显示从最近到最远的提交日志。如果嫌输出信息太多,看得眼花缭乱的,可以试试加上 –pretty=oneline参数:123456789101112131415$ git log –pretty=oneline commit a file readme text1.txt commit wrote a readme file 2015-1-30 upload local_gitgub remove text1.txt remove text.txt add test.txt git tracks changes add 3 text.txt understand how stage modify reamde.txt add a new word distr wrote a readme file友情提示:你看到的一大串类似3628164…882e1e0的是commit id(版本号),和SVN不一样,Git的commit id不是1,2,3……递增的数字,而是一个SHA1计算出来的一个非常大的数字,用十六进制表示。时光穿梭之版本回退!!如果你提交的一个文件,发现还不如你你上一个版本好,赶紧回退!怎么做呢?首先,Git必须知道当前版本是哪个版本,在Git中,用HEAD表示当前版本,也就是最新的提交3628164…882e1e0(注意我的提交ID和你的肯定不一样),上一个版本就是HEAD^,上上一个版本就是HEAD^^,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100。回退到上一个版本的命令git reset:1$ git reset –hard HEAD^–hard参数有啥意义?这个后面再讲,现在你先放心使用。查看文件命令cat readme.txt:123$ cat readme.txtGit is a distributed version control system.Git is free software distributed under the GPL.git reflog记录了每一次命令:$ git reflogea34578 [email protected]{0}: reset: moving to HEAD^3628164 [email protected]{1}: commit: append GPLea34578 [email protected]{2}: commit: add distributedcb926e7 [email protected]{3}: commit (initial): wrote a readme file前面的数字是commit id。知道commit id可以回退上一次执行的命令,回退命令为git reset –hard <commit id>:1$ git reset –hard 3628164
Ⅲ 怎么从git导出某个分支的android代码
git status 看一下有没有红色的文件如果master分支上的修改不会覆盖你develop的修改,是允许切换的,这时候修改不会丢,反之不能切换。既然切换成功了,你要么是:你用命令强制切换,修改玩完,节哀吧。如果是eclipse开发的,试试在local history里头找找吧你根据提示提交了,但你忘记了
Ⅳ linux git 怎样退回到指定版本
无论windows还是linux或其他操来作系自统,git版本管理的操作命令都是一致的,没有任何区别。退回到指定版本可使用revert反转提交命令,git revert用一个新提交来消除一个历史提交所做的任何修改。revert 之后你的本地代码会回滚到指定的历史版本,这时你再 git push 既可以把线上的代码更新。
Ⅳ 怎么使用repo或git工具将本地代码回退到历史的某一个版本。
那些xml文件是分支配置的文件,使用的话直接init 后再sync就可以了repo init git地址 -b 分支名 -m xml文件名repo sync如果要将本地代码回版到某权个历史版本直接checkout 或者 resetcheckout 支持将文件切换到历史版本,数据库不会修改,还可以回到你最新的状态reset 是直接回退带指定版本,它有两种模式 一种是只将所有提交回退,修改还在,还有一种模式是完全回退,修改直接就没了。repo forall -c git chekout 指定节点的哈希值repo forall -c git reset 指定节点的哈希值repo forall -c git reset 指定节点的哈希值 –hard (此操作会回退掉指定节点之后的所有修改,如果回退出错 只能重新跟服务器同步了。)希望我的回答能帮助你
Ⅵ 有没有方法可以从git远程版本库里直接下指定版本的一个文件
你pull的时候,后面直接带hash版本就是。不能只下载一个文件。如果是github,你不如直接上去下载那个文件的raw格式。
Ⅶ git如何更新到指定版本,然后再更新到最新版本
更新到指定版本git checkout <版本hash码>之后先切回当前分支git checkout <当前分支名>最后更新到最新版本git pull
Ⅷ Git工作流程和常用命令分享
git是一个分布式版本控制软件,最初由林纳斯·托瓦兹创作,于2005年以GPL发布。最初目的是为更好地管理Linux内核开发而设计。林纳斯·托瓦兹在编写第一个版本时就使用了“git”这个名称, 他将工具描述为“愚蠢的内容跟踪器”。
[图片上传失败…(image-c23291-1619063471664)]
四个专有名词:
Workspace:工作区
Index / Stage:暂存区
Repository:仓库区(或本地仓库)
Remote:远程仓库
打开本地生成的.git隐藏文件
创建新项目gittest
创建新文件test.txt
git add <file>
git status显示有变更的文件
git restore <file> 撤回文件修改内容
git commit –m “注释”
修改内容-> 执行git diff工作区和本地仓库的差异
git log显示当前分支的版本历史
git reset –hard HEAD^ 当前版本回退到上一个版本
git reset –hard HEAD^ ^ 当前版本回退到上上一个版本
git reset –hard HEAD~100 回退到前100个版本
恢复已经删除的版本
git reflog 展示所有的提交记录
git reset –hard <版本号> 回退到指定版本
git push origin master 将本地master分支推送到远程master分支,相当于创建远程分支
git checkout -b dev = git branch dev + git checkout dev 创建并切换分支
git branch 不带参数,会列出所有本地的分支;带参数表示创建分支
git branch –d name 删除本地分支(-D表示强制删除)
git branch –r 不带参数,会列出所有远程的分支
git branch –set-upstream-to=origin/<branch本地> 本地和远程分支关联
git push origin –delete <branch> 删除远程分支
git merge release用于合并指定分支到当前分支上
注:Fast-forward表示的合并是“快进模式”,也就是直接把master指向dev的当前提交,所以合并速度非常快。在这种模式下,删除分支后,会丢掉分支日志信息。可以使用带参数 –no-ff来禁用”Fast forward”模式。
git merge –no-ff -m “注释”dev
git checkout release 切换release分支
vim test.txt 修改某条内容
git commit test.txt -m “release修改某条内容”
git checkout master 切换master分支
vim test.txt 修改某条同release内容
git commit test.txt -m “master修改某条内容”
git merge release 显示冲突
git status 显示冲突提示
Git用<<<<<<<,=======,>>>>>>>标记出不同分支的内容,其中>>>>release 是指release上修改的内容 vim test.txt 修改内容
git add test.txt
git commit -a -m “fix conflict”
当前分支有没有提交但也不合适现在就提交的内容,Git提供了暂储功能stash
git checkout release
vim test.txt 修改test.txt内容
git checkout develop 此时会提示Aborting
git status 查看当前状态
Git stash list 查看所有暂储列表
git stash apply恢复,恢复后stash内容并不删除,你需要使用命令git stash drop来删除; 另一种方式是使用git stash pop,恢复的同时把stash内容也删除了
创建Git Tag并推送远程服务器
git tag -a V1.0.0 –m“注释” //创建TAG
git push origin V1.0.0 //推送到远程服务器
git push origin –tag //提交所有tag至服务器
git tag -d V1.0.0 //删除本地标签
git push origin –delete tag <tagname> //删除远程标签
HEAD,它始终指向当前所处分支的最新的提交点。你所处的分支变化了,或者产生了新的提交点,HEAD就会跟着改变
add相关命令很简单,主要实现将工作区修改的内容提交到暂存区,交由git管理。
git add .添加当前目录的所有文件到暂存区
git add 添加指定目录到暂存区,包括子目录
git add 添加指定文件到暂存区
commit相关命令也很简单,主要实现将暂存区的内容提交到本地仓库,并使得当前分支的HEAD向后移动一个提交点。
git commit -m 提交暂存区到本地仓库,message代表说明信息
git commit –amend -m 使用一次新的commit,替代上一次提交
上传本地仓库分支到远程仓库分支,实现同步。
git push 上传本地指定分支到远程仓库
git push –force强行推送当前分支到远程仓库,即使有冲突
git push –all推送所有分支到远程仓库
关于分支,大概有展示分支,切换分支,创建分支,删除分支这四种操作。
git branch列出所有本地分支
git branch -r列出所有远程分支
git branch -a列出所有本地分支和远程分支
git branch 新建一个分支,但依然停留在当前分支
git checkout -b 新建一个分支,并切换到该分支
git checkout 切换到指定分支,并更新工作区
git branch -d 删除分支
git push origin –delete 删除远程分支
关于分支的操作虽然比较多,但都比较简单好记
merge命令把不同的分支合并起来。在实际开放中,我们可能从master分支中切出一个分支,然后进行开发完成需求,中间经过R3,R4,R5的commit记录,最后开发完成需要合入master中,这便用到了merge。
git merge 合并指定分支到当前分支
注:如果在merge之后,出现conflict,主要是因为两个用户修改了同一文件的同一块区域。需要针对冲突情况,手动解除冲突。
rebase又称为衍合,是合并的另外一种选择。
在开始阶段,我们处于new分支上,执行git rebase dev,那么new分支上新的commit都在dev分支上重演一遍,最后checkout切换回到new分支。这一点与merge是一样的,合并前后所处的分支并没有改变。
git rebase dev,通俗的解释就是new分支想站在dev的肩膀上继续下去。
rebase操作不会生成新的节点,是将两个分支融合成一个线性的提交。
rebase也需要手动解决冲突。
1.如果你想要一个干净的,没有merge commit的线性历史树,那么你应该选择git rebase
2.如果你想保留完整的历史记录,并且想要避免重写commit history的风险,你应该选择使用git merge
reset命令把当前分支指向另一个位置,并且相应的变动工作区和暂存区。
git reset —soft 只改变提交点,暂存区和工作目录的内容都不改变
git reset —mixed 改变提交点,同时改变暂存区的内容
git reset —hard 暂存区、工作区的内容都会被修改到与提交点完全一致的状态
git revert用一个新提交来消除一个历史提交所做的任何修改。
在回滚这一操作上看,效果差不多。git revert是用一次新的commit来回滚之前的commit,git reset是直接删除指定的commit。
在 Git工作区的根目录创建一个特殊的.gitignore文件。
在.gitignore文件中,添加需要忽略的文件。
git rm -r –cached . //将仓库中的index递归删除
git add . //重新添加仓库索引
git commit -m “update git.ignore” //提交
git branch –set-upstream-to=origin/<branch> <branch> //重现将本地仓库和远程仓库关联
最后,如果此篇博文对你有所帮助,别忘了点个赞哟~
Ⅸ git如何更新到指定版本,然后再更新到最新版本
更新到指定版本git checkout <版本hash码>之后先切回当前分支git checkout <当前分支名>最后更新到最新版本git pull