服务器之家:专注于服务器技术及软件下载分享
分类导航

Linux|Centos|Ubuntu|系统进程|Fedora|注册表|Bios|Solaris|Windows7|Windows10|Windows11|windows server|

服务器之家 - 服务器系统 - Linux - Linux系统下Git的基本配置和使用示例

Linux系统下Git的基本配置和使用示例

2019-09-03 18:47cbk861110 Linux

这篇文章主要介绍了Linux系统下Git的基本配置和使用示例,由于Github的火爆使得Git成为当下绝对主流的版本控制系统,需要的朋友可以参考下

git config配置文件
一.Git已经在你的系统中了,你会做一些事情来客户化你的Git环境。你只需要做这些设置一次;即使你升级了,他们也会绑定到你的环境中。你也可以在任何时刻通过运行命令来重新更改这些设置。
      Git有一个工具被称为git config,它允许你获得和设置配置变量;这些变量可以控制Git的外观和操作的各个方面。这些变量可以被存储在三个不同的位置: 
  1./etc/gitconfig 文件:包含了适用于系统所有用户和所有库的值。如果你传递参数选项’--system’ 给 git config,它将明确的读和写这个文件。 
  2.~/.gitconfig 文件 :具体到你的用户。你可以通过传递--global 选项使Git 读或写这个特定的文件。
  3.位于git目录的config文件 (也就是 .git/config) :无论你当前在用的库是什么,特定指向该单一的库。每个级别重写前一个级别的值。因此,在.git/config中的值覆盖了在/etc/gitconfig中的同一个值。
   在Windows系统中,Git在$HOME目录中查找.gitconfig文件(对大多数人来说,位于C:\Documents and Settings\$USER下)。它也会查找/etc/gitconfig,尽管它是相对于Msys 根目录的。这可能是你在Windows中运行安装程序时决定安装Git的任何地方。
 
二.你的标识(Your Identity)
2.1 当你安装Git后首先要做的事情是设置你的用户名称和e-mail地址。这是非常重要的,因为每次Git提交都会使用该信息。它被永远的嵌入到了你的提交中:

复制代码

代码如下:


  $ git config --global user.name "John Doe"
  $ git config --global user.email johndoe@example.com


   重申一遍,你只需要做一次这个设置。如果你传递了 --global 选项,因为Git将总是会使用该信息来处理你在系统中所做的一切操作。如果你希望在一个特定的项目中使用不同的名称或e-mail地址,你可以在该项目中运行该命令而不要--global选项。
 
2.2 你的编辑器(Your Editor)
  现在,你的标识已经设置,你可以配置你的缺省文本编辑器,Git在需要你输入一些消息时会使用该文本编辑器。缺省情况下,Git使用你的系统的缺省编辑器,这通常可能是vi 或者 vim。如果你想使用一个不同的文本编辑器,例如Emacs,你可以做如下操作:

复制代码

代码如下:


  $ git config --global core.editor emacs


 
2.3 你的比较工具(Your Diff Tool)
  另外一个你可能需要配置的有用的选项是缺省的比较工具它用来解决合并时的冲突。例如,你想使用vimdiff:

复制代码

代码如下:


  $ git config --global merge.tool vimdiff


   Git可以接受kdiff3, tkdiff, meld, xxdiff, emerge, vimdiff, gvimdiff, ecmerge, 和 opendiff作为有效的合并工具。你也可以设置一个客户化的工具;查看第7章获得更多关于此的信息。
 
2.4 检查你的设置(Checking Your Settings)
  如果你想检查你的设置,你可以使用 git config --list 命令来列出Git可以在该处找到的所有的设置:

复制代码

代码如下:


  $ git config --list
  user.name=Scott Chacon
  user.email=schacon@gmail.com
  color.status=auto
  color.branch=auto
  color.interactive=auto
  color.diff=auto
  ...


 
  你可能会看到一个关键字出现多次,这是因为Git从不同的文件中(例如:/etc/gitconfig以及~/.gitconfig)读取相同的关键字。 在这种情况下,对每个唯一的关键字,Git使用最后的那个值。 
  你也可以查看Git认为的一个特定的关键字目前的值,使用如下命令 git config {key}:

复制代码

代码如下:

  $ git config user.name
  Scott Chacon


 
2.5 获取帮助(Getting help)
  如果当你在使用Git时需要帮助,有三种方法可以获得任何git命令的手册页(manpage)帮助信息:

复制代码

代码如下:


  $ git help <verb>
  $ git <verb> --help
  $ man git-<verb>


   例如,你可以运行如下命令获取对config命令的手册页帮助:

复制代码

代码如下:


  $ git help config


   这些命令非常友好,因为你可以在任何地方存取他们,即使非在线状态。如果手册页和本书仍然不足而你需要个人的帮助,你可以试着使用Freenode IRCServer上的#git或#github 频道(irc.freenode.net)。这些频道会定期由数百个对Git非常熟悉的专业人士所维护,他们会非常乐意帮助你。
 
2.6 总结(Summary)
  你应该对Git是什么以及Git与你可能使用的其它CVCS之间的不同有了一个基本的了解。你也应当在你的系统中有了一个具有你个人标识的可以工作的Git版本。是时候来学习一些Git的基本知识了。

 


git 实际使用记录
1、git 提交代码错误实例分析
 

复制代码

代码如下:


$ git push origin master

 

复制代码

代码如下:


To git@192.168.1.3:k6.git


