git 使用

git博客笔记(详细版)
http://blog.csdn.net/Agul_/article/category/1205224




生成key   
   http://blog.csdn.net/hustpzb/article/details/8230454/


[图片]
更新代码 进入项目目录 git pull   
工作使用 : linux 命令
  1     cd 进入文件夹
  2    cd  ../ 退一步
  3    cd ../../ 
  4    ls  查看当前目录
  5    pwd 显示工作路径
  6   mkdir 文件名  :  创建一个文件夹目录
  7   mkdir dir1 dir2 同时创建两个目录
   8   rm -f file1 删除一个叫做 'file1' 的文件'
   9    rmdir dir1 删除一个叫做 'dir1' 的目录'
  10    cp file1 file2 复制一个文件(file)
   11   cp -a dir1 dir2 复制一个目录(folder)
   12   cat file1 从第一个字节开始正向查看文件的内容
   13    tac file1 从最后一行开始反向查看一个文件的内容
   14   ifconfig eth0 显示一个以太网卡的配置
   15    touch filename  创建一个文件(file)
    16    : wq 退出文件编辑
        
       
Change-Id: I230d2adf9be26f6ee61a79e32a7ad74292be406a
工作使用 : git 命令
提交
1       git log --oneline -10
 2      git add -u
3       git commit --amend
4       git push origin HEAD:refs/for/master;   
5        git commit -m “test1” 首次提交到版本库,提交说明为test1


6        git branch 查看本地所有分支
 7      git status 查看当前状态 
8         git checkout 分支名  :  切换分支
9         git pull 更新服务器上的代码(注意要在主分支上执行更新)
10        git rebase --continue


3. 回到没有做过的情况
git reset --hard(此过程不可逆,回到修改之前的状态)
CCBFUND-910 developing 超级现金宝取现
git push origin HEAD:refs/for/master


一、 Git 常用命令速查
git branch 查看本地所有分支
git status 查看当前状态 
git commit  -u      ---- 提交 
git branch -a 查看所有的分支
git branch -r 查看远程所有分支
git commit -am "init" 提交并且加注释 
git remote add origin [email protected]:ndshow
git push origin master 将文件给推到服务器上 
git remote show origin 显示远程库origin里的资源 
git push origin master:develop
git push origin master:hb-dev 将本地库与服务器上的库进行关联 
git checkout --track origin/dev 切换到远程dev分支
git branch -D master develop 删除本地库develop
git checkout -b dev 建立一个新的本地分支dev
git merge origin/dev 将分支dev与当前分支进行合并
git checkout dev 切换到本地dev分支
git remote show 查看远程库
git branch -d xxxxx  删除本地分支
git add .
git rm 文件名(包括路径) 从git中删除指定文件
git clone git://github.com/schacon/grit.git 从服务器上将代码给拉下来  复制工具上的命令即可
git config --list 看所有用户
git ls-files 看已经被提交的
git rm [file name] 删除一个文件
git commit -a 提交当前repos的所有的改变
git add [file name] 添加一个文件到git index
git commit -v 当你用-v参数的时候可以看commit的差异
git commit -m "This is the message describing the commit" 添加commit信息
git commit -a -a是代表add,把所有的change加到git index里然后再commit
git commit -a -v 一般提交命令
git log 看你commit的日志      git log --oneline -10  没页显示10条提交日志
git diff 查看尚未暂存的更新
git rm a.a 移除文件(从暂存区和工作区中删除)
git rm --cached a.a 移除文件(只从暂存区中删除)
git commit -m "remove" 移除文件(从Git中删除)
git rm -f a.a 强行移除修改后文件(从暂存区和工作区中删除)
git diff --cached 或 $ git diff --staged 查看尚未提交的更新
git stash push 将文件给push到一个临时空间中
git stash pop 将文件从临时空间pop下来
---------------------------------------------------------
git remote add origin [email protected]:username/Hello-World.git
git push origin master 将本地项目给提交到服务器中
-----------------------------------------------------------
git pull 本地与服务器端同步
-----------------------------------------------------------------
git push (远程仓库名) (分支名) 将本地分支推送到服务器上去。
git push origin serverfix:awesomebranch
------------------------------------------------------------------
git fetch 相当于是从远程获取最新版本到本地,不会自动merge
git commit -a -m "log_message" (-a是提交所有改动,-m是加入log信息) 本地修改同步至服务器端 :
git branch branch_0.1 master 从主分支master创建branch_0.1分支
git branch -m branch_0.1 branch_1.0 将branch_0.1重命名为branch_1.0
git checkout branch_1.0/master 切换到branch_1.0/master分支
du -hs
git branch 删除远程branch
git push origin :branch_remote_name
git branch -r -d branch_remote_name
-----------------------------------------------------------
初始化版本库,并提交到远程服务器端
mkdir WebApp
cd WebApp
git init 本地初始化
touch README
git add README 添加文件
git commit -m 'first commit'
git remote add origin [email protected]:daixu/WebApp.git
增加一个远程服务器端
上面的命令会增加URL地址为'[email protected]:daixu/WebApp.git',名称为origin的远程服务器库,以后提交代码的时候只需要使用 origin别名即可
gerrit :
git clone ssh://[email protected]:29418/ccb_fund_3




