当前位置: 首页 > news >正文

分布式版本控制工具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是分支,意思是从那支分支提交到服务器origingit 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

http://www.lryc.cn/news/609503.html

相关文章:

  • Spring之【Bean的实例化方式】
  • 电脑忘记开机密码怎么办?【图文详解】5种方法重置/更改/取消/设置开机密码?
  • Java从入门到精通 - 算法、正则、异常
  • 深入浅出 RabbitMQ:简单队列实战指南
  • 【Linux指南】软件安装全解析:从源码到包管理器的进阶之路
  • 小杰数据结构(five day)——知人者智,自知者明。
  • WPF 按钮背景色渐变
  • 飞算 JavaAI:给需求分析装上 “智能大脑“
  • VPS云服务器Linux性能分析与瓶颈解决方案设计
  • 机器学习 决策树案例电信用户流失
  • 豆包新模型+PromptPilot深度评测:提示词工程的智能化突破
  • Chrontel 【CH7104B-BF】CH7104B HDMI to HDTV/VGA Converter
  • SJW-app-1
  • 力扣热题100——双指针
  • Android GPU测试
  • 豹女篇章-人形态技能加攻速
  • 数据离不开哈希
  • 【Linux | 网络】网络层(IP协议、NAT技术和ICMP协议)
  • 【前端:Html】--1.3.基础语法
  • 【人工智能99问】什么是Post-Training,包含哪些内容?(19/99)
  • 3.JVM,JRE和JDK的关系是什么
  • Linux 系统重置用户密码指南
  • 【09】C++实战篇——C++ 生成静态库.lib 及 C++调用lib,及实际项目中的使用技巧
  • vue3指定设置了dom元素的ref但是为null问题
  • 大模型 与 自驾 具身 3D世界模型等相关知识
  • 华为OD机考2025C卷 - 最小矩阵宽度(Java Python JS C++ C )
  • vim 组件 使用pysocket进行sock连接
  • 408数据结构排序部分知识的复盘:从原理到辨析的系统化梳理
  • 抗辐照DCDC与MCU在核环境监测设备中的集成应用
  • 远程测控终端RTU:工业物联的“神经末梢”与远程操控核心