百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 热门文章 > 正文

代码管理-3-git常规使用 git运行代码

bigegpt 2024-10-29 13:00 7 浏览

Git常规使用

git init    把当前所在目录变成git工作目录
git config  
    ‐‐global       使用全局配置文件
    ‐‐system       使用系统级配置文件
    ‐‐local        使用版本库级配置文件
[root@tyschool1 ~]# git config --global user.name "hello"
#定义git用户
[root@tyschool1 ~]# git config --global user.email "hello@localhost
#定义git使用的邮箱
[root@tyschool1 ~]# git config --global color.ui true
#定义语法高亮
[root@tyschool1 ~]# git config --list
user.name=hello
user.email=hello@localhost
color.ui=true
#查看定义的信息

**1.增**
1.git config --global --add configName configValue
解释:给指定的级别的指定config增加一个值
示例:
[root@tyschool1 git_data]# git config --global --add user.name test
[root@tyschool1 git_data]# git config --global --list
user.name=hello
user.email=hello@localhost
user.name=test
color.ui=true


**2.删**
git config --global --unset configName  (只针对存在唯一值的情况)
为了测试先增加一个
[root@tyschool1 git_data]# git config --global --add alias.test "aaaaa"
[root@tyschool1 git_data]# git config --global --list
user.name=hello
user.email=hello@localhost
user.name=test
color.ui=true
alias.test=aaaaa

删除这个唯一值,查看效果
[root@tyschool1 git_data]# git config --global --unset alias.test 
[root@tyschool1 git_data]# git config --global --list
user.name=hello
user.email=hello@localhost
user.name=test
color.ui=true


 

**3.改**
git config --global configName configValue
[root@tyschool1 git_data]# git config --global --list
user.name=hello
user.email=hello@localhost
user.name=test
color.ui=true
[root@tyschool1 git_data]# git config --global user.name aaa
warning: user.name 有多个取值
error: 无法用一个值覆盖多个值
       使用一个正则表达式、--add 或 --replace-all 来修改 user.name。
[root@tyschool1 git_data]# git config --global --replace-all user.name aaa
[root@tyschool1 git_data]# git config --global --list
user.email=hello@localhost
user.name=aaa
color.ui=true

 

**4.查**
git config --global configName
查询指定级别下: 实际生效的配置值
[root@tyschool1 git_data]# git config --global user.name 
aaa

git提交数据及状态

创建数据-提交数据



本地仓库可以理解为工作目录下.git/objects

git流程:先git add把新文件提交到暂存区-->再git commit 存到仓库,最后使用git push提交到远程仓库;使用git clone/git pull将数据同步到本地仓库,再使用相关命令进行操作

git四种状态



untracked:未跟踪的,也就是一个文件没有被git管理、监控起来

unmodified:未修改的

modified:已修改的

staged:已暂存的

你工作目录下的每一个文件都不外乎这两种状态:已跟踪 或 未跟踪。 已跟踪的文件是指那些被纳入了版本控制的文件,在上一次快照中有它们的记录,在工作一段时间后, 它们的状态可能是未修改,已修改或已放入暂存区。简而言之,已跟踪的文件就是 Git 已经知道的文件。

工作目录中除已跟踪文件外的其它所有文件都属于未跟踪文件,它们既不存在于上次快照的记录中,也没有被放 入暂存区。 初次克隆某个仓库的时候,工作目录中的所有文件都属于已跟踪文件,并处于未修改状态,因为 Git 刚刚检出了它们, 而你尚未编辑过它们。

编辑过某些文件之后,由于自上次提交后你对它们做了修改,Git 将它们标记为已修改文件。 在工作时,你可以 选择性地将这些修改过的文件放入暂存区,然后提交所有已暂存的修改,如此反复。

检查当前文件状态

我们可以使用git status检查文件的状态

[root@tyschool2 git]# git status 
位于分支 master
尚无提交
无文件要提交(创建/拷贝文件并使用 "git add" 建立跟踪)

#这说明你现在的工作目录相当干净。换句话说,所有已跟踪文件在上次提交后都未被更改过。 此外,上面的信 息还表明,当前目录下没有出现任何处于未跟踪状态的新文件,否则 Git 会在这里列出来。

在项目下创建一个新的 README 文件。 如果之前并不存在这个文件,使用 git status 命令,你将看到一个新的未跟踪文件:

[root@tyschool2 git]# echo test > README
[root@tyschool2 git]# git status 
位于分支 master
尚无提交
未跟踪的文件:
  (使用 "git add <文件>..." 以包含要提交的内容)
    README
提交为空,但是存在尚未跟踪的文件(使用 "git add" 建立跟踪)

在状态报告中可以看到新建的 README 文件出现在 “未跟踪的文件” 下面。 未跟踪的文件意味着 Git 在之前 的快照(提交)中没有这些文件;Git 不会自动将之纳入跟踪范围,除非你明明白白地告诉它“我需要跟踪该文件”。

跟踪新文件

[root@tyschool2 git]# git add README 
[root@tyschool2 git]# git status
位于分支 master
尚无提交
要提交的变更:
  (使用 "git rm --cached <文件>..." 以取消暂存)
    新文件:   README

只要在 Changes to be committed 或者“要提交的变更”这行下面的,就说明是已暂存状态。 如果此时提交,那么该文件在你运 行git add时的版本将被留存在后续的历史记录中。

暂存已修改的文件

