Git版本控制-程序员宅基地

技术标签: git  

Git

关于Linux的简介、诞生,大家可以去网上查一查,这里不多做赘述了

基本概念

  • 工作区:仓库的目录,工作区是独立于各个分支的
  • 暂存区:数据暂时存放的区域,暂存区是独立于各个分支的
  • 版本库:存放所有已经提交到本地仓库的代码版本
  • 版本结构:树结构,树中每个节点代表一个代码版本

Linux上安装Git

yum安装

在Linux上是有yum安装Git,非常简单,只需要一行命令

yum -y install git

输入 git --version查看Git是否安装完成以及查看其版本号

至此,使用yum安装git就完成了

自定义安装

使用yum安装虽然比较方便,但是其安装的Git版本比较旧,而且安装的目录是固定的,所以我们一般采用自定义安装

  1. 进入gitGitHub上发布版本页面Git历史版本,这个页面我们可以找到所有git已发布的版本.这里我选择的版本比较早。

    外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

  2. 下载tar.gzGit到本地电脑,然后上传到Linux服务器中某个目录下,我上传到的是/opt目录下

    外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

  3. 然后我们可以在/opt目录下创建一个git文件夹,将我们的git压缩包放到git文件夹中,并且解压

    tar -zxvf git-2.30.2.tar.gz
    
  4. 进入到解压的文件夹中,此时我们拿到我们解压后的源码,需要开始编译源码,不过需要先去安装编译所需要的依赖

    # 进入到解压后的git文件夹中
    cd git-2.30.2
    
    # 安装编译所需依赖
    yum install curl-devel expat-devel gettext-devel openssl-devel zlib-devel gcc perl-ExtUtils-MakeMake  # 安装途中会出现提示,全部按y即可
    
  5. 提示,安装编译源码所需依赖的时候,yum自动帮你安装了git,这时候你需要先卸载这个旧版的git

    yum -y remove git 
    
  6. 编译git源码,这里你当时解压在哪个目录,最好就编译在哪个目录,我是在/opt/git中,大家不要混淆!!!

    make prefix=/opt/git all
    
  7. 安装git/opt/git路径,和6一样,按照自己的目录!!!

    make prefix=/opt/git install
    
  8. 配置环境变量(没有vim的,记得提前去下载安装,也可以使用vi)

    vim /etc/profile 
    

    在最后加入以下内容,和6、7一样,一定要按照自己的目录!!!

    export PATH=$PATH:/opt/git/bin
    

    输入:wq保存修改

    刷新环境变量

    source /etc/profile
    
  9. 查看Git是否安装完成

    git --version
    

    外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

至此,Linux中的Git已安装完成,Windows上的Git非常简单,几乎傻瓜式安装,需要安装的朋友可以自己搜索

全局设置

  1. git config --global user.name xxx:设置全局用户名,信息记录在~/.gitconfig文件中
  2. git config --global user.email [email protected]:设置全局邮箱地址,信息记录在~/.gitconfig文件中

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

常用命令

创建一个文件夹

  1. git init:将当前目录配置成git仓库,信息记录在隐藏的.git文件夹中
  2. git add XX:将XX文件添加到暂存区中
    • git add .:将所有待加入暂存区的文件加入暂存区
  3. git commit -m "备注信息":将暂存区的内容提交到当前分支
  4. git status:查看仓库状态
  5. git log:查看当前分支的所有版本
  6. git push -u (第一次需要-u以后不需要):将当前分支推送到远程仓库
    • git push origin branch_name:将本地的某个分支推送到远程仓库
  7. git clone [email protected]:xxx/XXX.git:将远程仓库XXX下载到当前目录下
  8. git branch:查看所有分支和当前所处分支

查看命令

  1. git diff XX:查看XX文件相对于暂存区修改了哪些内容
  2. git status:查看仓库状态
  3. git log:查看当前分支的所有版本
  4. git log --pretty=oneline:用一行来显示
  5. git reflog:查看HEAD指针的移动历史 (包括被回滚的版本)
  6. git branch:查看所有分支和当前所处分支
  7. git pull:将远程仓库的当前分支与本地仓库的当前分支合并

删除命令

  1. git rm --cached XX:将文件从仓库索引目录中删除,不希望管理这个文件
  2. git restore --staged XX:将XX从暂存区里移除
  3. git checkout — XX或git restore XX:将XX文件尚未加入暂存区的修改全部撤销

代码回滚

  1. git reset --hard HEAD^ 或git reset --hard HEAD~ :将代码库回滚到上一个版本
  2. git reset --hard HEAD^^:往上回滚两次,以此类推
  3. git reset --hard HEAD~100:往上回滚100个版本
  4. git reset --hard 版本号:回滚到某一特定版本