! [rejected] master -> master (non-fast-forward)  
error: failed to push some refs to 'git@192.168.1.3:k6.git'  
To prevent you from losing history, non-fast-forward updates were rejected  
Merge the remote changes before pushing again. See the 'Note about  
fast-forwards' section of 'git push --help' for details.  
cbk@YCS:~/work/k6_130708/k6$ git fecth  
git: 'fecth' is not a git command. See 'git --help'.  
git push 错误,因为没有先pull最新的代码,需要以下操作:

 

 

复制代码

代码如下:


$ git fetch origin 
$ git merge origin/master 
$ git push origin master

 

如果安装git后没有设置你的用户名称和e-mail地址,还需要先执行:
 

复制代码

代码如下:


$ git config --global user.name "cbk" 
$ git config --global user.email <a target=_blank target="_blank" href="mailto:cbk@ylf.com">cbk@ylf.com</a>


这是非常重要的,因为每次Git提交都会使用该信息。它被永远的嵌入到了你的提交中:
重申一遍,你只需要做一次这个设置。如果你传递了 --global 选项,因为Git将总是会使用该信息来处理你在系统中所做的一切操作。如果你希望在一个特定的项目中使用不同的名称或e-mail地址,你可以在该项目中运行该命令而不要--global选项。

 

具体到此问题,如果没有设置你的用户名称和e-mail地址,则一直正确无法push代码。

 

2、Git 跟踪一个文件的提交历史记录
在跟踪Android代码是,有时候发现某个关键文件被改动了,需要跟踪查看对这个关键文件的所有commit的记录,以便理解其中的修改原因和过程:

复制代码

代码如下:


git log -p “file name”

 

显示这个文件的每一行的最后提交commit,方便定位commit:

复制代码

代码如下:


git blame “file name"

 


显示log详细修改记录:
git show [log_id_num],例如:

复制代码

代码如下:


git show 75704c8543b033619a80439ddb0fd69cc7cb172c

 


3、git初始化之git config
1). 下面的命令将修改/home/[username]/.gitconfig文件,也就是说下面的配置只对每一个ssh的用户可见,所以每个人都需要做。
提交代码的log里面会显示提交者的信息

复制代码

代码如下:


git config --global user.name [username]
git config --global user.email [email]

 

在git命令中开启颜色显示

复制代码

代码如下:


git config --global color.ui true

 

2). 下面的命令将修改/etc/gitconfig文件,这是全局配置,所以admin来做一次就可以了。 
 配置一些git的常用命令alias

复制代码

代码如下:


sudo git config --system alias.st status #git st
sudo git config --system alias.ci commit #git commit
sudo git config --system alias.co checkout #git co
sudo git config --system alias.br branch #git branch

 

3). 也可以进入工作根目录,运行git config -e,这样就只会修改工作区的.git/config文件,但是暂时还用不着.
git config文件的override顺序是3)>1)>2).


4.版本回退
 

复制代码

代码如下:


git reset --hard commit_id

 

复制代码

代码如下:


git checkout commit_id

 

复制代码

代码如下:


git clean –df commit_id

延伸 · 阅读

精彩推荐
  • LinuxLinux lnmp下无法使用mail发邮件的两种解决方法

    Linux lnmp下无法使用mail发邮件的两种解决方法

    在配置了lnmp环境后,出现了mail函数不能发送邮件的问题,其实有两种方法,一是使用sendmail组件,而是使用postfix。下面为大家一一介绍下 ...

    Linux之家4042019-09-17
  • Linuxlinux中rmdir命令使用详解(删除空目录)

    linux中rmdir命令使用详解(删除空目录)

    今天学习一下linux中命令: rmdir命令。rmdir是常用的命令,该命令的功能是删除空目录,一个目录被删除之前必须是空的 ...

    linux命令大全5372019-11-19
  • LinuxLinux上设置用户通过SFTP访问目录的权限的方法

    Linux上设置用户通过SFTP访问目录的权限的方法

    这篇文章主要介绍了Linux上设置用户通过SFTP访问目录的权限的方法,SFTP可以理解为使用SSH协议进行FTP传输的协议,因而同时要对OpenSSH进行相关设置,需要的朋...

    OSChina10022019-06-19
  • Linux手把手教您在 Linux 上使用 GPG 加解密文件

    手把手教您在 Linux 上使用 GPG 加解密文件

    在本教程中,我将告诉你如何用 GPG 加密和解密文件。这是一个简单的教程,你可以在你的 Linux 系统上尝试所有的练习。这将帮助你练习 GPG 命令,并在你...

    Linux中国6962021-12-15
  • LinuxLinux中环境变量配置的步骤详解

    Linux中环境变量配置的步骤详解

    Linux中环境变量包括系统级和用户级,系统级的环境变量是每个登录到系统的用户都要读取的系统变量,而用户级的环境变量则是该用户使用系统时加载的...

    Myths7882022-02-10
  • LinuxLinux常用的日志文件和常用命令

    Linux常用的日志文件和常用命令

    成功地管理任何系统的关键之一,是要知道系统中正在发生什么事。 Linux 中提供了异常日志,并且日志的细节是可配置的。Linux 日志都以明文形式存储,所...

    Linux教程网2632020-04-18
  • Linux确保Linux系统安全的前提条件 漏洞防护

    确保Linux系统安全的前提条件 漏洞防护

    Linux 作为开放式的操作系统受到很多程序员的喜爱,很多高级程序员都喜欢编写Linux操作系统的相关软件。这使得Linux操作系统有着丰富的软件支持,还有无...

    Linux之家2642020-04-11
  • Linux详解Linux系统下PXE服务器的部署过程

    详解Linux系统下PXE服务器的部署过程

    这篇文章主要介绍了Linux系统下PXE服务器的部署过程,包括对PXE的API架构作了一个基本的简介,需要的朋友可以参考下...

    运维之道9812019-07-04