[root@tyschool2 git]# echo aaa >> README 
[root@tyschool2 git]# git status
位于分支 master
尚无提交
要提交的变更:
  (使用 "git rm --cached <文件>..." 以取消暂存)
    新文件:   README
尚未暂存以备提交的变更:
  (使用 "git add <文件>..." 更新要提交的内容)
  (使用 "git checkout -- <文件>..." 丢弃工作区的改动)
    修改:     README

现在我们来修改一个已被跟踪的文件。出现在Changes not staged for commit或者“尚未暂存以备提交的变更”这行下面,说明已跟踪文件的内容发生了变化,但还没有放到暂存区。 要暂存这次更新,需要运行 git add 命令。 这是个多功能命令:可以用它开 始跟踪新文件,或者把已跟踪的文件放到暂存区,还能用于合并时把有冲突的文件标记为已解决状态等。再次使用git status -s查看

[root@tyschool2 git]# git status -s
A  README
################
??  新添加的未跟踪文件
A   新添加到暂存区中的文件
M   修改过的文件

git的增删改查操作

git的提交流程

git的数据状态

重点:git的基本操作,git的提交流程,git的数据状态分类

难点:理解git基本操作命令,理解git数据的提交流程及状态


3分钟了解计算机发展历史-组团学

相关推荐

悠悠万事,吃饭为大(悠悠万事吃饭为大,什么意思)

新媒体编辑:杜岷赵蕾初审:程秀娟审核:汤小俊审签:周星...

高铁扒门事件升级版!婚宴上‘冲喜’老人团:我们抢的是社会资源

凌晨两点改方案时,突然收到婚庆团队发来的视频——胶东某酒店宴会厅,三个穿大红棉袄的中年妇女跟敢死队似的往前冲,眼瞅着就要扑到新娘的高额钻石项链上。要不是门口小伙及时阻拦,这婚礼造型团队熬了三个月的方案...

微服务架构实战:商家管理后台与sso设计,SSO客户端设计

SSO客户端设计下面通过模块merchant-security对SSO客户端安全认证部分的实现进行封装,以便各个接入SSO的客户端应用进行引用。安全认证的项目管理配置SSO客户端安全认证的项目管理使...

还在为 Spring Boot 配置类加载机制困惑?一文为你彻底解惑

在当今微服务架构盛行、项目复杂度不断攀升的开发环境下,SpringBoot作为Java后端开发的主流框架,无疑是我们手中的得力武器。然而,当我们在享受其自动配置带来的便捷时,是否曾被配置类加载...

Seata源码—6.Seata AT模式的数据源代理二

大纲1.Seata的Resource资源接口源码2.Seata数据源连接池代理的实现源码3.Client向Server发起注册RM的源码4.Client向Server注册RM时的交互源码5.数据源连接...

30分钟了解K8S(30分钟了解微积分)

微服务演进方向o面向分布式设计(Distribution):容器、微服务、API驱动的开发;o面向配置设计(Configuration):一个镜像,多个环境配置;o面向韧性设计(Resista...

SpringBoot条件化配置(@Conditional)全面解析与实战指南

一、条件化配置基础概念1.1什么是条件化配置条件化配置是Spring框架提供的一种基于特定条件来决定是否注册Bean或加载配置的机制。在SpringBoot中,这一机制通过@Conditional...

一招解决所有依赖冲突(克服依赖)

背景介绍最近遇到了这样一个问题,我们有一个jar包common-tool,作为基础工具包,被各个项目在引用。突然某一天发现日志很多报错。一看是NoSuchMethodError,意思是Dis...

你读过Mybatis的源码?说说它用到了几种设计模式

学习设计模式时,很多人都有类似的困扰——明明概念背得滚瓜烂熟,一到写代码就完全想不起来怎么用。就像学了一堆游泳技巧,却从没下过水实践,很难真正掌握。其实理解一个知识点,就像看立体模型,单角度观察总...

golang对接阿里云私有Bucket上传图片、授权访问图片

1、为什么要设置私有bucket公共读写:互联网上任何用户都可以对该Bucket内的文件进行访问,并且向该Bucket写入数据。这有可能造成您数据的外泄以及费用激增,若被人恶意写入违法信息还可...

spring中的资源的加载(spring加载原理)

最近在网上看到有人问@ContextConfiguration("classpath:/bean.xml")中除了classpath这种还有其他的写法么,看他的意思是想从本地文件...

Android资源使用(android资源文件)

Android资源管理机制在Android的开发中,需要使用到各式各样的资源,这些资源往往是一些静态资源,比如位图,颜色,布局定义,用户界面使用到的字符串,动画等。这些资源统统放在项目的res/独立子...

如何深度理解mybatis?(如何深度理解康乐服务质量管理的5个维度)

深度自定义mybatis回顾mybatis的操作的核心步骤编写核心类SqlSessionFacotryBuild进行解析配置文件深度分析解析SqlSessionFacotryBuild干的核心工作编写...

@Autowired与@Resource原理知识点详解

springIOCAOP的不多做赘述了,说下IOC:SpringIOC解决的是对象管理和对象依赖的问题,IOC容器可以理解为一个对象工厂,我们都把该对象交给工厂,工厂管理这些对象的创建以及依赖关系...

java的redis连接工具篇(java redis client)

在Java里,有不少用于连接Redis的工具,下面为你介绍一些主流的工具及其特点:JedisJedis是Redis官方推荐的Java连接工具,它提供了全面的Redis命令支持,且...