冲突解决的一般过程
merge/patch的冲突解决
先编辑冲突,然后git commit提交。
注:对于git来讲,编辑冲突跟平时的修改代码没什么差异。修改完成后,都是要把修改添加到缓存,然后commit。
rebase的冲突解决
rebase的冲突解决过程,就是解决每个应用补丁冲突的过程。
解决完一个补丁应用的冲突后,执行下面命令标记冲突已解决(也就是把修改内容加入缓存):
git add -u
注:-u 表示把所有已track的文件的新的修改加入缓存,但不加入新的文件。
 
然后执行下面命令继续rebase:
git rebase --continue
有冲突继续解决,重复这这些步骤,直到rebase完成。
 
如果中间遇到某个补丁不需要应用,可以用下面命令忽略:
git rebase --skip
 
如果想回到rebase执行之前的状态,可以执行:
git rebase --abort
 
注:rebase之后,不需要执行commit,也不存在新的修改需要提交,都是git自动完成。
编辑冲突的方法
直接编辑冲突文件
冲突产生后,文件系统中冲突了的文件(这里是test.txt)里面的内容会显示为类似下面这样:
a123
<<<<<<< HEAD
b789
=======
b45678910
>>>>>>> 6853e5ff961e684d3a6c02d4d06183b5ff330dcc
c
其中:冲突标记<<<<<<< (7个<)与=======之间的内容是我的修改,=======与>>>>>>>之间的内容是别人的修改。
此时,还没有任何其它垃圾文件产生。
 
最简单的编辑冲突的办法,就是直接编辑冲突了的文件(test.txt),把冲突标记删掉,把冲突解决正确。


 






                  提交步骤


1.新建一个分支,并且代码和服务器中代码同步
   git checkout origin/v2.0 -b temp  
2.为了保证新建的temp分支代码是最新的,可以多执行下面一步
  git pull
3.当你新建分支后,系统会自动checkout到temp分支上,此时
  git checkout  new
4.合并代码,并整理
  git rebase  temp  //会将temp分支的代码合并过来,并按照提交的顺序排序
5.  因为顺序是重新整理的,所以肯定会出现冲突
6.解决冲突,最后 git add * ,但不许要git commit
7.解决后,执行 git rebase --continue
8.重新提交代码: git push for-*


git 使用命令简化:
    git  init  初始化目录
     git  glog  看日志  ===== git log --oneline -10
      git  br =============git branch  
      git  co   master ===   git  checkout master   
      git br -d
      git  st   ========= git status
       git  ci --amend   ============git commit --amend
       git add fileName       #添加指定文件  
 
   git add -i             #手工选择要添加的文件  
    git add -A             #所有的更改操作--新建,更改,删除;  
    git add .              #只包括 新建 ,修改操作;无删除;  
    git add -u             #只包括修改,删除操作,无新建;  
    git add -p             #提交确认  


          

你可能感兴趣的:(技术,git)