stonelee's notes

Table Of Contents

Previous topic

fedora

Next topic

linux

This Page

版本控制

git

撤销上一次commit:

git reset HEAD^

避免push时填入密码,通过ssh:

git remote set-url origin git@github.com:user/repo.git

使用代理:

git config --global http.proxy http://127.0.0.1:8087

升级子模块:

git submodule update --init --recursive

如果做了修改或删除,想回到版本控制的状态:

git checkout .

提交:

git commit -a -m 'Validation!'

添加远程仓库:

git remote add office http://stonelee:mima@10.10.22.86:1080/raphael

提交:

git push office

如果Fork别人的项目或者多人合作项目,最好每人都拥有一个独立分支,然后由项目维护人合并。

RhodeCode

RhodeCode中推送已经存在的库:

$ git push http://stonelee@10.10.22.86:1080/parseCSV master

如果报错:

RhodeCode error: RPC failed; result=22, HTTP code = 502
fatal: The remote end hung up unexpectedly

应该设置:

$ git config http.postBuffer 524288000

如何建立自己的分支

  • git branch yourbranch 创建分支
  • git checkout yourbranch 切换到yourbranch
  • 开发yourbranch分支,然后开发之后与master分支合并
  • git checkout master
  • git merge yourbranch
  • git branch -d yourbranch 合并完后删除local

如何将牛人的远程分支更新到自己的本地分支?

  • git remote 查看当前项目下远程
  • 增加新的分支链接,例如 git remote add niuren giturl…
  • 获取牛人的远程更新 git fetch niuren
  • 将牛人的远程更新合并到本地分支 git merge niuren/master

如何建立远程库进行管理

远程机器建立空的库:

git clone --bare raphael.git

本地设置远程访问路径:

git remote add centos ssh://stonelee@10.10.22.82/home/stonelee/raphael

推送:

git push centos svg

其他人拉取:

git clone ssh://stonelee@10.10.22.82/home/stonelee/raphael

切换到svg分支:

git checkout svg

删除错误提交的commit

起因: 不小新把记录了公司服务器IP,账号,密码的文件提交到了git

方法:

git reset --hard <commit_id>
git push origin HEAD --force

其他:

根据–soft –mixed –hard,会对working tree和index和HEAD进行重置:
git reset –mixed:此为默认方式,不带任何参数的git reset,即时这种方式,它回退到某个版本,只保留源码,回退commit和index信息
git reset –soft:回退到某个版本,只回退了commit的信息,不会恢复到index file一级。如果还要提交,直接commit即可
git reset –hard:彻底回退到某个版本,本地的源码也会变为上一个版本的内容

HEAD 最近一个提交
HEAD^ 上一次
<commit_id>  每次commit的SHA1值. 可以用git log 看到,也可以在页面上commit标签页里找到.

使用submodule

clone:

git clone /path/to/repos/foo.git
git submodule init
git submodule update

或者:

git clone --recursive /path/to/repos/foo.git

添加:

git submodule add ~/submd/repos/lib1.git libs/lib1

删除:

git rm --cached event-simulate

修改子项目:

在子项目目录中修改并git push后,还要在工程项目中更新commit id

更新:

git submodule foreach git pull

git pages

创建两个branch。在master中开发,稳定版本merge到gh-pages中。参见:https://github.com/aralejs/aralejs.github.com

hg

使用本地ignore

.hg/hgrc中添加:

[ui]
ignore = /path/to/repo/.hg/hgignore

然后在.hg/hgignore中列出本地存在但不提交的代码

查看自己提交的log

$ hg log -u stonelee --template '{date|isodate} {desc}\n'|more

bitbucket

将~/.ssh/id_rsa.pub添加到网站SSH keys中

修改.hg/hgrc文件:

[paths]
bitbucket = https://istonelee@bitbucket.org/hsialee/ciis

[hostfingerprints]
bitbucket.org = 24:9c:45:8b:9c:aa:ba:55:4e:01:6d:58:ff:e4:28:7d:2a:14:ae:3b

TortorseHg中View-Synchronize,选择相应的url进行操作

Git常用操作命令

http://rongjih.blog.163.com/blog/static/335744612010112562833316/

远程仓库相关命令:

