`
truelove12358
  • 浏览: 77704 次
  • 性别: Icon_minigender_1
  • 来自: 上海
文章分类
社区版块
存档分类
最新评论

MyEclipse 安装插件 Github安装/使用 教程

 
阅读更多

本文的目的是

1.在 Myeclipse10.7中 集成Github并使用。

选择的安装方式是:MyEclipse 中设置下文中1后,下载github与当前myeclilpse版本对应的压缩包,然后Installnewsoftware from archive。

2.在Myeclipse中使用github管理项目。

用惯了svn的同学们来用github刚开始确实不太习惯,项目管理无非4点:更新、提交、回复、处理冲突。但是github里加入了克隆分支的概念就有点复杂了。

提交:

1、team >> commit (commit窗口下要勾选push,不勾选需要继续push) ;

2、team >> push

更新:

team >> fetch from head + team >> pull

回复:

team >> reset >> hard

处理冲突:

fetch + rebase 或 fetch + merge


具体使用还是要详细研究。

GitHub详细教程http://blog.csdn.net/lishuo_os_ds/article/details/8078475#sec-1



如果你已经不满足于基础知识了,欢迎探索更高级的玩法!
1、GitCafe / Help
2、[git简明指南](git - the simple guide)墙裂推荐!漫画的形式很形象(恩我承认比我画的好看多了)

3、在线交互学习 github 的网站Learn Git Branching 这个也很好玩~

4、[GitHub自身的官方博客](The GitHub Blog · GitHub)

5、git-flow 备忘清单

入门书籍推荐:
GitHub入门与实践 (豆瓣)比较基础
Pro Git (豆瓣) 更高级的教程,很全面!

对了对了,还有阳志平老师的两篇非常全面的旧文
如何高效利用GitHub
Git与Github入门资料




1.

MyEclipse中有一个 Software and Workspace center,这东西,加载特别慢,我用10版本基本是没有可能看到这个界面。更别说在线安装插件了,如果有eclipse原来的 “installnewsoftware”菜单就好了。

其实,这个菜单还是有的,只是就隐藏起来了。如图:

将图中的classicupdate选中,就可以了。

如果没有看到Installnewsoftware,重启一下就OK。


恩,现在是想装什么都可以装了。


  


大纲

  1.git客户端安装

  2.ssh配置

  3.egit安装配置

  4.参考资料

1.egit的安装

  

  当然也可以选择在Eclipse Marketplace中搜索

有经验的朋友肯定会想到是不是可以通过Link的方式来实现插件安装,好像这个真没有

还有一个要说明的是如果使用:http://download.eclipse.org/egit/updates.来安装,则要保证您的eclipse版本是最新的,否则会安装失败

  低版本Eclipse安装EGit插件

  本人的Eclipse是3.6版本的,正好不能使用上述方式,处理方法如下

  打开http://wiki.eclipse.org/EGit/FAQ#Where_can_I_find_older_releases_of_EGit.3F

  选择<wbr><a target="_blank" href="http://download.eclipse.org/egit/updates-1.3(" style="color:rgb(61,107,167); text-decoration:none">http://download.eclipse.org/egit/updates-1.3(</a>因为这个版本的发布时间跟Eclipse3.6发布时间相近,其他版本同理试试)</wbr>

  

  Next到底就OK了。

  二、配置EGit

  这里有个前提,就是首先电脑上必须安装有git的客户端

  安装地址:http://code.google.com/p/msysgit/downloads/list?q=full+installer+official+git

  安装之后,打开Eclipse

    

  选择git客户端的安装路径,接着在Configuration中配置user Settings的user和email

  这个用户名必须是github的用户,还没注册的,点击这里申请https://github.com/

  

  

  到此,插件的配置结束


  非常激动的开始创建一个DEMO试试

  

  <wbr>File &gt; Team &gt; Share Project 选择GIT</wbr>

  

  这里选中Git的时候,会提示设置HOME环境变量

  

  HOM-->%USERPROFILE%

  

  接着就创建一个仓库

  

  三、上传工程

  首先需要登录github

  创建一个空的仓库

  

  点击Create a new repository

  因为我已经创建过一个GitDemo,就不再演示

  点击上传

  提示exception caught during execution of ls-remote command

  发现是没有私钥。


  这里简单说明下egit的工作原理

  事实上,熟悉CVS或则SVN的朋友肯定知道,当我们点击commit的时候,版本管理器会将我们修改的内容进行同步更新

  但是egit却没有那么智能,事实上,GIT有个本地仓库的概念,也就是说当我们commit的时候,我们把更新的内容信息

  同步到本地仓库,点击push的时候才将本地仓库中的更新内容提交到github

  本地仓库路径window-->show view-->other-->Git Repositories

  

  

  说多了,不知大家有没印象,最早配置EGit的User Settings的时候之后用户的名称,没有密码

  Passwords aren't very secure, you already know this. If you use one that's easy to remember, it's easier to guess or brute-force (try many options until one works). If you use one that's random it's hard to remember, and thus you're more inclined to write the password down. Both of these are Very Bad Things?. This is why you're using ssh keys.

  上述这段话是github给出的解释,通俗点说,github担心用户使用过于简单的密码造成安全隐患,或则是密码过于复杂造成用户难以记住带来的不必要麻烦

  因此采用SSH keys的方式

  四、SSH配置

  如何生成属于自己的SSH kyes,操作如下

  1.打开Git Bash

    输入ssh -T<wbr><a target="_blank" href="http://blog.sina.com.cn/s/mailto:git@github.com" style="color:rgb(61,107,167); text-decoration:none">git@github.com</a></wbr>

  

  发现没有RSA文件

  接着输入

  <wbr>#<wbr><code style="margin:0px; padding:0px">ssh</code><span style="margin:0px; padding:0px"><wbr></wbr></span><code style="margin:0px; padding:0px">-T<wbr><a target="_blank" href="http://blog.sina.com.cn/s/mailto:git@github.com" style="color:rgb(61,107,167); text-decoration:none">git@github.com</a></wbr></code></wbr></wbr>

  

  提示没有权限。

  继续输入

  ssh-keygen (一直enter)

  上述路径不是唯一的,大家自己把握之前HOME配置的路径

  最后测试下

  

  配置SSH2

  

  

  简单解释下,之前上传的是SSH keys的公钥,而id_rsa中存放的就是我们的私钥,因此当我们上传(push)的时候只需要

  输入公共的账号git即可

  

  参考资料:

  1.GIT安装配置:http://liuzhichao.com/p/624.html

  2.如何删除repository(仓库)

  

  3.开始egit的使用:http://wiki.eclipse.org/EGit/User_Guide/Getting_Started

  4.更多参考:http://wiki.eclipse.org/EGit/User_Guide#Github_Tutorial

  5.EGit与github的简化版本说明:http://gevin.me/182.html

  6.关于SSH:https://help.github.com/articles/generating-ssh-keys

  7.关于仓库:https://help.github.com/articles/creating-a-new-repository


Eclipse上使用Github


二_使用EGIT前的配置


配置个人信息,最重要的是user.name和user.email

l Preferences > Team > Git > Configuration

l New Entry

三_新建GIT仓库


新建NC module project

l File > Team > Share Project 选择GIT

创建仓库后,在$workspace\demo目录下的.git文件夹,就是git的仓库地址。和CVS、SVN不同,GIT不会在每一个目录下建立版本控制文件夹,仅在根目录下建立仓库

同时,eclipse中的project也建立git版本控制,此时未创建分支,处于NO-HEAD状态

文件夹中的符号”?”表示此文件夹处于untracked状态,这样就成功创建GIT仓库。

四_配置.gitignore

此时我们尝试做一次提交

l Team -> Commit…

如上图所示,Author和Committer会默认为Git配置的用户信息。下面的Files窗口中可以看到此次提交的文件,其中有非常多带有NC_HOME的文件,此时可以猜测出,在我们的project中链接的NC_HOME也被GIT默认到版本控制中了,如下图:

显然NC_HOME和out是不需要进行版本控制的,我们可以通过配置.gitignore来排除这两个文件夹

打开Navigator窗口,在project根目录中添加.gitignore文件,将需要排除控制的目录写入.gitignore文件中

再次尝试commit,需要提交的文件已经被过滤

首次提交后,会自动生成master分支

然后在public中新建一个文件,可以看到图标依然是问号,处于untracked状态,即git没有对此文件进行监控

通过Team -> Add to index可以将文件加入git索引,进行版本监控

可以看到图标显示也有了变化(EGIT中只要Commit就可以默认将untracked的文件添加到索引再提交更新,不需要分开操作)

也可以通过Team -> Untrack将文件从索引控制中排除。

将此次新增的文件commit到仓库中,文件将处于unmodified状态,或者说,这就是一种staged状态

然后修改文件的内容,文件将处于modified状态


五_查看历史记录

Team -> Show in history可以查看版本历史提交记录

可以选择对比模式


六_远程GIT仓库

此小结的前提是已经搭建GIT服务器,并通过SSH协议连接,可参看文档《RHEL下搭建GIT服务器》《WindowsXP下搭建GIT服务器》《GIT服务器使用基础》。本文使用RHEL5.5系统下的GIT-2012-01-11,用户root/password,GIT仓库统一存放在/app/gitspace目录下。

首先通过shell工具连接到服务器,建立空仓库gitdemo,此时的ssh访问地址如下,分别由协议名称、用户名、IP、端口、git仓库目录组成。

ssh://root@192.168.1.101:22/app/gitspace/gitdemo

打开GIT资源库窗口,选择克隆资源库

现在已经把远程的GIT仓库克隆到本地,接下来需要将仓库检出为NC模块项目。

最后得到gitdemo模块项目,分支是mirror

七_推送远程仓库


克隆服务器端仓库后,会在本地建立一个一样的仓库,称本地仓库。在本地进行commit操作将把更新提交到本地仓库,然后可以将服务器端的更新pull到本地仓库进行合并,最后将合并好的本地仓库push到服务器端,这样就进行了一次远程提交。

先提交一次到本地仓库

然后push到服务器端的mirror分支,Team -> remote -> Push

完成推送后,可以在服务器端mirror镜像的log中查看到此次记录


八_解决推送冲突


多人协作开发的情况下,往服务器推送更新时难免出现冲突,所以推送之前需要解决服务器端的最新版本和本地仓库的冲突。Pull操作就是把服务器端的更新拉拢到本地仓库进行合并,解决好合并冲突后,就可以顺利push到服务器分支了。

假设现在Mairo兄弟在用GIT协作开发NewSuperMairoBro游戏,目前服务器端的mushroom.java文件的内容如下:

MairoBro克隆出代码后,Mairo哥哥做了如下修改

Mairo弟弟做了如下修改

然后Mairo弟弟先push代码,Mairo哥哥使用pull来合并本地仓库和远程仓库,将发行文件出现冲突,此时GIT会自动合并冲突的文件,如下图所示:

很明显自动合并的冲突文件不能直接使用,我们可以手动调整,右键发生冲突的文件,选择Team -> Merge Tool

第一项是将GIT自动合并过的文件和服务器端文件进行对比

第二项是用本地最新版本的文件和服务器端文件进行对比,建议用此项

接下来就是熟悉的对比界面

Mairo哥哥将冲突文件修改如下

然后右键点击此冲突文件,选择Team -> Add to index再次将文件加入索引控制,此时文件已经不是冲突状态,并且可以进行提交并push到服务器端

解决合并冲突后,Mairo弟弟只需要将服务器中合并后的版本pull到本地,就完成了一次协作开发的代码合并。从历史记录中可以看到,从mushroom开始历史进入分支,先是mushroomA的记录,然后是mushroomB的记录,最后历史分支合并。


九_Rebase和Merge的区别

Rebase和Merge操作最终的结果是一样的,但是实现原理不一样。

从上面的MairoBro例子可以知道pull大概对历史记录进行了怎样的合并操作,其实默认pull的操作就是一个分支的merge操作,如下图重现一下:

Mairo弟弟的提交记录如下:

Mairo哥哥的提交记录如下:

首先是Mairo弟弟把更新push到服务器,这样服务器端的记录就和Mairo弟弟本地的记录是一样的,接着Mairo哥哥执行pull操作,现在分析下pull是如何操作的。

l pull默认就是先把服务器端的最新记录更新到本地的Remote Tracking中对应的mirror分支

l 接着对Local的mirror分支和Remote Tracking的mirror分支进行merge操作

Merge操作后的结果就是会新增加一个merge记录节点,如下所示:

从上图可以看出,mushroomA是在mushroomB之前的,这个时间关系不取决于谁先执行push,而取决于本地仓库中谁先执行commit。所以merge会按照时间顺序严格的记录每一次commit。

接下来看看rebase,其实rebase也是把两个分支进行合并的操作,当Mairo弟弟push更新后,服务器端的mirror分支的历史如下:

Mairo哥哥本地的历史如下:

现在Mairo哥哥不是执行merge操作,而是执行rebase操作,最后结果如下:

很明显的区别是没有出现分支的记录,而且注意到mushroomA*,请注意这个记录和mushroomA不是同一个记录,我们先分析下rebase操作下,Mairo哥哥的历史记录都做了哪些变化:

l 先将当前分支的更新部分保存到临时区域,而当前分支重置到上一次pull的记录

l 然后将服务器端的更新添加到当前分支,此时当前分支和服务器端分支是一样的

l 最后将原分支的更新部分mushroomA提交到当前分支的后面,就是要在mushroomB的后面添加mushroomA的更新,当然此时更新记录已经不是之前的mushroomA了,如果出现冲突则使用对比工具解决冲突,最后记录变成mushroomA*。

如果Mairo哥哥提交过mushroomA1、mushroomA2、mushroomA3,那么执行rebase后会对mushroomA1、mushroomA2、mushroomA3分别顺序执行上图所示的合并,最后记录为mushroomA1*、mushroomA2*、mushroomA3*。很显然rebase操作更复杂,冲突的概率也更高,并且不是按照时间顺序记录。


十_Rebase和Merge如何选择的简单解析


此小结为什么说是简单解析呢,因为rebase和merge的选择问题讨论比较激烈,笔者也没有一个定论,而且git也处于研究发展阶段,很多理论还没有完全的纯熟。

对于一个多人开发团队频繁提交更新的情况,如果使用merge会使得历史线图非常复杂,并且merge一次就会新增一个记录点,如果使用rebase就是完全的线性开发。

上图所示是Merge和Rebase的两个结果,显然你不想要merge的混乱结果吧,你能告诉我merge图中那条线是master分支吗?

所以给出如下建议,如果同一文件反复修改或提交次数比较多,预期会出现很多的conflict,那么可以使用merge合并,仅需要解决一次冲突即可(不过,大范围主题式的修改,是不是应该事先就新开一个分支呢?);如果修改范围小,预期conflict少,则建议使用rebase。

EGIT中默认的pull操作是Fetch+Merge,如果要用rebase,可以分开操作。先执行Fetch更新remote tracking,再执行rebase进行合并(下一小节将介绍rebase操作)。或者修改pull的默认操作,在.git/config文件中配置:

上述配置只对mirror分支有效,也可做全局配置,在$HOME/.gitconfig中配置,windows系统如果没有配置HOME变量的话就默认在$documents and settings/ USER目录下:


十一_Fetch和Rebase


MairoBro来做fetch和rebase的测试,首先Mairo弟弟在client中添加文件OPQ分别提交,并push到服务器,如图:

此时服务器端的历史已经被更新,但是Mairo哥哥的remote tracking中mirror分支并没有更新到最新的记录,如图:

所以需要更新remote tracking中的分支,使得它与服务器端的分支同步,右键点击资源库选择Fetch

这样就更新了本地的remote tracking中的分支,使得它和服务器端分支同步。

然后Mairo哥哥在本地的private中添加文件ABC,并分别提交到本地仓库中。

然后将本地mirror分支和remote tracking中的mirror分支进行rebase,先checkout本地mirror分支 ,然后右键点击选择Rebase

如上图可以看到历史记录的顺序是OPQABC,已经rebase成功,接着push到服务器即可。

十二_重置功能


GIT中有三种重置功能,分别是soft、mixed、hard,区别如下:

lSoft -当前分支重置到指定commit记录位置,索引和工作树不变;

lMixed -当前分支重置到指定commit记录位置,索引被更新,工作树不变;

lHard -当前分支重置到指定commit记录位置,索引和工作树都更新。

貌似不好理解,首先要理解GIT的三个区域(工作树、索引区、仓库),可以参考文档《GIT简介》。

先做soft的测试,新建Soft.java文件,可以看到此文件未添加到索引控制

先进行一次提交,提交后在History窗口中重置此次提交,如图:

重置后查看工作树,如图

从上图可以看出,soft文件还存在,说明重置没有改变工作树,而且soft文件不是“问号”图标,说明已经添加到索引,说明索引也没有变。唯一重置的是历史记录。

然后新建Mixed.java文件,此时Mixed.java也没有添加到索引控制,然后提交。

在History窗口中重置

重置后查看工作树结果如下:

从上图可以看出,Mixed.java文件还存在,说明工作树没有改变,但是文件状态是untracked,说明索引被更新,此时文件没有添加索引控制。

最后来看hard重置,新建Hard.java文件,此时文件没有添加索引,然后提交。

在History界面重置此次提交,如图:

重置后再查看工作树,结果如下:

可以看到Hard.java文件已经不存在了,说明索引和工作树都被更新。



更多进阶教程推荐

鉴于本文只是一篇抛砖引玉的入门教程,就不再详述更多的细节,如果对Git感兴趣的同学,可以看看下面这些,它们可以帮助你成为一名专家、至少是设计师中的Git专家 :)





分享到:
评论

相关推荐

    ecilpse/myeclipse安装svn插件

    本教程将详述如何在Eclipse和MyEclipse集成开发环境中安装SVN插件,以便更好地进行代码版本管理和协同开发。 首先,Eclipse和MyEclipse都是流行的Java IDE,它们提供了一个强大的平台来编写、调试和部署Java应用...

    myeclipse9.0 svn插件安装

    因此,为了在MyEclipse中实现对源码的版本控制,我们需要手动安装SVN插件。这篇博客(&lt;https://zfwdl2005.iteye.com/blog/1010631&gt;)将指导我们完成这一过程。 首先,了解SVN的基本概念至关重要。SVN是一种分布式...

    myeclipse 使用git插件

    本篇文章将详细介绍如何在MyEclipse中安装和使用Git插件。 首先,我们来看标题“myeclipse 使用git插件”。这表明我们要在MyEclipse环境中集成Git,以便在开发过程中进行代码版本管理和协作。Git插件的引入,使得...

    eclipse/myeclipse 反编译插件 Eclipse Class Decompiler 2.10.0

    Eclipse Class Decompiler是一款Eclipse插件,整合了多种反编译器,和Eclipse Class Viewer无缝集成,能够很方便的使用插件查看类库源码,进行Debug调试。 同时还提供了在线自动查找源代码,查看Class二进制字节码的...

    MyEclipse9.1(以上)安装SVN插件

    本文将详细介绍如何在MyEclipse9.1及以上版本中安装SVN(Subversion)版本控制插件,帮助开发者更好地管理代码版本。 ### 安装SVN插件步骤 #### 步骤一:下载Subclipse插件包 首先,需要下载适用于MyEclipse的...

    GitHub插件

    以下是关于GitHub插件及其在MyEclipse和Eclipse中的使用方法的详细说明: 一、Git基础 Git是一种分布式版本控制系统,由Linux创始人Linus Torvalds创建,用于管理Linux内核的源代码。Git的核心功能包括版本管理、...

    MyEclipse10安装PropertiesEditor的插件

    总的来说,通过以上步骤,你可以在MyEclipse10中成功安装并使用PropertiesEditor插件,从而提升对`.properties`文件的管理和编辑体验。了解和掌握这些工具的使用方法,对于Java开发者来说是非常必要的,能够帮助他们...

    MyEclipse9.0安装jad反编译插件和文件

    这个文件夹包含了所有已安装和待安装的MyEclipse插件。 4. **解压并复制JAD插件**:将下载的JAD插件压缩包解压,将解压后的.jar文件复制到`plugins`目录下。 5. **更新MyEclipse配置**:接着,需要更新MyEclipse的...

    Myeclipse 2016 GIT插件

    - **features**和**plugins**目录:这些目录通常包含Myeclipse插件的组件和功能,每个子目录代表一个独立的功能或服务。 - **web**目录:可能包含了与Web相关的资源,比如HTML、CSS、JavaScript等,用于插件的用户...

    elipse里Groovy安装

    在Eclipse中安装Groovy插件是一个简单但重要的步骤,特别是对于那些希望在Java IDE上进行Groovy开发的开发者来说。Groovy是一种强大的、动态的编程语言,它与Java兼容,能够提高开发效率并简化代码。以下是安装...

    MyEclipse2017 SVN插件.zip

    3. **覆盖原有文件**:将解压后的文件逐个复制到对应的MyEclipse插件目录下,覆盖原有的文件。这一步骤中的“对应文件夹依次覆盖”意味着需要按照文件类型和功能来正确地定位和替换。 4. **重启MyEclipse**:完成...

    eclipse myeclipse svn 和 jadclipse 反编译插件 及安装

    本文将详细介绍如何在Eclipse和MyEclipse集成开发环境中安装及使用SVN版本控制系统以及jadclipse反编译插件。 首先,让我们来了解一下这三个核心概念: 1. **Eclipse**:Eclipse是一款开源的Java IDE,支持多种...

    Eclipse和MyEclipse安装和使用git(egit)图解笔记

    Eclipse和MyEclipse是两种广泛使用的Java集成开发环境(IDE),它们对于版本控制系统Git的集成,主要依赖于名为egit的开源插件。Git是一种分布式版本控制系统,它允许开发者跟踪代码的更改,并与其他团队成员协作。...

    myeclipsesvn

    ### MyEclipse 配置 SVN 教程 在软件开发过程中,版本控制系统(Version Control System,简称VCS)是不可或缺的工具之一。其中,Subversion(简称SVN)作为一款非常流行的集中式版本控制系统,被广泛应用于项目...

    MyEclipse插件egit4.9.0下载

    【MyEclipse插件egit4.9.0下载】是一个关于在MyEclipse集成开发环境中安装和使用Egit插件的主题。Egit是基于Java的Git版本控制系统的一个开源插件,它允许开发者在Eclipse或MyEclipse中直接进行Git操作,包括代码的...

    GitHub配置指南

    为了在Eclipse中使用GitHub,你需要安装EGit插件。可以从Eclipse的更新站点下载并按照指示进行安装。安装成功后,在Eclipse的“Preferences--&gt;Team--&gt;Git--&gt;Configuration”中设置你的GitHub用户名和邮箱。 接下来...

    MyEclipse安装反编译软件jadclipse

    MyEclipse是一款强大的Java集成开发环境,而jadclipse是它的一个插件,主要用于反编译Java类文件,帮助开发者查看并理解已编译的.class文件中的源代码。在IT行业中,有时我们可能需要查看或分析没有源代码的第三方库...

    myeclipse 10 egit插件

    myeclipse10的egit插件,亲测可用。从官网下载的org.eclipse.egit.repository-2.3.1.201302201838-r、org.eclipse.egit.repository-2.2.0.201212191850-r和为了方便国内下载我把官网egit各个版本的列表网页保存到了...

    GitHub使用说明

    有关GitHub的简介和 详细使用方法在window中和Linux中并附上在myeclipse中有关github中的插件

    MyEclipse黑色主题

    此外,除了使用插件外,有些用户还会手动修改MyEclipse的配置文件,如`.myeclipse.ini`,来启动时自动应用特定的主题。 黑色主题不仅对眼睛友好,还能帮助开发者专注于代码,减少视觉干扰。同时,很多开发者发现,...

Global site tag (gtag.js) - Google Analytics