git/github初级运用自如

 以前初学过一点git版本控制工具,利用github作仓库,照着github上的文档练习的了一下。不过那只篇只是照虎画猫(个人水平只能照着老虎画个猫模样,嘻嘻!)。 html

最近在学hibernate,公司与家之间都要调用我练习的小项目,交给git/github来管理,我只想说真的爽歪歪了。 java

本文在我以前的那篇《git/github学习笔记》的基础上,属于那个的升级增强版,欢迎对照阅读:http://www.cnblogs.com/fnng/archive/2011/08/25/2153807.html linux

若是本文有不太明白的地方请参考上面的文章。 git

 

Github: git项目托管网站,请先免费申请一个github账号:www.github.com github

Git:分布式版本控制工具,http://d.download.csdn.net/down/3169511/z_y_liu89 shell

 

Github的申请与git的安装我这里就不说了。这个不难。 网络

 

----//git/github环境配置

 

一 .  github上建立立一个项目 ssh

用户登陆后系统,在github首页,点击页面右下角“New Repository” 分布式

填写项目信息: ide

project name: hibernate-demo  

description : my first project

点击Create Repository” ; 如今完成了一个项目在github上的建立。

说明:咱们建立的是一个github仓库,一个仓库里只能存放(或叫对应)一个项目。

当你建立完成一个仓库的以后,github已经给你一个提示:当你看完了个人文章再来看这个提示就很是清楚了。

Global setup:
 Set up git
  git config --global user.name "Your Name"
  git config --global user.email defnngj@gmail.com
      
Next steps:
  mkdir hibernaet-demo2
  cd hibernaet-demo2
  git init
  touch README
  git add README
  git commit -m 'first commit'
  git remote add origin git@github.com:defnngj/hibernaet-demo2.git
  git push -u origin master

Existing Git Repo?
  cd existing_git_repo
  git remote add origin git@github.com:defnngj/hibernaet-demo2.git
  git push -u origin master

Importing a Subversion Repo?
  Click here 
When you're done:
  Continue



二  .  建立密钥

咱们如何让本地git项目与远程的github创建联系呢?之里就用的密钥。通俗点叫口令吧!(天王盖地老,宝塔镇河妖。。)

 

$ cd ~/. ssh 检查本机的ssh密钥

若是提示:No such file or directory 说明你是第一次使用git

若是不是第一次使用,请执行下面的操做,清理原有ssh密钥

$ mkdir key_backup
 $ cp id_rsa* key_backup
 $ rm id_rsa*

生成新的密钥:

Ssh-keygen –t rsa –C “defnngj@gmai.com”

 

注意: 此处的邮箱地址,你能够输入本身的邮箱地址。在回车中会提示你输入一个密码,这个密码会在你提交项目时使用,若是为空的话提交项目时则不用输入。这个设置是防止别人往你的项目里提交内容。

 

打开本地C:\Documents and Settings\Administrator\.ssh\id_rsa.pub文件。此文件里面内容为刚才生成人密钥。

登录github系统。点击右上角的 Account Settings--->SSH Public keys ---> add another public keys

把你本地生成的密钥复制到里面(key文本框中), 点击 add key ok

git中运行下面命令:

 

$ git –T git@github.com

若是提示:Hi defnngj You've successfully authenticated, but GitHub does not provide shell access. 说明你链接成功了

 

三 . 设置用户信息

这一步不是很重要,貌似不设置也行,但github官方步骤中有,因此这里也提一下。

git中设置用户名,邮箱

 

$ git config --global user.name "defnngj"//给本身起个用户名
$ git config --global user.email  "defnngj@gmail.com"//填写本身的邮箱


github中找到 Account Settings--->Account Admin ,找到一下信息:

Your API token is e97279836f0d415a3954c1193dba522f ---keep it secret! Changing your password will

generate a new token

$ git config --global github.user defnngj      //github 上的用户名
$ git config --global github.token e97279836f0d415a3954c1193dba522f

 

 

 

