关于git你日常工作中会用到的一些东西

前言

git是一个版本控制工具, 版本控制主要的好处有三点:

  1. 从当前版本回退到任意版本
  2. 查看历史版本
  3. 对比两个版本差异

git

相关术语

repository  仓库
branch      分支
summary     摘要
track       跟踪
modify      修改
stage       暂存
commit      提交
push        推送
pull        拉取
clone       克隆
amend       修改
merge       合并
conflict    冲突
origin      源
upstream    上游
downstream  下游
verbose     详情
reflog      参照日志
复制代码

git基础

  1. modified: 已修改, 修改了项目但没有提交到本地数据库, 也就是没有git add
  2. staged: 已暂存, 就是执行了git add,但是没有git commit
  3. committed: 已提交, 保存在本地数据库, 就是执行了git commit

git基本工作流程

  • 写代码
  • 对修改的文件进行快照, 保存到暂存区域中
  • 提交代码, 将暂存区域中的文件快照上传到git中

基本配置

查看当前的git配置:

git config --list
git config user.name
git config user.email

//通过git config -h了解更多的git配置查询
复制代码

修改当前配置(一般只需要配置一次, 但是如果换了电脑, 或者更换了系统我们就需要从新配置):

//用户名配置
git config --global user.name "xiaohuochai"

//邮箱配置
git config --global user.email "[email protected]"
复制代码

项目配置.gitignore

当我们提交项目到git时, 有很多文件是不需要提交的, 比如node_modules, .vscode, .idea等等

这是我们需要在项目的根目录下新建.gitignore文件

