git小白初学习

#1. 安装 http://npm.taobao.org/mirrors/git-for-windows/

#2. 设置自己的用户信息,方便各个节点知道这个客户端是谁
#全局设置
git config --global user.name ‘xyg’
git config --global user.email ‘1584066465@qq.com’

#对单个仓库设置
cd 到对应仓库下
git config user.email '1584066465@qq.com'

#3. 建立本地git仓库
mkdir e:/gitrepo
cd e:/gitrepo

#4. 初始化文件夹,使其变为可管理的git仓库
git init
#这时候看e:/gitrepo文件夹下就回多出一个.git文件,表示已成功初始化

#5. 拷贝项目文件进入该目录

#6. 添加修改并提交
git add index.php #添加单个文件
git add Admin/ #添加一个目录
git add *.php #添加所有php文件

git commit -m '修改原因说明'  #不必每次都执行,可以add一定数量之后在执行

#7. 查看被修改过的文件或者不受git管理的文件列表
git status # +(加号)开始,绿色行,表示新增
# -(减号)开始,红色行,表示删除
# git对修改认为是 删除旧行,新增新行

git diff index.php          #查看修改文件 都修改了什么
git diff HEAD -- index.php  #对比仓库中和当前修改的区别, -- 分割路径修改
git diff xxxxxxx yyyyyyy    #对比两次提交的差别
git diff topic master       #对比master分支和topic分支的差别git log #查看最近都修改了什么#  --pretty=oneline #让log更好看点#  --name-only #显示修改的文件名称#git reflog   #查看所有操作的命令历史记录

#8. 回滚
git reset --hard HEAD^ #HEAD^ 表示回滚到上一次的版本 HEAD^^ 上上一次 HEAD~n 回滚到第n次提交的版本
git reset --hard xxxxxxx #回滚到指定commit id的版本, 可以通过git log查看, 注意这里的id一般没必要写全,前7位足够了,也可以更少

#9. 撤销修改
git checkout – index.php #撤销工作区index.php文件的修改
git reset HEAD – index.php #撤销暂存区index.php最新一次修改

#10. 删除文件
#先删除源文件
git rm index.php #从仓库中删除

#恢复误删文件(git之前管理过的)
git checkout -- index.php

#11. 连接远程仓库
#1). 创建SSH key
ssh-keygen -t rsa -C ‘1584066465@qq.com’
#一路回车就行了,创建好之后的sshkey在用户主目录里面
#例如 C:\Users\sujrex.ssh
#id_rsa位私钥不能泄露,id_rsa.pub为公钥提供给git服务器,如gitee
#2). 将id_rsa.pub的内容保存到远程库里面,后面以华为git举例
#3). 将本地仓库和远程仓库关联
git remote add boss-origin ssh://git@218.108.32.134:5188/home/gitrepo/miu.git
#公司远程库命名boss-origin
git remote add huawei-origin git@codehub.devcloud.huaweicloud.com:fucun00001/fucun.git
#华为远程库的名字就命名huawei-origin
#4). 查看远程仓库
git remote -v
#5). 拉取远程仓库的最新代码到本地
git pull huawei-origin master

#12. 克隆远程仓库
cd /homework/ #到工作目录 当在家里或者其他地方的时候,需要修改项目这时就可以用到这条命令
git clone git@codehub.devcloud.huaweicloud.com:fucun00001/fucun.git

#13. 分支概念
#1). 查看分支
git branch #查看所有分支,*指向的就是当前分支

