玩转git@Ku_xiao航

首先进入一个文件夹之后,使用这个命令是先初始化一个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里面的id_rsa.pub里面的内容复制到sshkey的值里面 只是使用ssh上传仓库的必备条件

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

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

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

克隆到本地

然后修改里面文件之后,可以
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  [email protected]:michaelliao/learngit.git (fetch)
origin  [email protected]:michaelliao/learngit.git (push)

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

推送分支

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

$ git push origin master

抓取分支

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

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

$ git clone [email protected]: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

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

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 [email protected]:michaelliao/learngit.git
fc38031..291bea8 dev -> dev

————————————————
版权声明:本文为CSDN博主「TongQiHang」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/kukuhang/article/details/102545579

你可能感兴趣的:(玩转git@Ku_xiao航)