----//小玩一下git

 

 

上面都是准备工做,一次完成,之后就不用设置了。下面内容才是亮点。

 

先来讲说git下经常使用的几个基本操做,和linux系统的操做是同样同样的:

复制代码
$ ls   查看当前目录的内容

$ cd  /d   切换到d盘

$ cd  java/   打开当前目录下的java目录

$ cd  j(table键)  若是当你想打开java目录且当前目录下只有一个j开头的目录,输入J 而后按键盘上的table键,会自动帮你补齐。

$ cd ..  返回上一级目录
复制代码

 

假如你如今新建立了一个项目,想把它提交到github上面?

 

假设你建立好了一个项目,并切换到项目的根目录下面:

$ git status   //查看当前项目下全部文的状态,若是第一次,你会发现都红颜色的,由于它尚未交给git/github管理。

$ git add .   //.)点表示当前目录下的全部内容,交给git管理,也就是提交到了git的本地仓库。

Ps:git的强大之处就是有一个本地仓库的概念,在没有网络的状况下能够先将更新的内容提交到本地仓库。

$ git commit –m”new natter ”  //对你更新或修改了哪些内容作一个描述。

$ git remote add origin git@github.com:defnngj/hibernate-demo.git

//若是你是第一次提交项目,这一句很是重要,这是你本地的当前的项目与远程的哪一个仓库创建链接。

Psorigin能够改成别人的名字,可是在你下一次push(提交)时,也要用你修改以后的名字。

$ git remote -v  //查看你当前项目远程链接的是哪一个仓库地址。

$ git push -u origin master  //将本地的项目提交到远程仓库中。

 

 ------------------------------------------------------------

假如,你回到了家,想把公司提交的项目克隆到本地?

 

若是你是第一次想把github上面的项目克隆到本地或者要克隆别人的项目到地。

$ git clone git@github.com:defnngj/hibernate-demo.git  //在git下面切换到想存放此项目的文件目录下,运行这条命令就能够将项目克隆下来。

 

假如本地已经存在了这个项目,而仓库中又有一新的更新,如何把更的合并到本地的项目中?

$ git fetch origin    //取得远程更新,这里能够看作是准备要取了

$ git merge origin/master  //把更新的内容合并到本地分支/master

 

------------------------------------------- 

项目中删除了一些文件,如何提交?

 

假如远程仓库中已经存了aaa这个文件,我fetch了下来,并删除了aaa这个文件,想再push上到远程仓库中,并使远程仓库中的项目被新的修改覆盖(也是是远程仓库中的aaa也被删除)

$ git status   //能够看到咱们删除的哪些文件

$ git add .   //删除以后的文件提交git管理。

$ git rm   src/com/hzh/hibernate/dao/aaa.java    //移除咱们删除的那个文件,否则git不容许咱们往远程仓库提交。

Ps: 若是你想删除的是某个目录(java包),这里想移除整个目录的内容。

$ git rm  src/com/hzh/hibernate/bbb/ -r   // -r 会把bbb/目录下的全部内容一次性移动。

 

------------------------------------------------------------------------

远程建立了一个新仓库,本地建立了一个新项目,如何使新的项目与仓库对应起来?

 

其实,这个也很简单,只是我当时对那些命令不太理解,因此比较模糊,不知如何对应。

 

$ git remote add origin git@github.com:defnngj/hibernate-demo.git

//仍是这个命令,在你push项目以前加上这一句就OK了。

git@github.com:defnngj/hibernate-demo.git 就是你常见的新仓库的地址啊。git切换到新项目下,在push以前,加上这一句,咱们建立的新仓库就与新项目创建了链接。

 

 

怎么样?掌握了上面的那些,你是否是就能够在项目中把玩一下了。Git很强大,这些只是冰山一角,不过对新手来讲暂时够用了。

Ps:前两天聊天,一哥们说又发现个藏片的好地方,能够把岛国的小电影用这个管理,就不怕我的隐私被别人发现了尴尬。哈哈,你要不要试试。