#2). 创建删除分支
git branch fucunnewfeature    #创建fucunnewfeature分支
git switch fucunnewfeature    #切换到fucunnewfeature分支,这个命令也一样的结果 git checkout fucunnewfeature
#下面这行等同于上两行执行的结果
git switch -b fucunnewfeature #创建并切换到fucunnewfeature分支, 这个命令一样的结果 git checkout -b fucunnewfeaturegit branch -d fucunnewfeature   #删除分支  -D 强行删除#3). 合并分支
git switch master
git merge fucunnewfeature 
# 合并分支时,默认使用的是fast forward模式,如果想强制不使用该模式,可以使用
git merge --no-ff -m '合并原因' fucunnewfeature # --no-ff就是不使用默认模式,并且因为该命令会产生一次提交,所以必须有m参数
#fast forward模式在删除分支后,会丢失分支信息,使用上面的方案之后,会吧分支信息保留在git log中,即便删除了分支git log --graph --pretty=oneline --abbrev-commit #查看分支合并图#4). 设想场景 你正在分支上干活,现在突然间主线版本出现BUG,需要立即修复
git stash  #保存现场,待后续继续
git switch master #切回主分支
git switch -c issue-1001 # 创建bug分支,并切换到分支上,修改完成后 add, commit, switch master, merge到主分支上
git switch fucunnewfeature #重新切回到正在修改的分支上
git stash list #查看之前保存的现场
git stash pop #恢复现场并删除stash内容  也可以 
git stash apply #恢复现场,但不删除stash内容
git stash drop  #删除stash内容
git stash apply stash@{0} #指定恢复那个现场,当有多个现场的时候,其中stash@{0}可以在git stash list的时候查看到#5). 设想场景,在master分支上修复了bug后,我们要想一想,fucunnewfeature分支是早期从master分支分出来的,所以,这个bug其实在当前fucunnewfeature分支上也存在。那怎么在fucunnewfeature分支上修复同样的bug?git cherry-pick xxxxxxx #这个xxx就是在issue-1001上commit时得到的,也可以git log查看, 这样就完成的了bug同步到分支上的功能
#6). 设想各种原因导致推送到远程服务器上的代码有问题需要回退git log --pretty=oneline #找到需要回滚到的节点commit id_rsa位私钥不能泄露,id_rsagit reset --hard commit_id #回滚到指定地点git push origin HEAD --force #远程提交回退#也可以通过以下方式回滚,比上面多出的是可以方便的备份修改git reset --hard commit_idgit checkout -b newmaster #重新创建一个分支,这时候的分支就是上一次提交的代码git push origin newmaster:newmaster #推到对应的远程newmastergit branch -d mastergit push --delete origin master #这个时候相当于备份做好了,接下来就可以删除本地及远端的master分支git checkout -b master origin/newmastergit push master:master #从newmaster分支,重新在创建master分支,并推向远端

#14. 打包发版本
git switch master
git tag fucun-v1.0 [xxxxxxx] #默认给最新提交的commit上打tag,后面的xxxxxx是指定的commit id(通过git log查看)
git tag -a fucun-v1.0 -m “打tag说明” [xxxxxxx] #对当前tag进行注释说明
git tag #查看所有tag
git show fucun-v1.0 #查看指定tag的信息

git push huawei-origin fucun-v1.0 #推送指定tag到远程仓库
git push huawei-origin --tags     #一次性推送所有未推送到远程仓库的taggit tag -d fucun-v1.0 #删除本地仓库指定tag
git push huawei-origin :refs/tags/fucun-v1.0 #删除远程仓库指定tag

#15. 忽略不需要提交的文件
.gitignore #创建该文件,里面编辑
#Windows
Thumbs.db
Desktop.ini

    #Linux*.ini

#16. 配置常用的命令的别名
#比如git log --graph --pretty=oneline --abbrev-commit这个命令太长了,记不住
git config --global alias.lg “log --graph --pretty=oneline --abbrev-commit” #之后只要执行
git lg #就可以了

git config #全局配置对应的文件在 .git/config下
#而当前仓库的配置文件在 .gitconfig下

#17. 配置beyondcompare
#在用户家目录下找到 .gitconfig文件,编辑或加入以下配置
[diff]
tool = bc4
[difftool]
prompt = true
[difftool “bc4”]
cmd = “D:/Program Files/Beyond Compare 4/BCompare.exe” “$(cygpath -w L O C A L ) " " LOCAL)" " LOCAL)""REMOTE”
[merge]
tool = bc4
[mergetool]
prompt = true
keepBackup = false #为了解决使用git mergetool合并分支时,总会产生以*.orig为扩展名的备份文件
[mergetool “bc4”]
#trustExitCode = true
cmd = “D:/Program Files/Beyond Compare 4/BCompare.exe” “ L O C A L " " LOCAL" " LOCAL""REMOTE” “ B A S E " " BASE" " BASE""MERGED”

#FAQ:
#1. warning: LF will be replaced by CRLF in … #git默认开启在不同系统下不同换行结束符的转换
git config --global core.autocrlf false #关闭自动转换

