`
saiyaren
  • 浏览: 228705 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

git使用 原创-胡志广

    博客分类:
  • git
阅读更多

1.  Git 克隆代码

git clone git://github.com/facebook/hiphop-php.git

2.  Git更新分支

查看服务器上的所有分支

[huzg@slave3 hiphop-php]git branch –r

输出结果:

origin/HEAD -> origin/master

 origin/HPHP-2.0

  origin/a832f349d8caf0de8c7df671d03c90a5e078fb53

 origin/master

查看当前有效分支:

[huzg@slave3 hiphop-php]git branch

* master

 

更新 HPHP-2.0分支:

[huzg@slave3 hiphop-php]$ git checkout -b HPHP-2.0

输出结果如下:已经选择HPHP-2.0分支了,如果已经有该分支就不用-b了,-b是先建分支

Switched to a new branch 'HPHP-2.0'

查看当前有效分支,此时有效分支变为:HPHP-2.0

[huzg@slave3 hiphop-php]$ git branch

* HPHP-2.0

  Master

 

Git 更详细操作见:

http://blog.csdn.net/linuxdriverdeveloper/article/details/7321485

http://xxw8393.blog.163.com/blog/static/37256834201010309569903/

 

3.  git错误处理

3.1.  fatal: Not a git repository (or any of the parent directories): .git解决方法

fatal: Not a git repository (or any of the parentdirectories): .git

 

是由于git没有进入到目录中

 

3.2.  The file will have its original line endings in your workingdirectory. 解决方法

The file will have its original line endings inyour working directory.

当报这个警告时是由于文件夹远程不存在,但是不影响提交

4.  打标签(tag)

4.1.  查看当前标签状态

git tag

例子:

D:\git_programs\hiphop_extension>git tag

0.1.3

4.2.  创建标签

git tag -a ice-1.0 0d0fc38441  -m "ice hhvm 1.0"

解释:

-a ice -a是创建 ice是名称

0d0fc38441 这个是你commitID

可以通过git log获取:

也可以通过网页中的commit 获取

如果不加commit的标示,那么就是最后的,如果加了,可以在中间打上版本的标签,这个很好

-m “ice hhvm 1.0”:是描述

 

4.3.  分享提交标签到远程服务器上

git push origin master

git push origin --tags

注:

–tags 前面是2个横杠(-)

如果这里错误了会如下错误:

error: src refspec –tags does not match any.

error: failed to push some refs to'https://github.com/huzhiguang/hiphop_extensi

on.git'

 

正确后会提示:

Username for 'https://github.com': XXXXXXXX

Password for 'https://XXXXXXXXXX@github.com':

Counting objects: 1, done.

Writing objects: 100% (1/1), 166 bytes| 0 bytes/s, done.

Total 1 (delta 0), reused 0 (delta 0)

To https://github.com/huzhiguang/hiphop_extension.git

 * [new tag]         ice-1.0 -> ice-1.0

然后你去你的git上查看就会有新的了的tag版本了

注:

--tags 参数表示提交所有 tag 至服务器端,普通的 git push origin master 操作不会推送标签到服务器端。

4.4. 删除本地标签命令

git tag -d ice-1.0

执行后运行git tag可以查看是否已经删除了

4.5. 删除远程标签命令

git push origin :refs/tags/ ice-1.0

删除后:

Username for'https://github.com': xxxxx

Password for'https://xxxxxx@github.com':

Tohttps://github.com/huzhiguang/hiphop_extension.git

 - [deleted]         ice-1.0

这表示远程的已经删除了

 

:refs/tags/ ice-1.0

红色部分表示tag名称

 

参考:

http://www.iteye.com/topic/1126153

 

 

5.  git操作

参考:

http://rogerdudler.github.io/git-guide/index.zh.html

5.1.  创建git仓库

创建新文件夹,打开,然后执行

git init

以创建新的 git 仓库。

5.2.  检出仓库

执行如下命令以创建一个本地仓库的克隆版本:

git clone /path/to/repository

如果是远端服务器上的仓库,你的命令会是这个样子:

git clone username@host:/path/to/repository

 

例子:

git clone https://github.com/huzhiguang/hiphop_extension.git

 

这里需要用https的,否则你提交等操作无法进行

 

5.3.  工作原理

你的本地仓库由 git 维护的三棵“树”组成。第一个是你的工作目录,它持有实际文件;第二个是缓存区(Index),它像个缓存区域,临时保存你的改动;最后是 HEAD,指向你最近一次提交后的结果。

 

http://rogerdudler.github.io/git-guide/img/trees.png

 

5.4.  添加、提交与推送

5.4.1.  添加到缓存区

你可以计划改动(把它们添加到缓存区),使用如下命令:

git add <filename>

git add *

这是 git 基本工作流程的第一步;使用如下命令以实际提交改动:

git commit -m "代码提交信息"

现在,你的改动已经提交到了 HEAD,但是还没到你的远端仓库。

 

例子:

git add a.php

git commit –m “test a.php”

 

这时只是把代码提交到了本地缓存

 

5.4.2.  推送改动

你的改动现在已经在本地仓库的 HEAD 中了。执行如下命令以将这些改动提交到远端仓库:

git push origin master

可以把 master 换成你想要推送的任何分支。

 

如果你还没有克隆现有仓库,并欲将你的仓库连接到某个远程服务器,你可以使用如下命令添加:

git remote add origin <server>

如此你就能够将你的改动推送到所添加的服务器上去了。

 

在你当前的分支下:

git branch 查看,可以通过gitcheckout ice切换(如果你有多个的话,默认是master

 

例子:

git push origin master

推送到master

git push origin ice推送到ice 分支上

 

这时你去你的git上查看,就可以看到已经上传到远程服务器的内容了

 

5.5.  分支

创建一个叫做“feature_x”的分支,并切换过去:

git checkout -b feature_x

切换回主分支:

git checkout master

再把新建的分支删掉:

git branch -d feature_x

除非你将分支推送到远端仓库,不然该分支就是不为他人所见的:

git push origin <branch>

 

例:

git checkout –b ice (没有的时候可以用 ­–b创建)

如果存在branch,那么直接切换即可,如:

git checkout master

推送到远程仓库

git push origin master

 

 

5.6.  更新与合并

要更新你的本地仓库至最新改动,执行:

git pull

以在你的工作目录中获取(fetch合并(merge远端的改动。

要合并其他分支到你的当前分支(例如 master),执行:

git merge <branch>

两种情况下,git 都会尝试去自动合并改动。不幸的是,自动合并并非次次都能成功,并可能导致冲突(conflicts)。这时候就需要你修改这些文件来人肉合并这些冲突(conflicts了。改完之后,你需要执行如下命令以将它们标记为合并成功:

git add <filename>

在合并改动之前,也可以使用如下命令查看:

git diff <source_branch><target_branch>

 

例:

git pull 从远程获取最新改动

git merge ice

比如当前的branch master,那么就是将ice 这个分支的内容合并到master中,但是可能会发生冲突

 

 

5.7.  标签

在软件发布时创建标签,是被推荐的。这是个旧有概念,在 SVN 中也有。可以执行如下命令以创建一个叫做 1.0.0 的标签:

git tag 1.0.0 1b2e1d63ff

1b2e1d63ff 是你想要标记的提交 ID 的前 10 位字符。使用如下命令获取提交 ID

git log

你也可以用该提交 ID 的少一些的前几位,只要它是唯一的。

 

5.8.  替换本地改动

假如你做错事(自然,这是不可能的),你可以使用如下命令替换掉本地改动:

git checkout -- <filename>

此命令会使用 HEAD 中的最新内容替换掉你的工作目录中的文件。已添加到缓存区的改动,以及新文件,都不受影响。

 

假如你想要丢弃你所有的本地改动与提交,可以到服务器上获取最新的版本并将你本地主分支指向到它:

git fetch origin

 

 

 

 

5.9.  删除一个repository

点击setting

然后点击:

Click Delete this repository in the Danger Zone™area

然后弹出警告框:

你不输入项目名称时,I understand the consequences, delete this repository这个是虚的点击不了;

你需要输入名字,才可以删除;

但是删除时要谨慎;

 

 

参考:

https://help.github.com/articles/deleting-a-repository

 

5.10.    分配合作用户

首先点击setting

然后点击collaborators

 

然后输入合作者的账号,搜索出后,点击Add即可

 

5.11.    创建一个新的repositories

 

选择repositories

然后点击New

 

 

然后点击create reposltory

创建好后,会显示:

 

5.12.    删除文件

git rm php/ice/Ice.php.bak

注:rm后面需要跟上具体的路径

git commit –m “delte Ice.php.bak”

更新远程分支:

git push origin ice

 

然后上传后,更新同步本地:

git pull

 

5.13.    公司访问git访问不了

配置host

184.50.87.50 a248.e.akamai.net

5.14.    Git操作pullrequest

首先需要fork你想要进行合作的项目:

比如我fork的是hiphop那么就点击这里:

然后再你自己的git中就会fork出一个项目出来

然后你可以修改你的项目,然后点击new pull request

然后点击click to create a pull requeset for this comparsion

然后点击标题,添加内容

 

点击send pull request

 

参照了:

http://www.worldhello.net/gotgithub/04-work-with-others/010-fork-and-pull.html

 

 

5.15.    git fork 同步原服务

(1)      首先fork服务

去已经有的项目中进行fork一个项目,然后也可以进行pullrequeset,这个操作参见5.14

(2)      遇到问题

当原来的版本服务修改时,我们fork的服务就不好进行贡献代码,那么我们需要进行与远程的服务进行同步,那么下面就是同步的过程

(3)      克隆自己已经fork的服务到本地

git clone https://github.com/huzhiguang/hiphop-php.git

(4)      添加一个远程服务

git remote add upstream https://github.com/facebook/hiphop-php.git

格式:

git remote add 远程仓库名称远程仓库地址

(5)      抓取远程服务信息

git fetch upstream

格式:

git fetch 远程仓库名称

(6)      合并远程仓库信息到本地仓库中

git merge upstream/master

合并的过程中会遇到错误:

Auto-merginghphp/runtime/vm/type-profile.cpp

Auto-merginghphp/runtime/vm/type-constraint.h

Auto-merging hphp/runtime/vm/type-constraint.cpp

Auto-merginghphp/runtime/vm/runtime.cpp

CONFLICT(content): Merge conflict in hphp/runtime/vm/runtime.cpp

Auto-merginghphp/runtime/vm/repo-helpers.cpp

Auto-merginghphp/runtime/vm/php-debug.cpp

Auto-merginghphp/runtime/vm/object-allocator-sizes.cpp

Auto-merginghphp/runtime/vm/name-value-table-wrapper.h

Auto-merginghphp/runtime/vm/name-value-table-wrapper.cpp

Auto-merginghphp/runtime/vm/member-operations.h

Auto-merginghphp/runtime/vm/member-operations.cpp

Auto-merginghphp/runtime/vm/indexed-string-map.h

Auto-merginghphp/runtime/vm/fixed-string-map.cpp

Auto-merginghphp/runtime/vm/event-hook.cpp

Auto-merginghphp/runtime/vm/debugger-hook.cpp

Auto-merginghphp/runtime/vm/backup-gc.cpp

Automatic merge failed; fix conflicts and then commit the result.

上面标示的红色加粗位置提示了hphp/runtime/vm/runtime.cpp位置的文件有冲突;

 

查看该文件:

<<<<<<<HEAD

//自己的代码

   /*

      author:huzhiguang

        date:2013/7/31

        function:string_md5function don't free and have memery leak

   */

  //md5 = MD5(string_md5(s, sz, false,out_len));

   char * string_md5_char=string_md5(s, sz,false, out_len);

   md5 = MD5(string_md5_char);

   free(string_md5_char);

=======

//远程服务代码

  char * md5str = string_md5(s, sz, false,out_len);

  md5 = MD5(md5str);

  free(md5str);

>>>>>>> upstream/master

 

这里提示了冲突内容,我们将冲突的内容删除后,然后保存文件;

(7)      合并代码成功后,我们进行添加和提交代码

git add *

git commit –m “sync code”

git push origin master

(8)      同步完成后,查看远程服务中的提交会有最新的同步后的结果

(9)      pull request中如果有由于冲突的文件造成的行等小差异解决后然后提交即可

 

 

可参照:

http://lullabyus.iteye.com/blog/1499402

  • 大小: 19.6 KB
  • 大小: 46.7 KB
  • 大小: 18.2 KB
  • 大小: 18.2 KB
  • 大小: 31.5 KB
  • 大小: 26.8 KB
  • 大小: 8.1 KB
  • 大小: 4.5 KB
  • 大小: 28.1 KB
  • 大小: 59 KB
  • 大小: 53.7 KB
  • 大小: 7.5 KB
  • 大小: 20.8 KB
  • 大小: 16.7 KB
  • 大小: 42.3 KB
  • 大小: 42.5 KB
0
3
分享到:
评论
4 楼 saiyaren 2013-09-16  
貌似掉线 写道
saiyaren 写道
貌似掉线 写道
看了前面,没看下去,因为有话要说

1,git clone不是更新代码,而是克隆一个远程仓库下来。如果你后面不指定--depth的话,它会把整个远程仓库克隆到本地来。

2,git checkout 分支名 这个是切换分支

现在继续往下看,因为看到我想要找的功能。感谢分享。


更新有2种:
(1)是用checkout  
(2)是fetch和merge同步fork的

我那个写的有问题,主要是总结直接贴上去了,感谢指点问题!

在git里checkout貌似是切换分支的
更新的话,有pull,或是fetch+merge


首先需要用checkou切换到你的指定分支,然后在用pull来进行更新,但最开始都需要clone
3 楼 貌似掉线 2013-09-13  
saiyaren 写道
貌似掉线 写道
看了前面,没看下去,因为有话要说

1,git clone不是更新代码,而是克隆一个远程仓库下来。如果你后面不指定--depth的话,它会把整个远程仓库克隆到本地来。

2,git checkout 分支名 这个是切换分支

现在继续往下看,因为看到我想要找的功能。感谢分享。


更新有2种:
(1)是用checkout  
(2)是fetch和merge同步fork的

我那个写的有问题,主要是总结直接贴上去了,感谢指点问题!

在git里checkout貌似是切换分支的
更新的话,有pull,或是fetch+merge
2 楼 saiyaren 2013-09-13  
貌似掉线 写道
看了前面,没看下去,因为有话要说

1,git clone不是更新代码,而是克隆一个远程仓库下来。如果你后面不指定--depth的话,它会把整个远程仓库克隆到本地来。

2,git checkout 分支名 这个是切换分支

现在继续往下看,因为看到我想要找的功能。感谢分享。


更新有2种:
(1)是用checkout  
(2)是fetch和merge同步fork的

我那个写的有问题,主要是总结直接贴上去了,感谢指点问题!
1 楼 貌似掉线 2013-09-13  
看了前面,没看下去,因为有话要说

1,git clone不是更新代码,而是克隆一个远程仓库下来。如果你后面不指定--depth的话,它会把整个远程仓库克隆到本地来。

2,git checkout 分支名 这个是切换分支

现在继续往下看,因为看到我想要找的功能。感谢分享。

相关推荐

    Git-2.28.0-64-bit.exeGit-2.28.0-64-bit.exe

    Git-2.28.0-64-bit.exe Git-2.28.0-64-bit.exe Git-2.28.0-64-bit.exe

    Git-2.13.2-64-bit

    Git-2.13.2-64-bit是Git的一个特定版本,适用于64位操作系统。在这个版本中,Git可能包含了各种性能优化、新特性和错误修复。 1. **Git的基本概念**: - **版本控制**:Git的核心功能是版本控制,它记录了代码的每...

    Git官方最新版下载 Git-2.18.0-64-bit 64位Windows版本

    Git-2.18.0-64-bit是Git官方发布的一个针对64位Windows系统的更新版本,旨在提供更稳定、高效和功能丰富的代码管理体验。 1. Git的基本概念: - 版本控制:Git的核心功能是版本控制,它记录了代码的每一次修改,...

    Git-2.28.0-64-bit git安装包windos64位官方下载

    Git-2.28.0-64-bit.exe 是适用于Windows 64位操作系统的Git官方安装程序,该版本为2.28.0,意味着它包含了最新的功能和性能改进。 **Git基础概念** 1. **版本控制**:Git的核心功能是版本控制,它能跟踪文件和目录...

    git-2.41.0-64-bit window版本

    Git-2.41.0-64-bit window版本是针对Windows操作系统的一个特定构建,提供64位架构的支持。这个版本的发布,意味着用户可以在Windows环境下享受到Git的最新功能和性能优化。 Git的核心特性包括: 1. 分布式:每个...

    Git安装包Git-2.21.0-64-bit.zip

    Git安装包快速下载;git资源包,Git下载,Git压缩包;Git工具下载;Git-2.21.0-64-bit.zip;Git工具下载

    Git-1.9.5-preview20150319资源及安装指导

    Git是分布式版本控制系统,因其高效、灵活和开源的特性,在软件开发领域被广泛使用。Git-1.9.5-preview20150319是Git的一个特定版本,...Git-1.9.5-preview20150319的使用和配置知识是每个开发者都应该掌握的基础技能。

    Git-2.23.0-64-bit--Windows安装包.zip

    Git-2.23.0-64-bit--Windows安装包是一个专门为Windows操作系统设计的64位Git版本,它包含了所有必要的组件,使得用户可以在Windows环境下无缝地使用Git。 Git的核心功能包括: 1. 版本追踪:Git能够记录文件和...

    git-lfs-windows-v3.2.0.exe

    git-lfs-windows-v3.2.0.exe

    windows xp Git32 安装包 Git-2.10.0-32-bit

    总之,Git-2.10.0-32-bit是Windows XP用户进行版本控制的有力工具,尽管XP系统已经过时,但通过使用这个安装包,开发者仍然可以享受到Git带来的高效和便利。在使用过程中,记得定期检查更新,以获取最新的安全修复和...

    git-2.45.0-64bit.exe

    "git-2.45.0-64bit.exe" 是Git的特定版本,即2.45.0版本的64位Windows安装程序。这个文件是为Windows用户设计的,确保在64位操作系统上顺利运行Git。 Git的核心特性包括: 1. 分布式:每个开发者的本地仓库都包含...

    Git-2.30.0-64-bit.exe

    "Git-2.30.0-64-bit.exe" 是Git的Windows 64位版本的安装程序,版本号为2.30.0,表明这是Git在2021年初的一个稳定版本更新。 Git的核心特性包括: 1. 分布式:每个开发者的本地机器上都有一个完整的版本库,可以...

    Git-2.10.0-32-bit-官网版本-支持WinXp、Win2003系统最后的32位版本

    总的来说,Git-2.10.0-32-bit是那些仍在使用旧版Windows系统的开发者的重要资源,它提供了版本控制的关键功能,但同时也提醒用户注意与过时操作系统相关的安全问题。下载并安装"Git-2.10.0-32-bit.exe"文件后,用户...

    git-2.15.0-intel-universal-mavericks.dmg.zip

    "git-2.15.0-intel-universal-mavericks.dmg.zip" 是一个专门为苹果MacOS操作系统,特别是Mavericks(OS X 10.9)版本优化的Git安装包,版本号为2.15.0。 Git的版本号2.15.0代表着该软件的特定迭代,通常包含性能...

    git安装包git-2.34.0-64-bit.rar

    在安装"Git-2.34.0-64-bit.exe"时,可以选择自定义安装路径、选择是否关联文件类型以及是否在命令行中使用Git Bash。安装完成后,可以通过运行`git --version`命令验证Git是否成功安装。在实际工作中,不断实践和...

    Git-2.18.0-64-bit安装包.zip

    Git-2.18.0-64-bit安装包是专为Windows 64位操作系统设计的,确保在高性能的64位环境下运行时,Git的所有功能都能得到充分发挥。 Git的2.18.0版本是一个重要的更新,它可能包含了多项性能优化和新特性。例如,这个...

    Git-2.12.0-64-bit 64位下载

    Git-2.12.0-64-bit 64位下载

    Git-2.8.1-64-bit.rar_Git-2.8_Git-2.8.1-64-bit._git_git-2.8.1-64-

    Git-2.8.1-64-bit是Git的一个特定版本,专为64位操作系统设计,提供了强大的功能来跟踪和管理代码的变化。这个版本的发布在2016年,带来了许多性能改进和新特性,旨在提升开发人员的工作效率。 1. 分布式特性:Git...

    Git-2.21.0-64-bit.zip

    总之,Git-2.21.0-64-bit.zip包含了在Windows 64位环境下使用Git所需的所有组件,让用户能够充分利用Git的强大功能进行软件开发和协作。安装并熟悉Git对于任何开发者来说都是一项基础且重要的技能。

    Git-2.34.0-64-bit安装包

    Git-2.34.0-64-bit安装包

Global site tag (gtag.js) - Google Analytics