远程仓库

  1. git remote add origin [email protected]:xxx/XXX.git:将本地仓库关联到远程仓库
  2. git push -u (第一次需要-u以后不需要) :将当前分支推送到远程仓库
  3. git push origin branch_name:将本地的某个分支推送到远程仓库
  4. git clone [email protected]:xxx/XXX.git:将远程仓库XXX下载到当前目录下
  5. git push --set-upstream origin branch_name:设置本地的branch_name分支对应远程仓库的branch_name分支
  6. git push -d origin branch_name:删除远程仓库的branch_name分支
  7. git checkout -t origin/branch_name 将远程的branch_name分支拉取到本地
  8. git pull :将远程仓库的当前分支与本地仓库的当前分支合并
  9. git pull origin branch_name:将远程仓库的branch_name分支与本地仓库的当前分支合并
  10. git branch --set-upstream-to=origin/branch_name1 branch_name2:将远程的branch_name1分支与本地的branch_name2分支对应

分支命令

  1. git branch branch_name:创建新分支
  2. git branch:查看所有分支和当前所处分支
  3. git checkout -b branch_name:创建并切换到branch_name这个分支
  4. git checkout branch_name:切换到branch_name这个分支
  5. git merge branch_name:将分支branch_name合并到当前分支上
  6. git branch -d branch_name:删除本地仓库的branch_name分支
  7. git push --set-upstream origin branch_name:设置本地的branch_name分支对应远程仓库的branch_name分支
  8. git push -d origin branch_name:删除远程仓库的branch_name分支
  9. git checkout -t origin/branch_name:将远程的branch_name分支拉取到本地
  10. git pull :将远程仓库的当前分支与本地仓库的当前分支合并
  11. git pull origin branch_name:将远程仓库的branch_name分支与本地仓库的当前分支合并
  12. git branch --set-upstream-to=origin/branch_name1 branch_name2:将远程的branch_name1分支与本地的branch_name2分支对应

stash暂存

  1. git stash:将工作区和暂存区中尚未提交的修改存入栈中
  2. git stash apply:将栈顶存储的修改恢复到当前分支,但不删除栈顶元素
  3. git stash drop:删除栈顶存储的修改
  4. git stash pop:将栈顶存储的修改恢复到当前分支,同时删除栈顶元素
  5. git stash list:查看栈中所有元素
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_51971817/article/details/138012662

智能推荐

Springboot/java/node/python/php基于springboot+vue手机售后管理系统【2024年毕设】-程序员宅基地

文章浏览阅读779次,点赞19次,收藏24次。springboot微信小程序的小疾病问诊服务系统的设计与实现。springboot基于spring的物业管理系统的设计与实现。springboot基于Java的高校学生请假系统。ssm基于Android的购物商场APP设计与实现。springboot基于微信小程序的智慧校园系统。ssm基于Android的英语词典的设计与开发。ssm基于SSM+Vue的学生实践管理平台开发。ssm基于android的企业员工考勤系统。ssm基于web的暗香小店系统的设计与实现。ssm基于Web的高等学校公费医疗管理系统。

css中hover属性的使用技巧_css hover的用法-程序员宅基地