#2. 第一次push时报错
The authenticity of host '....' can't be established.  输入yes#3. 错误
error: failed to push some refs to 'git@codehub.devcloud.huaweicloud.com:fucun00001/fucun.git'
hint: Updates were rejected because the tip of your current branch is behind
hint: its remote counterpart. Integrate the remote changes (e.g.
hint: 'git pull ...') before pushing again.
hint: See the 'Note about fast-forwards' in 'git push --help' for details.#主要原因是远程仓库不为空导致的,需要先合并远程仓库到本地
git pull --rebase huawei-origin master
#后续在git push就可以了#4. git merge 和 git rebase区别
#假设现在有两个分支 A B
#1). 在B分支上执行 git merge A 后 A就被合到B上了
#2). 在B分支上执行 git rebase A 后,效果与merge是一样的,但是 A就没有了,两个分支就合在一起了。#5. git pull 和 git pull --rebase
git pull = git fetch + git merge FETCH_HEAD 
git pull --rebase =  git fetch + git rebase FETCH_HEAD
#https://www.jianshu.com/p/dc367c8dca8e#6.git push时出现
#remote: error: insufficient permission for adding an object to repository database ./objects
#这个主要原因是git服务器的git仓库权限不足导致的
cd /home/gitrepo/
chown -R git:git fucun.git
cd fucun.git
git config --bool core.bare true

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/187684.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

GaussDB如何进行性能调优

GaussDB如何进行性能调优 GaussDB性能调优过程需要综合考虑多方面因素,因此,调优人员应对系统软件架构、软硬件配置、数据库配置参数、并发控制、查询处理和数据库应用有广泛而深刻的理解。 调优流程 调优各阶段说明,如下表所示。 数据库性…

深入探究Photoshop图像修复与润饰技巧

💂 个人网站:【 海拥】【神级代码资源网站】【办公神器】🤟 基于Web端打造的:👉轻量化工具创作平台💅 想寻找共同学习交流的小伙伴,请点击【全栈技术交流群】 在Photoshop中,图像修复和润饰是强…

Vim Coc插件实现代码跳转

Vim Coc插件实现代码跳转 按照coc主页的配置 里面是有提供代码跳转的功能的 具体配置如下 " GoTo code navigation nmap <silent> gd <Plug>(coc-definition) nmap <silent> gy <Plug>(coc-type-definition) nmap <silent> gi <Plug…

CNN对 MNIST 数据库中的图像进行分类

加载 MNIST 数据库 MNIST 是机器学习领域最著名的数据集之一。 它有 70,000 张手写数字图像 - 下载非常简单 - 图像尺寸为 28x28 - 灰度图 from keras.datasets import mnist# 使用 Keras 导入MNIST 数据库 (X_train, y_train), (X_test, y_test) mnist.load_data()print(&…

安卓搜索框,EditText,SearchView

创建安卓搜索框一般有两种方法&#xff0c;使用EditText控件或使用SearchView控件&#xff1b;因为SearchView自由度和效果感觉没有EditText好&#xff0c;建议使用EditText控件&#xff1b;SearchView建议与ToolBar和menu配合使用。 1. EditText EditText制作搜索框只需要使…

代码随想录算法训练营第三十六天| 435 无重叠区间 763 划分字母区间 56 合并区间

目录 435 无重叠区间 763 划分字母区间 56 合并区间 435 无重叠区间 将intervals数组按照左端点进行升序排序。 设置变量len标志此时新加入端点后所有区间的位置&#xff0c;将其赋初值为第一对区间的右端点&#xff0c;因为该点是一定可达的。设置变量res来存储需要移除空间…

java对xml压缩

import java.util.*; import java.util.zip.GZIPOutputStream; import java.nio.charset.StandardCharsets; import org.apache.commons.codec.binary.Base64;/*** 模板压缩** param xml 模板xml* return* throws Exception*/public static String businessData(String xml) th…

上海亚商投顾:沪指震荡反弹 消费、医药股走势活跃

上海亚商投顾前言&#xff1a;无惧大盘涨跌&#xff0c;解密龙虎榜资金&#xff0c;跟踪一线游资和机构资金动向&#xff0c;识别短期热点和强势个股。 一&#xff0e;市场情绪 指数今日窄幅震荡&#xff0c;黄白二线分化明显&#xff0c;权重股力挺指数&#xff0c;题材小票走…

INA219电流感应芯片_程序代码

详细跳转借鉴链接INA219例程此处进行总结 简单介绍一下 INA219&#xff1a; 1、 输入脚电压可以从 0V~26V,INA219 采用 3.3V/5V 供电. 2、 能够检测电流&#xff0c;电压和功率&#xff0c;INA219 内置基准器和乘法器使之能够直接以 A 为单位 读出电流值。 3、 16 位可编程地…

《数字图像处理-OpenCV/Python》连载(50)非线性灰度变换

