分布式版本控制工具Git

一.开发中为什么需要Git

因为在多人开发中Git可以管理代码,而且每个人都可以从库里面下载代码进行修改,每个人上传和修改Git都会有记录,如果出现大错误,还可以回退到正常版本。

二.Git原理

我们首先 从代码库(Remote)下载代码到工作区(workspace),然后写代码,写好代码放到暂存区(index),觉得没问题了,就上传到本地库(Repository),本地库再上传到代码库(Remote)。

三. 基本操作

1.创建一个远端代码库(Remote),示例:在ubuntu上面创建远端代码库

随便创建一个文件夹,用于存放git管理的代码库

复制代码
sudo mkdir GitLib    //创建文件夹
​​​​​​​git init --bare      //创建裸代码库,创建完后,自动生成别名origin,后面用

2. 在工作区拉取远端代码库。

  • 本地端创建一个工作区的文件夹,进入Git Bash Here

  • 总共有四种协议(http,https,ssh,git)来和远端交互通,常用我们用ssh公钥进行git服务器交互就行。

    复制代码
    ssh-keygen -t rsa    //生成公钥
  • 一直回车,就会把公钥放在C:\Users\SF\.ssh,复制里面公钥

  • 把公钥放到服务器上面

    复制代码
    cd ~
    cd .ssh
    vi authorized_keys
    然后把刚刚复制的公钥放进去保存就行
  • 拉取服务器代码

    复制代码
     git clone ssh://harry@192.168.235.130:/home/harry/VsCodeProject/GitLib

    就会出现以下文件夹,(当然文件夹名字随便改,这是我改过的,原来的名字和服务器上面一样)

3.基础设置(用于后面知道是谁上传的代码什么的)

复制代码
cd GitLib-sxf    //进入文件夹
git config user.name sxf    //设置用户名
git config user.email sxf@qq.com    //设置邮箱

4. Git各种操作指令

复制代码
git add .        //把所有文件放到暂存区(index)
git add 文件名   //把单个文件放到暂存区(index)

git commit .  -m "feat:function"      //把所有文件放到本地代码库(Repository)
git commit 文件名 -m "feat:function"  //把单个文件放到本地代码库(Repository)
      
git push origin master//把存放在本地代码库的代码放到服务器上面(Remote),origin是创建服务器时候默认名,master是分支,意思是从那支分支提交到服务器origin
        
git pull        //从服务器拉取代码到工作区

git status      //查看状态,代码处于什么阶段
git log        //生成提交日志,看谁,在什么时候提交什么东西

5.逆向操作

复制代码
git restore -S 文件名    //index->workspace,暂存区回退到工作区

git reset --soft head^    //Repository->index,本地库回退到暂存区index
git reset --mixed head^    //Repository->workspace,本地库回退到工作区workspace
git reset --hard head^    //Repository->null,本地库直接删除之前操作

git checkout        //workspace -> null,重置workspace里面的修改,例如:你添加一个函数,但你不想要了,可以使用这个
git checkout -- file
git checkout -f

6.整理操作

复制代码
git commit --amend    //整理上一次提交,一个代码,你每次加一个函数就提交一次,日志里面就有你多次提交记录,显得很麻烦,如果只想日志里面出现一次,就用这个

git rebase -i    //多次提交日志合并成一个

7.分支操作

复制代码
git branch    //查看分支

git branch 分支名    //创建分支
git checkout -b 分支名    //创建分支,并进入这个分支
git checkout 分支名    //切换到指定分支 
git switch 分支名    //切换到指定分支 

git merge    //合并分支

git branch -d 分支名    //删除分支

如果你是在分支线上面添加修改代码,就得以下步骤更新代码数据:

1.拉取 master最新数据;
git switch master//进入主线
git pull    //拉取最新代码

2.先把 master合并到develop
git switch 分支名    //变更到分支
git merge master    //合并主线最新代码

3.然后测试代码
进入代码解决冲突(因为人家比你先写好代码提交,所有你拉取最新代码后,占用同样位置,所有产生冲突)
git add.
git commit . -i -m "......"    //.是提交所有文件,-i是解决冲突提示文件,-m是添加提示

4.合并到master,测试如果ok提交到远端
git checkout master
git merge 分支名
git push origin master