玩转Git@酷酷的小航航

首先进入一个文件夹之后,使用这个命令是先初始化一个git仓库

		git init  它会默认创建一个名为master的分支
		下面这个用于查看是否有修改的文件,如果有就会报红
		git status
		下面这个用于查看文件修改的细节
		git diff test.txt
		下面这个是提交到暂存区
		git add test.txt
		下面这个是提交修改,记住每操作一次都要进行add 和commit
		git commit -m "提交信息"
		以列表的形式展示所有分支
		git branch
		切换分支
		git checkout branchname 分支名称,用于切换分支
		发现每次切换分支,内部的仓库内容会随之发生改变
		用来查看历史提交,可以根据commit_id来回退到历史提交
		git log
		git reset --harh commit_id
		已经修改文件之后,但是还没有提交,可以通过下面命令回退
		git checkout -- test.txt
		若干修改文件之后,已经 add 了,那么可以先取消暂存 然后回退
		git reset HEAD test.txt
		git checkout -- test.txt
		负责直接回退到历史最近版本
		记住 git status 是用来查看暂存区的命令
		用它可以查看所有被修改的文件状态,如果为绿色则可以提交,红色需要先 add 再提交
		git rm test.txt 表示删除库中文件,需要commit完成命令

github远程仓库使用

如何链接远程仓库,并将自己的本地仓库上传到远程仓库管理

首先将本机的sshkey添加到github账号

ssh-keygen -t rsa -C "youremail@example.com"

将生成的.ssh里面的id_rsa.pub里面的内容复制到sshkey的值里面 只是使用ssh上传仓库的必备条件

然后新建一个github仓库,然后使用ssh的方式将本地仓库push到远程仓库

git remote add origin git@github.com:aeasringnar/newfile.git
注意如果这里初夏错误那么就git remote rm origin后重新上传
最后
git push -u origin master 将本地仓库直接push到远程仓库(这里是将master分支上传)

先创建远程仓库然后克隆到本地进行协作开发。

git clone git@github.com:aeasringnar/gitskills.git
克隆到本地
然后修改里面文件之后,可以
git add filename
git commit -m "描述"
git push -u origin master 推送修改到远程仓库

分支的合并,有一种情况会发生冲突,当每个分支都有自己的提交的时候就会产生冲突,需要手动修改这些冲突之后再次提交即可,

注意:不产生冲突的合并,不需要提交,直接删除无用分支即可

回到主分支后的,合并命令
git merge (branchname)
如果有冲突,手动将冲突的地方修改之后再次提交,
git add test.txt 
git commit -m "conflict fixed"
git log --graph --pretty=oneline --abbrev-commit这个可以查看分支的合并情况
git log --graph 查看分支合并图
最后,删除无用的分支
git branch -d newtest

git merge --no-ff -m "merge with no-ff" branchname 实际开发中的合并

在实际开发中,我们应该按照几个基本原则进行分支管理:

首先,master分支应该是非常稳定的,也就是仅用来发布新版本,平时不能在上面干活;

那在哪干活呢?干活都在dev分支上,也就是说,dev分支是不稳定的,到某个时候,比如1.0版本发布时,再把dev分支合并到master上,在master分支发布1.0版本;

你和你的小伙伴们每个人都在dev分支上干活,每个人都有自己的分支,时不时地往dev分支上合并就可以了。

合并分支时,加上–no-ff参数就可以用普通模式合并,合并后的历史有分支,能看出来曾经做过合并,而fast forward合并就看不出来曾经做过合并。

多人协作

工作中,首先建立一个空的远程仓库,然后将本地的仓库全部上传到远程仓库,注意将主要分支和开发分支全部上传。

当你从远程仓库克隆时,实际上Git自动把本地的master分支和远程的master分支对应起来了,并且,远程仓库的默认名称是origin。

要查看远程库的信息,用git remote:

$ git remote
origin

或者,用git remote -v显示更详细的信息:

	$ git remote -v
	origin  git@github.com:michaelliao/learngit.git (fetch)
	origin  git@github.com:michaelliao/learngit.git (push)

上面显示了可以抓取和推送的origin的地址。如果没有推送权限,就看不到push的地址。

推送分支

推送分支,就是把该分支上的所有本地提交推送到远程库。推送时,要指定本地分支,这样,Git就会把该分支推送到远程库对应的远程分支上:

$ git push origin master

抓取分支

多人协作时,大家都会往master和dev分支上推送各自的修改。

现在,模拟一个你的小伙伴,可以在另一台电脑(注意要把SSH Key添加到GitHub)或者同一台电脑的另一个目录下克隆:

	$ git clone git@github.com:michaelliao/learngit.git
	Cloning into 'learngit'...
	remote: Counting objects: 46, done.
	remote: Compressing objects: 100% (26/26), done.
	remote: Total 46 (delta 16), reused 45 (delta 15)
	Receiving objects: 100% (46/46), 15.69 KiB | 6 KiB/s, done.
	Resolving deltas: 100% (16/16), done.

当你的小伙伴从远程库clone时,默认情况下,你的小伙伴只能看到本地的master分支。不信可以用git branch命令看看:

	$ git branch
  • master

    现在,你的小伙伴要在dev分支上开发,就必须创建远程origin的dev分支到本地,于是他用这个命令创建本地dev分支:

      	$ git checkout -b dev origin/dev
    

现在,他就可以在dev上继续修改,然后,时不时地把dev分支push到远程:

$ git commit -m "add /usr/bin/env"
[dev 291bea8] add /usr/bin/env
 1 file changed, 1 insertion(+)
$ git push origin dev
Counting objects: 5, done.
Delta compression using up to 4 threads.
Compressing objects: 100% (2/2), done.
Writing objects: 100% (3/3), 349 bytes, done.
Total 3 (delta 0), reused 0 (delta 0)
To git@github.com:michaelliao/learngit.git
   fc38031..291bea8  dev -> dev

原文链接转载于haeasringnar

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值