《数字图像处理-OpenCV/Python》连载&#xff08;50&#xff09;非线性灰度变换 本书京东优惠购书链接&#xff1a;https://item.jd.com/14098452.html 本书CSDN独家连载专栏&#xff1a;https://blog.csdn.net/youcans/category_12418787.html 第 7 章 图像的灰度变换 灰度变…

C# AES-128-CBC 加密

一、加密 /// <summary>/// 加密/// </summary>public static string AesEncrypt(string toEncrypt){byte[] toEncryptArray UTF8Encoding.UTF8.GetBytes(toEncrypt);byte[] keyArray UTF8Encoding.UTF8.GetBytes(Key);//注意编码格式(utf8编码 UTF8Encoding)byt…

Unity | 渡鸦避难所-0 | 创建 URP 项目并导入商店资源

0 前言 知识点零零碎碎&#xff0c;没有目标&#xff0c;所以&#xff0c;一起做游戏吧 各位老师如果有什么指点、批评、漫骂、想法、建议、疑惑等&#xff0c;欢迎留言&#xff0c;一起学习 1 创建 3D&#xff08;URP&#xff09;项目 在 Unity Hub 中点击新项目&#xff…

【ESP32】手势识别实现笔记:红外温度阵列 | 双三次插值 | 神经网络 | TensorFlow | ESP-DL

目录 一、开发环境搭建与新建工程模板1.1、开发环境搭建与卸载1.2、新建工程目录1.3、自定义组件 二、驱动移植与应用开发2.1、I2C驱动移植与AMG8833应用开发2.2、SPI驱动移植与LCD应用开发2.3、绘制温度云图2.4、启用PSRAM&#xff08;可选&#xff09;2.5、画面动静和距离检测…

SSM框架详解:结构创建与注解应用

文章目录 1. 引言2. SSM框架项目结构创建2.1 目录结构2.2 说明 3. 注解的应用3.1 Controller3.2 Service3.3 Repository3.4 Autowired3.5 RequestMapping3.6 Select、Insert等 4. 结语 &#x1f388;个人主页&#xff1a;程序员 小侯 &#x1f390;CSDN新晋作者 &#x1f389;欢…

专业级音频处理 Logic Pro X 中文 for Mac

Logic Pro X是一款专业音频制作和音乐创作软件。它是Mac电脑上最受欢迎和广泛使用的音频工作站&#xff08;DAW&#xff09;。Logic Pro X提供了丰富的功能和工具&#xff0c;适用于音乐制作、录音、编辑、混音和音频处理等方面。以下是Logic Pro X软件的一些主要特点和功能&am…

Fabric.js 入门指南

Fabric.js 入门指南 1. 简介 Fabric.js 是一个强大的开源库&#xff0c;用于处理 HTML5 canvas。它提供了丰富的 API 和功能&#xff0c;使得在网页上轻松创建交互性图形应用变得更加容易。 2. 安装 你可以通过不同的方式安装 Fabric.js&#xff0c;具体取决于你的项目需求…

怎么取消苹果订阅自动续费?分享3个可行方法!

在日常生活中&#xff0c;我们经常会使用到各种应用程序或服务&#xff0c;其中很多都提供了订阅自动续费的功能。然而&#xff0c;有时候用户可能会忘记取消订阅&#xff0c;从而导致不必要的扣费&#xff0c;给用户带来麻烦和困扰。 那么&#xff0c;对于使用苹果手机的小伙…

【JUC】十八、happens-before先行发生原则

文章目录 1、先行发生原则happens-before2、happens-before总原则3、8条happens-before规则4、案例 1、先行发生原则happens-before 在Java中&#xff0c;Happends-Before本质上是规定了一种可见性&#xff0c; A Happends-Before B&#xff0c;则A发生过的事情对B来说是可见的…

Discuz论坛自动采集发布软件

随着网络时代的不断发展&#xff0c;Discuz论坛作为一个具有广泛用户基础的开源论坛系统&#xff0c;其采集全网文章的技术也日益受到关注。在这篇文章中&#xff0c;我们将专心分享通过输入关键词实现Discuz论坛的全网文章采集&#xff0c;同时探讨采集过程中伪原创的发布方法…

企业微信hook接口调用,批量消息id转发

简要描述 批量消息id转发 操作码 101029 请求示例 { "type": 101029, "data": { "sendId": [ "78813025xxx38" ], "msg_id": "1119934", "msg_type": 23, "syncKey": "1680696363&q…