node_modules/
/*/node_modules/
.idea
.vscode

复制代码

配置ssh

当我们从github远程服务器pullpush代码时, 如何验证提交和拉取的代码是谁? 为了避免每次输入用户名, 密码的麻烦, 我们可以通过配置ssh来解决。

查看本机的ssh:

//ssh一般存在.ssh中
//打开命令行
cd ~/.ssh           //进入对应目录
ls                  //如果有可以看到私钥id_rsa文件和公钥id_rsa.pub
cat id_rsa.pub 或者 vim id_rsa.pub      //查看文件内容
复制代码

如果没有, 我们可以通过下面命令生成

ssh-keygen
复制代码

接下来, 我们复制公钥的内容,登录github

在右上角头像下拉settings -> SSH and GPG Keys中点击 New SSH Key进行添加。

通过ssh -T [email protected]命令来验证SSH是否配置成功。

git基本操作

  • 初始化新仓库
git init
复制代码
  • 查看文件状态
git status
复制代码
  • 文件跟踪
git add xxx         //跟踪某个文件
git add .           //批量跟踪
复制代码

文件是否add成功, 我们可以通过git status再检查一次

  • 文件提交本地仓库
git commit              //提交文件到本地仓库
git commit -m ‘xxx‘     //xxx是你本次提交的信息说明
git commit -am ‘xxx‘    //将所有已跟踪的文件暂存起来一并提交
复制代码
  • 推送远程仓库
git push origin xxx
//你可以通过-u指定一个默认的源, 这样以后push就不用加origin
git push -u origin xxx
//以后就可以
git push

复制代码
  • 拉取远程仓库
git pull origin xxx
//可以简写git pull, 如果提示no tracking information, 我们可以通过下面方法建立追踪,后续就可以直接git pull了
git branch --set-upstream branch-name origin/branch-name
复制代码
  • 差异比较
git diff
复制代码
  • 查看提交历史
git log                 //按提交时间列出所有的更新,最近的更新排在最上面
git log --oneline       //查看简要的历史记录
git reflog              //用来记录每一次命令, 常用来辅助版本切换
复制代码

一次正常的代码提交流程

git pull
git add .
git commit -m ‘xxx‘
git push
复制代码

git版本切换

有时候业务场景, 或者需求变更等各种因素, 需要我们切换回之前的某个版本。

要进行版本切换, 我们就得知道当前处于哪个版本:

git log --oneline
复制代码

带有HEAD字样的就是我们当前所在版本, 通过git reset --hard id命令切换版本。 id可以是:

- HEAD^ : 上个版本
- HEAD^^: 上上个版本
- HEAD~10: 上10个版本
复制代码

当你切换回上某个版本之后, 通过git log你就看不到最新版本了,这时我们就可以使用git reflog了, 这个命令会按照之前经过的所有的commit路径排列。

git分支管理

我们一般开发都会从master分支分离出dev或者其他开发分支, 用来开发, 这样即使开发出现问题也不会影响主分支。

使用git branch xxx创建一个新的分支。

使用git checkout xxx切换到新的分支

branch, checkout常用命令:

git checkout -b xxx         //可以快速新建并切换到新的分支

git branch -d xxx           //当分支合并到主分支, 这个分支就可以通过-d删除了

git branch -D xxx           //删除那些没有被合并的分支

git branch -a               //查看所有分支
复制代码

分支合并

注意: 分支合并时, 你一定要保证你在要合并到这个分支的目标分支上

使用git merge xxx即可将xxx分支合并到你当前所在的分支。

正常的合并分支很简单, 这样就ok了, 但是分支合并, 如果在不同的分支修改了同一个文件的同一部分, 此时git是无法判断该使用哪个分支的代码的, 这样就会产生冲突,虽然git进行了合并, 但并没有提交, 需要我们解决冲突, 重新提交。

我们可以通过git status查看是哪些文件发生了冲突,然后逐一解决, 当我们把冲突的代码按正确的代码修复后, 需要重新git add, git commit, git push

操作远程仓库

clone远程仓库

通过git clone url来克隆远程仓库

比如:

//这个默认会在你拉取的路径下新建一个blog-mason的文件夹
git clone https://github.com/MasonEast/blog-mason.git   

//如果你不想要文件夹blog-mason, 你可以这样, 在url后面,空格加新名字
git clone https://github.com/MasonEast/blog-mason.git newName

//如果你就想要在当前路径下放项目文件, 不要那个外面的文件夹了, 可以用.
git clone https://github.com/MasonEast/blog-mason.git .
复制代码

查看远程仓库git remote

我们克隆的仓库通过git remote会看到一个叫origin的远程库, 这是git默认标识克隆的原始仓库

通过git remote -vgit remote --verbose我们可以查看到更加详细的信息,即对应的项目地址, 正常会有两个, 但如果你没有push权限的话就只能看到一个fetch的地址。

git remote -v

origin  [email protected]:MasonEast/blog-mason.git (fetch)
origin  [email protected]:MasonEast/blog-mason.git (push)
复制代码

删除远程分支

git push origin :xxx
//也可以
git push origin --delete xxx
复制代码

删除远程仓库

git remote rm xxx
复制代码

重命名远程仓库

git remote rename oldName newName
复制代码

关于误操作

git主要用于版本控制, 协同开发, 误操作可以撤销, 但是有的撤销是不可逆的, 我们一定要慎重对待, 不然可能导致部分代码丢失。

修改最后一次提交

场景: 某次提交完后, 发现少提交了文件, 我们需要撤销刚才的提交, 然后重新提交。

git add xxx             //添加少提交的文件到暂存区
git commit --amend      //往最后一次提交中追加少提交的文件, 这次提交不会产生记录
复制代码

移除本地仓库的文件

场景: 我们通过git commit将文件提交到本地仓库后, 才想起来把不想提交的文件加进去了。

git rm xxx
复制代码

移除暂存区的文件

场景: 有时候我们习惯性git add ., 但有的文件我们不应该提交, 这时要从暂存区中移除文件。

git reset HEAD xxx      //从暂存区中移除xxx文件
复制代码

后话

上述只是日常工作可能会用到的基本操作,这里做一个小小的整理, 还有很多git进阶学习的命令还没有提到, 比如git stash, git rebase等, 主要是在下也没完全玩明白, 就不好在此提及了。

作者:MasonEast
链接:https://juejin.im/post/5e0f401f6fb9a047f164fc9f
来源:掘金
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

原文地址:https://www.cnblogs.com/hss-blog/p/12148082.html

时间: 2024-10-29 19:11:43

关于git你日常工作中会用到的一些东西的相关文章

日常工作中的点滴总结from 2014-03

一 关于 写方案: 写某个产品的方案基本应包括以下几点: 1产品目前现状(国内外)  2产品意义.作用 3产品架构 4产品优势 5产品功能讲解 二 关于 处理下属工作方向不正确的事务 首先 先肯定 下属工作的成果 其次 了解其思路,再站在他的角度分析方向的不妥之处 最后 愉快的氛围下,让下属明白自己 工作的方向性错误. 三 关于 与上司沟通工作的事务 1.认真听取上司所说的内容,听不懂及时确认,避免后续由于沟通不畅导致不愉快事情. 2.自己思考后,有问题 及时提出与其沟通 四 关于 团队 提高团

日常工作中常用的Linux命令

以下Linux命令是我日常工作中常用到的: sudo su - :切换为临时的root权限; chmod +x * :用于改变linux系统文件或目录的访问权限; ps -ef |grep dubbo-account :查看进程; ./ shutdown.sh : 关闭某个服务; tar -zxf nginx-1.6.tar.gz: 解压; less all.log : 查看当天的日志; tail -f all.log: 监控日志; ls -lh: 查看各个文件的大小; sz all.log:

Linux日常工作中常用快捷右键脚本(主要是android应用)

相对于Windows系统的环境里面,Linux在自定义的右键操作中提供了便利的个性化,只需要在 ~/.gnome2/nautilus-scripts 文件里面新建脚本文件即可.由于博主从事andriod工作,下面主要介绍该日常工作里面需要用到的脚本: 1.首先,在终端输入路径~/.gnome2/nautilus-scripts,然后直接输入gedit name.txt(或者直接在文件系统里面进入该路径新建脚本文件): 2.在打开的文字编辑框输入以下命令: (1)直接安装apk文件,gnome-t

在linux日常工作中touch的用法

大家在日常运维工作中都知道touch命令是用来创建一个新的空文件的,但是还有一个重要的作用今天给大家说一下,那就是更改文件日期. 一般我们主要用于把文件日期修改为目前日期: touch -d "日期" 文件名 例如:将test的日期调整为两天前 touch -d "2 days ago" test touch -t 时间 文件名 例如:将test文件日期改为2016/9/12 9:53 touch -t 1609120953 test

git命令日常工作总结

常用git命令git commit -m "fix:问题描述 # 出问题的CM-jiro号" 如 提交记录描述模板:fix(admin/统计/企业支付): "导出所有用户信息" 点击无响应 #CM-31334 git branch -r 查看远程所有分支git branch -a 查看本地和远程所有分支git branch -a 查看远程分支(当前分支.同级分支.上一级分支.下一级分支,不能查看其它分支的子分支)git branch -a | grep CM-305

日常工作中常见的mysql优化技巧

1.介绍一下MYSQL经常使用的优化技巧. MySQL 自带 slow log 的分析工具 mysqldumpslow ,可是没有说明.本文通过分析该脚本,介绍了其用法. slow log 是 MySQL 依据 SQL 语句的运行时间设定,写入的一个文件,用于分析运行较慢的语句. 仅仅要在 my.cnf 文件里配置好: log-slow-queries = [slow_query_log_filename] 就可以记录超过默认的 10s 运行时间的 SQL 语句. 假设要改动默认设置,能够加入:

日常工作中常用方法记录

1.根据数组对象中的某一个属性进行排序 var arr = [ {name:'zopp',age:0}, {name:'gpp',age:18}, {name:'yjj',age:8} ]; function compare(property){ return function(a,b){ var value1 = a[property]; var value2 = b[property]; return value1 - value2; } } console.log(arr.sort(com

日常工作中遇到“-bash: netstat: 未找到命令”的解决方法

1.遇到的问题如下: [[email protected] ~]# netstat -anptu | grep mysql -bash: netstat: 未找到命令 2.解决方法如下: [[email protected] ~]# yum -y install net-tools <!--安装依赖程序--> 已加载插件:fastestmirror Loading mirror speeds from cached hostfile * base: mirrors.aliyun.com * e

[日常工作]Oracle12cr2在日常工作中遇到的不兼容的问题

Oracle12c 数据库GS实例时需要使用新驱动,避免制单出现获取不到正确凭证编号内码的问题. Oracle12c 会产生大量的隐藏表,部分ddl语句会报错. Oracle12c 删除了VM_concat函数, 需要手工创建,解决供应链.新应收应付行转列函数报错(建议使用新函数来重写代码,Oracle已经废弃此函数). Oracle12.1.0.2 release 4的 ODP.net的驱动有问题,会造成IIS崩溃,不建议使用此版本. Oracle12.2的ODP.net驱动经常会出现异常提示