当前位置: 首页 > 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.dtcms.com/a/313898.html

相关文章:

  • 微服务配置管理:Spring Cloud Alibaba Nacos 实践
  • Scrapy爬虫集成MongoDB存储
  • 基于单片机空气质量检测/气体检测系统
  • FPGA学习笔记——简单的乒乓缓存(RAM)
  • docker容器命令
  • Dbeaver数据库的安装和使用(保姆级别)
  • 嵌入式硬件篇---OpenMV存储
  • 精品PPT | 企业数字化运营平台总体规划建设方案
  • LeetCode热题100——42. 接雨水
  • AI绘画-Stable Diffusion-WebUI的ControlNet用法
  • 设计模式(一)——抽象工厂模式
  • 蓝河操作系统(BlueOS)内核 (VIVO开源)
  • [spring-cloud: 负载均衡]-源码分析
  • Nginx服务做负载均衡网关
  • Rust ⽣成 .wasm 的极致瘦⾝之道
  • 旧物回收小程序:开启绿色生活新篇章
  • SpringBoot3.x入门到精通系列:3.2 整合 RabbitMQ 详解
  • Ethereum:智能合约开发者的“瑞士军刀”OpenZeppelin
  • 白杨SEO:百度搜索开放平台发布AI计划是什么?MCP网站红利来了?顺带说说其它
  • 剧本杀小程序系统开发:开启沉浸式推理社交新纪元
  • 力扣 hot100 Day65
  • 《Python 实用项目与工具制作指南》 · 前言
  • [自动化Adapt] GUI交互(窗口/元素) | 系统配置 | 非侵入式定制化
  • [特殊字符]️ 整个键盘控制无人机系统框架
  • Qt按键响应
  • 更智能的 RibbonBar Spread.NET 18.2Crack
  • QT:交叉编译mysql驱动库
  • 基于鼠标位置的相机缩放和平移命令的实现(原理+源码)
  • Prompt Engineering
  • 赛博威携手Dify,助力AI在企业的场景化落地