检出仓库:$ git clone git://github.com/jquery/jquery.git
查看远程仓库:$ git remote -v
添加远程仓库:$ git remote add [name] [url]
删除远程仓库:$ git remote rm [name]
修改远程仓库:$ git remote set-url --push [name] [newUrl]
拉取远程仓库:$ git pull [remoteName] [localBranchName]
推送远程仓库:$ git push [remoteName] [localBranchName]

* 如果想把本地的某个分支test提交到远程仓库,并作为远程仓库的master分支,或者作为另外一个名叫test的分支,如下:
$ git push origin test:master         // 提交本地test分支作为远程的master分支
$ git push origin test:test              // 提交本地test分支作为远程的test分支

分支(branch)操作相关命令:

查看本地分支:$ git branch
查看远程分支:$ git branch -r (如果还是看不到就先 git fetch origin 先)
创建本地分支:$ git branch [name] ----注意新分支创建后不会自动切换为当前分支
切换分支:$ git checkout [name]
创建新分支并立即切换到新分支:$ git checkout -b [name]
直接检出远程分支:$ git checkout -b [name] [remoteName] (如:git checkout -b myNewBranch origin/dragon)
删除分支:$ git branch -d [name] ---- -d选项只能删除已经参与了合并的分支,对于未有合并的分支是无法删除的。如果想强制删除一个分支,可以使用-D选项
合并分支:$ git merge [name] ----将名称为[name]的分支与当前分支合并
合并最后的2个提交:$ git rebase -i HEAD~2 ---- 数字2按需修改即可(如果需提交到远端$ git push -f origin master 慎用!)
创建远程分支(本地分支push到远程):$ git push origin [name]
删除远程分支:$ git push origin :heads/[name] 或 $ git push origin :[name]

* 创建空的分支:(执行命令之前记得先提交你当前分支的修改,否则会被强制删干净没得后悔)
$ git symbolic-ref HEAD refs/heads/[name]
$ rm .git/index
$ git clean -fdx

版本(tag)操作相关命令:

查看版本:$ git tag
创建版本:$ git tag [name]
删除版本:$ git tag -d [name]
查看远程版本:$ git tag -r
创建远程版本(本地版本push到远程):$ git push origin [name]
删除远程版本:$ git push origin :refs/tags/[name]
合并远程仓库的tag到本地:$ git pull origin --tags
上传本地tag到远程仓库:$ git push origin --tags
创建带注释的tag:$ git tag -a [name] -m 'yourMessage'

子模块(submodule)相关操作命令:

添加子模块:$ git submodule add [url] [path]
    如:$ git submodule add git://github.com/soberh/ui-libs.git src/main/webapp/ui-libs
初始化子模块:$ git submodule init  ----只在首次检出仓库时运行一次就行
更新子模块:$ git submodule update ----每次更新或切换分支后都需要运行一下
删除子模块:(分4步走哦)
 1) $ git rm --cached [path]
 2) 编辑“.gitmodules”文件,将子模块的相关配置节点删除掉
 3) 编辑“ .git/config”文件,将子模块的相关配置节点删除掉
 4) 手动删除子模块残留的目录

忽略一些文件、文件夹不提交:

在仓库根目录下创建名称为“.gitignore”的文件,写入不需要的文件夹名或文件,每个元素占一行即可,如
target
bin
*.db

后悔药:

删除当前仓库内未受版本管理的文件:$ git clean -f
恢复仓库到上一次的提交状态:$ git reset --hard
回退所有内容到上一个版本:$ git reset HEAD^
回退a.py这个文件的版本到上一个版本:$ git reset HEAD^ a.py
回退到某个版本:$ git reset 057d
将本地的状态回退到和远程的一样:$ git reset –hard origin/master
向前回退到第3个版本:$ git reset –soft HEAD~3

Git一键推送多个远程仓库:

编辑本地仓库的.git/config文件:
[remote "all"]
    url = git@github.com:dragon/test.git
    url = git@gitcafe.com:dragon/test.git
这样,使用git push all即可一键Push到多个远程仓库中。

暂存数据:

在堆栈中存储:git stash

查看存储:git stash list

应用最近的存储:git stash apply
应用其他存储:git stash apply stash@{2}

移除存储:git stash drop stash@{0}
应用并移除:git stash pop

创建新的分支,并应用最近的存储,并从堆栈中删除:git stash branch other