gxh1968 发表于 2018-9-18 07:43:25

分布式版本管理器Git的基础操作与配置指南<二>

  一.Git分支介绍与创建
  Git中的分支,其实本质上仅仅是个指向commit对象的可变指针。Git回使用master作为分支的默认名
  字,在若干次提交后,你其实已经有了一个指向最后一次提交对象的master分支,它在每次提交的时候
  都会自动向前移动。
  1.Git分支的创建,切换和删除
  git branch不带参数,它会给出当前所有分支的清单,*表示当前所在的分支
  git branch -v附带显示各个分支最后一次commit信息
  git branch testing创建一个tesing分支,这仅仅是建立一个新分支,但不会自动切换到这个分支上去,此时依然在master分支上工作
  git checkout testing切换到testing分支
  git checkout -b iss53新建并切换到该分支iss53
  git merge hotfix用来合并分支,将当前分支合并到hotfix分支上
  git branch -d hotfix删除分支hotfix
  2.Git分支管理
  git branch --merged查看哪些分支已经并入当前分支
  git branch --no-merged查看尚未和并的分支
  git push origin serverfix把分支serverfix推送到远程仓库origin,git默认拒绝了push操作,需要进行设置,修改.git/config添加如下代码:   denyCurrentBranch = ignore
  git fetch origin从远程仓库origin获取数据,在fetch操作抓来的新的远程分支后,无法在本地编辑该远程仓库,如果要把该内容合并到当前分支,可以运行git merge origin/branchname,如果想要一份自己的branchname,可以git checkout -b serverfix orgigin/branchname
  git pull git://github.com/project.git    抓取远程仓库上的数据
  二.服务器上的Git
  Git可以使用四种主要的协议来传输数据:本地传输,ssh协议,git协议,和http协议
  本地协议
  git clone /opt/git/project.git 或者git clone file:///opt/git/project.git
  git remote add local_proj /opt/git/project.git添加一个本地仓库到现有Git工程
  ssh协议
  git clone ssh://user@server:project.git 或者git clone user@server:project.git
  http/s协议
  cd /var/www/htdocs
  git clone --bare /path/to/git_project gitproject.git
  cd gitproject.git
  mv hooks/post-update.sample hooks/post-update
  chmod +x hooks/post-update    之后就可clone仓库git clone http://example.com/gitproject.git
  在服务器上部署Git
  开始架设 Git 服务器的时候,需要把一个现存的仓库导出为新的纯仓库,纯仓库的目录名以 .git 结尾git clone --bare my_project my_project.git有了仓库的纯副本以后,剩下的就是把它放在服务器上并设定相关的协议。假设一个域名为git.example.com 的服务器已经架设好,并可以通过 SSH 访问,而你想把所有的 Git 仓库储存在 /opt/git 目录下。只要把纯仓库复制上去: scp -r my_project.git user@git.example.com:/opt/git ,现在,其他对该服务器具有ssh访问权限并可以读取/opt/git的用户就可以用一下命令clone
  git clone user@git.example.com:/opt/git/my_project.git
  三.实例
  实例1:用authorized_keys方法来给用户授权(先做服务器端操作,后做客户机上操作)
  在客户机上
  ssh-kengen

  ssh-copy-id -i>  cd myproject
  git init
  git add .
  git commit -m "initial commit"
  git remote add origin git@gitserver:/opt/git/project.git
  git push origin master
  Git服务器上
  useradd git
  passwd git
  cd /opt/git
  mkdir project.git
  cd project.git
  git --bare init生成一个不含工作目录的*空仓库*,这样空仓库本地不能执行git status,git add等动作,适合远程发布仓库
  如果往裸仓库放东西的话,可以这样
  cd /opt/git/
  mkdir project
  echo "hello world!" > file1
  git add .
  git commit -m "initial commit"
  git clone --bare project project.git
  然后从本地clone该仓库
  git clone git@servername:/opt/git/project.git
  本地会生成一个project文件夹,file1文件会在此
  实例2:公共访问
  Git服务器上
  mkdir /opt/git/project.git
  groupadd www-data
  cd project.git
  git --bare init
  mv hooks/post-update.sample hooks/post-update
  chmod +x hooks/post-update更改apache的配置文件
  ServerName git.gitserver
  DocumentRoot /opt/git
  
  Order allow, deny
  allow from all
  
  
  chgrp -R www-data /opt/git
  重启apache就可以使用git clone http://git.gitserver/project.git

页: [1]
查看完整版本: 分布式版本管理器Git的基础操作与配置指南<二>