Git
2018-05-22 14:09:48 1 举报
AI智能生成
Git学习分享
作者其他创作
大纲/内容
设置
$ git config --global user.name \"Your Name\"$ git config --global user.email \"email@example.com\"
创建版本库
1、创建一个空目录并进入目录
$ mkdir learngit$ cd learngit
2、将目录变成Git管理的仓库
$ git initInitialized empty Git repository in /Users/learngit/.git/
3、在创建目录下编写文件
vim readme.txt
4、文件添加到仓库
$ git add readme.txt
5、文件提交到仓库
$ git commit -m \"wrote a readme file\"
远程仓库
准备工作
1、创建SSH Key
$ ssh-keygen -t rsa -C \"youremail@example.com\"
2、登陆GitHub Add SSH Key
在Key文本框里粘贴id_rsa.pub文件的内容
添加远程仓库
本地仓库关联远程库
$ git remote add origin git@github.com:1769974308/learngit.git
首次本地仓库内容推送至远程库
$ git push -u origin master
本地仓库提交内容至远程
$ git push origin master
注:先有本地库后有远程库按以上操作进行本地库与远程库关联
从远程库克隆
$ git clone git@github.com:1769974308/gitskills.git
注:远程库建立一个库克隆到本地
标签管理
标签
发布版本时,先在版本库中打一个标签(tag),确定标签时刻的版本。但取某个标签的版本,就是把那个打标签的时刻的历史版本取出来。标签也是版本库的一个快照
创建标签
git tag <name>
$ git tag <name> commit_id
创建带有说明的标签:$ git tag -a v0.1 -m \"version 0.1 released\" 3628164 -a指定标签名,-m指定说明文字
查看所有标签
git tag
查看标签信息
git show <tagname>
删除标签
删除本地
git tag -d <tagname>
删除远程
git push origin :refs/tags/<tagname>
推送标签到远程
git push origin <tagname>
使用云码
功能
提供免费的Git仓库集成了代码质量检测项目演示项目管理代码托管文档管理提供私有库5人以下小团队免费
删除关联远程库
git remote rm origin
一个本地库既关联GitHub又关联码云
1.查看关联远程库信息:$git remote -v2.删除已关联的名为origin的远程库:$git remote rm origin3.关联GitHub的远程库:$git remote add github git@github.com:1769974308/learngit.git4.关联码云的远程库:$git remote add gitee git@gitee.com:chenjt/learngit.git5.再次查看远程库信息:$git remote -v6.推送到GitHub:$git push github master7.推送到码云:git push gitee master注意:远程库的名称叫gitee和github 不是origin
配置别名
log别名
git config --global alias.lg \"log --color --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit\"
Git
初识
集中式VS分布式
概念
安装
Linux
命令安装
sudo apt-get install git
源码安装
Git官网下载源码,然后解压,依次输入:./config,make,sudo make install
Windows
Git官网直接下载安装程序,按默认选项安装即可
基础命令
查看仓库当前的状态
git status
查看修改内容
git diff
git diff HEAD -- file
版本回退
查看提交历史
git log
git reset --hard commit_id
查看命令历史
git reflog
撤销修改
git checkout -- file
文件还在工作区
git reset HEAD file
文件添加到暂存区
文件提交到版本库
删除文件
$ git rm file$ git commit -m \"remove file\"
分支管理
创建分支
创建并切换到新建分支
$ git checkout -b dev
$ git branch dev
切换分支
$ git checkout dev
合并分支
分支合并到当前分支上
$ git merge dev
禁用Fast forward合并分支
$ git merge --no-ff -m '合并dev分支使用--on--ff' dev
查看分支
$ git branch
$ git branch -a
删除分支
$ git branch -d dev
强行删除分支 $git branch -D dev
解决冲突
查看分支的合并情况
$ git log --graph
先解决冲突。解决冲突后,再提交,合并完成。
分支管理策略
1、master分支用于发布新版本2、dev分支用于开发使用,发布版本时dev分支合并到master上3、每个人都在dev分支开发,每个人都有自己的分支,完成时往dev分支合并
bug分支
1、保存未完成的开支分支
$ git stash
2、切换到修复bug分支并新建bug分支,完成修复合并分支,提交修复内容
3、查看保存分支信息
git stash list
4、恢复保存分支
git stash apply 恢复保存分支git stash drop 删除stash内容
git stash pop 恢复并删除stash内容
多人协作
查看远程库的信息
$ git remote
查看远程库的详细信息
git remote -v
推送分支
把该分支上的所有本地提交推送到远程库
抓取分支
$ git checkout -b dev origin/dev
备注:克隆只能获取到master分支,若要获取远程的其他分支到本地,则用上面命令执行
1.首先,可以试图用git push origin branch-name推送自己的修改;2.如果推送失败,则因为远程分支比你的本地更新,需要先用git pull试图合并;3.如果合并有冲突,则解决冲突,并在本地提交;4.没有冲突或者解决掉冲突后,再用git push origin branch-name推送就能成功!5.如果git pull提示“no tracking information”,则说明本地分支和远程分支的链接关系没有创建,用命令git branch --set-upstream branch-name origin/branch-name
数据结构
string(字符串)
hash(哈希)
list(列表)
set(集合)
zset(有序集合)
使用Github
如何参与一个开源项目呢?比如人气极高的bootstrap项目,这是一个非常强大的CSS框架,可以访问它的项目主页https://github.com/twbs/bootstrap,点“Fork”就在自己的账号下克隆了一个bootstrap仓库,一定要从自己的账号下clone仓库,才能推送修改权限
忽略特殊文件
0 条评论
下一页