ubuntu 16.04 搭建git16.04 怎么使用git 客户端

> 博客详情
本文主要目的是想让和我一样刚从SVN阵营转到Git阵营的程序员能够快速完成一些简单的Git操作。
简单理解 Git 的思想和基本的工作原理,能够更好的进一步和使用Git。在开始学习Git 的时候,最好不要把Git的各种概念和其他的版本控制系统诸如 Subversion&等相比,否则容易混淆每个操作的实际意义。
Git是一个免费的、分布式的版本控制工具,或是一个强调了速度快的源代码管理工具。每一个Git的工作目录都是一个完全独立的代码库,并拥有完整的历史记录和版本追踪能力,不依赖于网络和中心服务器。
Git 在管理项目时,在本地会有三个工作区域:Git 的本地数据目录,工作目录以及暂存区域。如下图所示:
因此对于任何一个文件,在 Git 内都只有三种状态:已提交(committed),已修改(modified)和已暂存(staged)。
在简单地了解了Git之后,那么接下来的事情就是安装Git客户端了,命令如下:
sudo apt-get install git
但是,安装了Git客户端之后,如果你的代码不是托管在GitHub上就可以跳过设置GitHub账户内容了,否则还需要配置一下GitHub账户,GitHub为托管的Git版本库提供SSH协议支持,即用户可以用公钥认证的方式连接到GitHub的SSH服务器。设置之后才能够使用Git命令来下载和推送代码。
首先需要到&注册一个账户:只要点击导航条中的“Signup and Pricing”,或者点击首页中那个大大的“Plans, Pricing and Signup”按钮,即进入收费方案介绍及注册页面。开源软件托管是GitHub的基石,对于开源项目的版本库(即非私有版本库)的托管,GitHub是免费的。在收费方案及注册页面中,最上面的就是针对于开源的免费托管方案,如下图所示。
点击上图右侧的“Create a free account”按钮,就进入到注册页面,如下图所示。
注册只需要用户名,邮件地址和密码需要输入。注意:每个邮件地址只能注册一次。注册完成之后就会以新注册的账号自动登录。如下图所示:
点击上图右上角的设置按钮,就能进入设置页面,我们主要关注的是“&setting up Git and SSH keys”,设置成功之后用户可以用公钥认证的方式连接到GitHub的SSH服务器。
我们首先使用ssh命令连接的SSH服务,登录用户名为git(所有GitHub用户共享此SSH用户名,不要写成其他)。
执行之后提示:Permission denied (publickey).
这说明我们还没在GitHub账户中正确设置公钥认证。下图为GitHub的SSH公钥设置界面:
GitHub的SSH服务支持OpenSSH格式的公钥认证,可以通过下的ssh-keygen命令创建公钥/私钥对。
ssh-keygen -C "" -f ~/.ssh/github
也可以用ssh-keygen命令以不同的名称创建多个公钥,当拥有多个GitHub账号时,非常重要。这是因为虽然一个GitHub账号允许使用多个不同的SSH公钥,但反过来,一个SSH公钥只能对应于一个GitHub账号。
接下来就将~/.ssh/github.pub文件内容拷贝到剪切板。公钥是一行长长的字符串,若用编辑器打开公钥文件会折行显示,注意在copy时一定不要在其中插入多余的换行符、空格等,否则在公钥认证过程因为服务器端和客户端公钥不匹配而导致认证失败。然后将公钥文件中的内容粘贴到GitHub的SSH公钥管理的对话框,即上图key对话框中,并为这个SSH Key起个名字并保存。设置成功后,再用ssh命令访问GitHub,会显示一条认证成功信息并退出。在认证成功的信息中还会显示该公钥对应的用户名。
执行后提示:Hi github! You've successfully authenticated, but GitHub does not provide shell access.
通过以上的设置之后,我们就能够通过SSH的方式,直接使用Git命令访问GitHub托管服务器了。那么,下面我们就开始使用Git进行版本控制:
1. 从服务器下载代码,准确的说应该是从GitHub服务器复制一个版本库到本地:
mkdir gitmkdir repos cd git/repos git clone :"account context"/"repos name".git
2. 获取到源码之后,就可以进行开发了,代码开发完成就可以提交代码:
//往暂存区域添加已添加和修改的文件,不处理删除的文件 git status //比较本地数据目录与暂存区域的变化 git commit -m "commit directions" //提到代码到本地数据目录,并添加提交说明
3. 有可能你和其他人改的是同一个文件,那么冲突的情况是在所难免的,那么在提交之后再获取一下代码,就会提示代码冲突的文件,我们需要做的就是处理这些冲突,并再次提交:
git pull //更新代码 根据提示修改冲突文件中的代码 git add . git commit -m "commit directions"
4. 当你做完以上的步骤的时候,你需要做的是把本地数据目录的版本库的数据同步到GitHub服务器上去,这样你的同事才能够看到你作出的修改:
注意:""中的内容需要读者根据自己实际情况书写合适的内容。 本文的主要目的是为了让程序员能够快速的上手使用Git和GitHub,希望对大家有帮助。
人打赏支持
码字总数 69258
支付宝支付
微信扫码支付
打赏金额: ¥
已支付成功
打赏金额: ¥温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!&&|&&
LOFTER精选
网易考拉推荐
用微信&&“扫一扫”
将文章分享到朋友圈。
用易信&&“扫一扫”
将文章分享到朋友圈。
阅读(2904)|
用微信&&“扫一扫”
将文章分享到朋友圈。
用易信&&“扫一扫”
将文章分享到朋友圈。
历史上的今天
在LOFTER的更多文章
loftPermalink:'',
id:'fks_',
blogTitle:'安装ubuntu16.04后,清理系统',
blogAbstract:'
{if x.moveFrom=='wap'}
{elseif x.moveFrom=='iphone'}
{elseif x.moveFrom=='android'}
{elseif x.moveFrom=='mobile'}
${a.selfIntro|escape}{if great260}${suplement}{/if}
{list a as x}
推荐过这篇日志的人:
{list a as x}
{if !!b&&b.length>0}
他们还推荐了:
{list b as y}
转载记录:
{list d as x}
{list a as x}
{list a as x}
{list a as x}
{list a as x}
{if x_index>4}{break}{/if}
${fn2(x.publishTime,'yyyy-MM-dd HH:mm:ss')}
{list a as x}
{if !!(blogDetail.preBlogPermalink)}
{if !!(blogDetail.nextBlogPermalink)}
{list a as x}
{if defined('newslist')&&newslist.length>0}
{list newslist as x}
{if x_index>7}{break}{/if}
{list a as x}
{var first_option =}
{list x.voteDetailList as voteToOption}
{if voteToOption==1}
{if first_option==false},{/if}&&“${b[voteToOption_index]}”&&
{if (x.role!="-1") },“我是${c[x.role]}”&&{/if}
&&&&&&&&${fn1(x.voteTime)}
{if x.userName==''}{/if}
网易公司版权所有&&
{list x.l as y}
{if defined('wl')}
{list wl as x}{/list}  其实,好几个月前,就已经安装好了,可是一直搁置在那儿,所以密码等一些其它细节都忘的差不多了,所以今天就重新部署了一下,并开始积极使用。。。。。。。。。
1,git 安装:
  sudo apt-get install git-core openssh-server openssh-client
  $ sudo apt-get install git-core git-gui git-doc&
  sudo apt-get install libcurl4-gnutls-dev libexpat1-dev gettext libz-dev git-core & (注意:红色部分很多网站都写错了,坑呐。。。。git-core是git的安装包,其他的是git所依赖的安装包)
  如果需要在push到网上:
    a、如果只是需要将github上感兴趣的代码拷贝到本地,自己进行修改使用,而不打算共享发布的话,其实不申请帐号也没有关系,只需要&git clone&代码到本地就可以了。本文对这种方法
