版本控制之Coding.net Git

简介: 版本控制之Coding.net Git


coding.net: https://coding.net/login

一、Git 忽略一些文件不加入版本控制

      在git中如果想忽略掉某个文件,不让这个文件提交到版本库中,可以使用修改 .gitignore 文件的方法。这个文件每一行保存了一个匹配的规则例如:
    (注:#此为注释,将被 Git 忽略)

*.a # 忽略所有 .a 结尾的文件
!lib.a # 但 lib.a 除外
/TODO # 仅仅忽略项目根目录下的 TODO 文件,不包括 subdir/TODO
build/ # 忽略 build/ 目录下的所有文件
doc/*.txt # 会忽略 doc/notes.txt 但不包括 doc/server/arch.txt

      这样设置了以后 所有的 .pyc 文件都不会添加到版本库中去。
      另外 git 提供了一个全局的 .gitignore,你可以在你的用户目录下创建 ~/.gitignoreglobal 文件,以同样的规则来划定哪些文件是不需要版本控制的。
       需要执行 git config --global core.excludesfile ~/.gitignoreglobal来使得它生效。
其他的一些过滤条件

  • ?:代表任意的一个字符
  • *:代表任意数目的字符
  • {!ab}:必须不是此类型
  • {ab,bb,cx}:代表ab,bb,cx中任一类型即可
  • [abc]:代表a,b,c中任一字符即可
  • [ ^abc]:代表必须不是a,b,c中任一字符

       由于git不会加入空目录,所以下面做法会导致tmp不会存在 tmp/*             //忽略tmp文件夹所有文件
       改下方法,在tmp下也加一个.gitignore,内容为

  *
  !.gitignore

      还有一种情况,就是已经commit了,再加入gitignore是无效的,所以需要删除下缓存      

git rm -r --cached ignore_file
      注意: .gitignore只能忽略那些原来没有被track的文件,如果某些文件已经被纳入了版本管理中,则修改.gitignore是无效的。
      正确的做法是在每个clone下来的仓库中手动设置不要检查特定文件的更改情况。      

git update-index --assume-unchanged PATH #在PATH处输入要忽略的文件。
      另外 git 还提供了另一种 exclude 的方式来做同样的事情,不同的是 .gitignore 这个文件本身会提交到版本库中去。用来保存的是公共的需要排除的文件。而 .git/info/exclude 这里设置的则是你自己本地需要排除的文件。 他不会影响到其他人。也不会提交到版本库中去。
      .gitignore 还有个有意思的小功能, 一个空的 .gitignore 文件 可以当作是一个 placeholder 。当你需要为项目创建一个空的 log 目录时, 这就变的很有用。 你可以创建一个 log 目录 在里面放置一个空的 .gitignore 文件。这样当你 clone 这个 repo 的时候 git 会自动的创建好一个空的 log 目录了。

二、Git 服务器提交材料及其常用命令
 1、向Git服务器提交材料
       服务器建立好一个空的版本库(需管理服务器的人创建)后,要想服务器提交源代码,主要步骤须做如下:
    a)递归刪除指定目录下的.git文件    

find . -name .git | xargs rm -fr
    b)递归刪除指定目录下的.gitignore文件  

find . -name .gitignore | xargs rm -fr
    c)git clonehttp://yourname@192.168.1.xxx:xxx/git/xxx //克隆版本库
        会有如下提示:       

正克隆到 'xxx'...
warning: 您似乎克隆了一个空版本库。
    d)git add *    //把所有文件加入版本控制
    e)git commit  //本地提交
         //第一次用git push直接push会报错,应该先用git push origin master ,以后直接用git push就行
    f)git push  //推到服务器
        会有如下提示:

Password for 'http://yourname@192.168.1.xxx:xxx':
No refs in common and none specified; doing nothing.
Perhaps you should specify a branch such as 'master'.
Everything up-to-date
    g)git push origin master  //把本地master分支推送到远程服务器origin,.git隐藏目录下的config文件可以看得到这些信息。
       会有如下提示:       

Password for 'http://wuzhifeng@192.168.1.xxx:xxx':
Everything up-to-date
 2、Git常用命令
       以下是一些我自己常用到的git命令:

git clone :从服务器上克隆代码;
git pull :从服务器上拉取最新代码(需在原有版本上,即电脑上存在该系统版本);
git branch -a :查看系统分支相关信息;
git checkout *:切换分支;
git log :查看该系统版本里修改的相关信息;
git show ID(git log上显示的数字信息):可以查看该ID的补丁详细信息;

......

3、gitignore(对于较大的系统一定需忽略生成的文件)
     定义:在版本控制服务器上忽略某些指定的文件。
    编写方式:

*~
*.swp
./kernel/
*.swo
*.bak
out/
/version.sh

三、exclude

git 还提供了另一种 exclude 的方式来完成同样的忽略

不同的是 .gitignore 这个文件本身会push到库中去。保存的是公共的需要排除的文件。

而exclude 是自己本地忽略的设置,不会影响到其他人,也不会提交到库中去。

exclude 文件所在位置:.git/info/exclude 
可以在项目文件路径下,使用下列命令
vim .git/info/exclude  

然后再#号下的一行写入要忽略的文件  

如:  

*.o

目录
相关文章
|
5天前
|
存储 开发工具 数据安全/隐私保护
「Mac畅玩鸿蒙与硬件9」鸿蒙开发环境配置篇9 - 使用 Git 进行版本控制
在 HarmonyOS 项目开发中,Git 版本控制可以帮助开发者规范地管理代码变更,确保协作流程顺畅。本篇将详细介绍从创建项目、提交代码到 Git 远程仓库,再到修改、推送更新的完整操作流程,重点演示如何使用 Git 和 GitHub 进行身份验证和版本管理。
34 3
「Mac畅玩鸿蒙与硬件9」鸿蒙开发环境配置篇9 - 使用 Git 进行版本控制
|
1月前
|
Linux 开发工具 git
掌握 Git:版本控制的艺术
Git 是由 Linus Torvalds 开发的分布式版本控制系统,广泛用于代码管理和团队协作。其核心价值在于分布式特性、数据完整性和支持非线性开发。本文介绍 Git 的安装、仓库初始化、文件管理、分支管理、远程仓库操作及撤销操作等基础与高级技巧,助你掌握版本控制的艺术。通过实践,你将能更高效地利用 Git 进行代码管理和团队协作。
|
8天前
|
Ubuntu 开发工具 git
Git高手必备:掌握这些版本控制最佳实践,让你的代码管理效率翻倍!
【10月更文挑战第25天】使用 Git 进行版本控制是现代软件开发的重要部分。本文详细介绍了 Git 的安装、配置、基本操作、分支管理、冲突解决及常用命令,帮助开发者提高工作效率,确保代码质量和团队协作的顺利进行。通过合理使用 Git,可以有效管理代码变更,支持多人协作,并追踪历史记录。
30 4
|
8天前
|
开发工具 C# git
C#一分钟浅谈:Git 版本控制与 GitFlow 工作流
【10月更文挑战第22天】本文介绍了 Git 和 GitFlow 的结合使用,从基础概念到具体操作,涵盖了安装配置、基本命令、GitFlow 工作流的核心分支和流程示例。同时,文章还讨论了常见的问题和易错点,如忽略文件、冲突解决、回退提交和分支命名规范,并提供了代码案例。通过学习本文,读者可以更好地理解和应用 Git 及 GitFlow,提高团队协作效率。
37 1
|
2月前
|
存储 Linux 开发工具
掌握版本控制的艺术:Git 技巧深度解析
在软件开发中,版本控制对于代码管理和团队协作至关重要。Git 作为最流行的分布式版本控制系统,凭借其强大的功能和灵活性成为开发者必备工具。本文深入探讨 Git 的高级技巧和最佳实践,包括交互式暂存、撤销提交、合并冲突处理等,帮助你更高效地使用 Git。通过遵循清晰的提交信息、保持提交原子性、利用分支开发等最佳实践,开发者可以更好地管理代码库,提升协作效率。
|
25天前
|
存储 数据可视化 开发工具
2款.NET开源且免费的Git可视化管理工具
2款.NET开源且免费的Git可视化管理工具
|
8天前
|
开发工具 git 开发者
|
1月前
|
编译器 开发工具 数据安全/隐私保护
Git——多人协作/版本控制,在一个gitee仓库下开发(Gitee版教程)手把手教学,包好用的!
本文提供了一个关于如何在Gitee上进行多人协作和版本控制的详细教程,包括新建和初始化仓库、克隆仓库、邀请好友共同管理仓库以及注意事项,旨在帮助用户顺利进行代码协作开发。
108 0
Git——多人协作/版本控制,在一个gitee仓库下开发(Gitee版教程)手把手教学,包好用的!
|
2月前
|
安全 开发工具 git
git合并错了,我想回退到之前的版本
git合并错了,我想回退到之前的版本
|
2月前
|
存储 Linux 开发工具
掌握 Git:版本控制的瑞士军刀
在软件开发中,版本控制对于代码管理和团队协作至关重要。Git 是一款由 Linus Torvalds 开发的分布式版本控制系统,广泛应用于各类项目。本文介绍了 Git 的基本原理、核心概念及常用命令,如初始化仓库 (`git init`)、克隆 (`git clone`)、提交 (`git commit`) 和合并 (`git merge`) 等。此外,还分享了编写清晰提交信息、使用分支开发和定期合并等最佳实践,帮助开发者更高效地使用 Git。

相关实验场景

更多