文章浏览阅读2.3w次,点赞15次,收藏63次。hover属性用不同的书写方式,来改变不同关系的元素样式。元素:hover 表示聚焦后改变自己元素:hover 元素 表示聚焦后改变其子元素元素:hover + 元素 表示聚焦后改变其指定的“亲兄弟”(条件是该兄弟元素与其相邻)元素元素:hover ~ 元素 表示聚焦后改变其指定的兄弟元素,两个元素相不相邻都行。示例:.first:hover {color: white;}/* 聚焦我改变自己 */.three:hover .three-son {font-size: 20px._css hover的用法

coursera-斯坦福-机器学习-吴恩达-第8周笔记-无监督学习_pca反向压缩-程序员宅基地

文章浏览阅读6k次,点赞3次,收藏15次。coursera-斯坦福-机器学习-吴恩达-第8周笔记-无监督学习coursera-斯坦福-机器学习-吴恩达-第8周笔记-无监督学习1聚类算法clutering1聚类算法简介2K-means21kmeans的目标函数22随机初始化23选择类别数3考试quiz维数约减 dimensionality reduction1数据压缩2数据可视化3维度约简-主成分分析法PCA1 PCA_pca反向压缩

vim插件安装及常用技巧_bxbx.vim-程序员宅基地

文章浏览阅读5.2k次。一、插件安装Vundle是vim的一个插件管理器, 同时它本身也是vim的一个插件。插件管理器用于方便、快速的安装、删除、Vim更新插件。mkdir -p ~/.vim/bundlegit clone https://github.com/gmarik/Vundle.vim.git ~/.vim/bundle/Vundle.vim管理器安装完成后,vim ~/.vimrc命令创建.vimrc文件syntax on" tab宽度和缩进同样设置为4set tabstop=4set softta_bxbx.vim

java.lang.ClassNotFoundException:如何解决-程序员宅基地

文章浏览阅读7.2w次,点赞10次,收藏41次。本文适用于当前面临java.lang.ClassNotFoundException挑战的Java初学者。 它将为您提供此常见Java异常的概述,这是一个示例Java程序,可支持您的学习过程和解决策略。 如果您对与更高级的类加载器相关的问题感兴趣,我建议您复习有关java.lang.NoClassDefFoundError的文章系列,因为这些Java异常密切相关。 java.lang..._java.lang.classnotfoundexception:

串口通信数据帧_一帧数据-程序员宅基地

文章浏览阅读1.2k次,点赞9次,收藏17次。不同的设备间建立连接往往需要通信,而串口通信是十分常用的一种。UART串口通信需要两根线来实现,一根用于串口发送,另外一更用于串口接收。UART串口发送或者接收过程中一帧数据包括1位起始位、8位数据位、1位停止位,为了提高数据的可靠性可以在停止位前加上1位奇偶校验位。串口通信虽然十分简单,但是在不同设备间发送的数据往往不止1个字节,往往需要多个字节组成的数据包。当我们按照数据包发送时我们需要考虑到以及,因此我们可以采用定义数据帧的方式解决上述两个问题。_一帧数据

随便推点

Android四大组件之Activity--管理方式_android activityrecord中的activitytype-程序员宅基地

文章浏览阅读1.7k次。1. 概览Activity的管理有静态和动态两层涵义: 静态是指Activity的代码组织结构,即Application中声明的Activity的集合,这些Activity被组织在一个APK中,有特定的包名。 在编写应用程序时,Activity对应到用户界面,它定义了用户界面的布局、交互行为、启动方式等,最重要的,是Activity的生命周期函数。 在应用进程看来,只需要按照Android定义的规范,实现生命周期函数的具体逻辑即可,所有的用户界面都遵循同一个规范。 编写完一个应用程序的所有用户界面_android activityrecord中的activitytype

[LINUX]sed查找不包含某个字符串的行,并进行替换_sed不包含字符串-程序员宅基地

文章浏览阅读5.5k次,点赞3次,收藏7次。sed 查找不包含某个特性 sed -i "/src/!s/xxx/bbb/g" xxx将不包含src的行中的xxx替换为bbb_sed不包含字符串

问题解决:shared_ptr Assertion px != 0 failed 及debug经验分享_typename boost::detail::sp_dereference<t>::type bo-程序员宅基地

文章浏览阅读6.8k次,点赞11次,收藏18次。问题解决:shared_ptr Assertion px != 0 failed及debug经验分享问题详细描述:/usr/include/boost/smart_ptr/shared_ptr.hpp:646: typename boost::detail::sp_dereference::type boost::shared_ptr::operator*() const [with T = pcl::PointCloudpcl::pointxyz; typename boost::detail::sp_typename boost::detail::sp_dereference::type boost::shared_ptr::operat

看不见的“网” ,一文读懂阿里云基础设施网络_阿里云网络基线理解-程序员宅基地

文章浏览阅读553次。编者按:在这个万物智联的时代,无论是在线网络购物,还是网络强国、数字中国建设,都离不开一张“看不见的网”——基础设施网络。2009年,首届双11每秒交易订单创建峰值400;2021年,双11每秒交易订单创建峰值58.3万,12年交易数字量猛增的背后,是阿里云在庞大分布式系统上计算和IO能力的飞跃,更离不开阿里云基础设施底层网络技术的支撑。图|阿里云全球基础设施网络系统作为阿里云基础设施的重要组成部分,阿里云基础设施网络团队负责整个阿里云全球基础设施网络,包括大规模高性能数据中心网络,全球数据中心互联_阿里云网络基线理解

TCP/UDP常见端口参考_怎么查看端口映射的是tcp还是udp-程序员宅基地

文章浏览阅读1.7k次。端口列表一览端口号码 / 层 名称 注释 1 tcpmux TCP 端口服务多路复用 5 rje 远程作业入口 7 echo Echo 服务 9 discard 用于连接测试的空服务 11 systat 用于列举连接了的端口的系统状态 13 daytime 给请求主机发送日期和时间 17 qotd 给连接了的主机发送每日格言 18 msp 消息发送协议 19 _怎么查看端口映射的是tcp还是udp

推荐文章

热门文章

相关标签