不做讨论,毕竟使用&github就是为了开源的目的。首先去&/&上注册一个帐号,具体的注册流程就不赘述了。
    b、在本地建立一个文件夹,然后做一些全局变量的初始化
        git config --global user.name &"用户名或者用户ID"
        git config --global user.email &邮箱
    这两个选项会在以后的使用过程中自动添加到代码中
    c、创建验证用的公钥
      这个是比较复杂和困扰大多数人的地方,因为&git&是通过&ssh&的方式访问资源库的,所以需要在本地创建验证用的文件。
      使用命令:ssh-keygen -C 'you email&' -t rsa & & & &会在用户目录&~/.ssh/&下建立相应的密钥文件
      可以使用&ssh -v&&命令来测试链接是否畅通
    d、上传公钥
      在&&的界面中 选择右上角的&Account Settings,然后选择&SSH Public Keys&,选择新加。
      Title&可以随便命名,Key&的内容拷贝自&~/.ssh/id_rsa.pub&中的内容,完成后,可以再使用&ssh -v&&进行测试。看到下面的信息表示验证成功。
          
2,创建项目:
  a、创建本地新项目工作树      # mkdir new-project      # cd new-project      # git init      # touch README      # git add README & & (上传README 文件)      # git commit -m 'first commit'      定义远程服务器别名origin      #& git remote add origin :xxx/new-project.git & & (origin 在这里就是&:xxx/new-project.git 的一个别名, 一个 url 链接)      本地和远程合并,本地默认分支为master      # git push origin master &(执行这一步可能会有报错)
      如果出现报错为
        ERROR: Repository not found.        fatal: The remote end hung up unexpectedly
      则代表你的 origin &的url 链接有误,可能是创建错误,也可能是这个 &:xxx/new-project.git &url 指定不正确。
      重新创建。
&      &如果报错为 ()
         error: src refspec master does not match any.
&        All I had to do was:
         $~ git commit -m 'initial commit'
         $~ git push origin master
    Success!
  b、更新文件:
    # vi README    自动commit更改文件    # git commit -a&&&&&    更新至远程    # git push origin master
    如果报错的话:
      ssh: connect to
port 22: Connection timed out
      fatal: The remote end hung up unexpectedly
    解决方法:
  c、&创建和合并分支:
    #git branch 显示当前分支是master
    #git branch new-feature& 创建分支    # git checkout new-feature 切换到新分支
    # vi page_cache.inc.php    # git add page_cache.inc.php    Commit 到本地GIT    # git commit -a -m "added initial version of page cache"    合并到远程服务器    # git push origin new-feature
    Counting objects: 4, done.    Compressing objects: 100% (2/2), done.    Writing objects: 100% (3/3), 336 bytes, done.    Total 3 (delta 0), reused 0 (delta 0)    To :acanoe/hello_world.git&    * [new branch] & & &new-feature -& new-feature    root@AC:~/hello_world#
    如果new-feature分支成熟了,觉得有必要合并进master    #git checkout master    #git merge new-feature    #git branch    #git push&    则master中也合并了new-feature 的代码    再登录到GitHub可以看见"Switch Branches"下的分支选项
到这里,基本的操作也就完成了,在以后的操作中或许还会出现各种各样的问题,所以会继续更新,下面附一张git的命令表。。。。。。。
以下是参考链接:
阅读(...) 评论()

我要回帖

更多关于 ubuntu 16.04 git gui 的文章

 

随机推荐