git学习文档
1.创建git库
$ mkdir aa 该命令是创建一个叫aa的空目录
$ cd aa 跳到aa目录下
$ pwd 命令用于显示当前目录
$ git init 命令把这个目录变成Git可以管理的仓库(里面有隐藏文件.git)
$ ls -ah 查看该目录下所有的文件 包括隐藏文件
$ git rm -rf "文件路径" 删除文件
$ git reset --hard <commit ID号> 文件回滚
2.文件修改
$ git add aa.txt 提交单独的修改文件
$ git add .(--all) 提交所有的修改文件
$ git commit -m " " 文件里面有没有文件被修改
$ git diff 查看冲突
3.创建,删除分支
$ git checkout -b dev 这里就是创建了一个叫dev的分支 并且跳到该分支上
$ git branch 查看当前在那个分支上面
$ git checkout master 回到主分支上面
$ git merge dev 就是把分支上的修改和主分支合并起来
$ git branch -d dev 任务完成后 把dev分支删除掉
4.克隆文件
$ git clone git@github.com:michaelliao/gitskills.git
该命令就是git@github.com:michaelliao地址克隆一个gitskills的目录
必须使用SSH协议
5.添加远程库
$ git remote add origin git@github.com:michaelliao/learngit.git
origin为远程库名称(默认可自行修改)
$ git push -u origin master
把本地库当前分支master推送到远程(第一次推送)。
$ git push origin master
为跟新推送
6.冲突
$ git status 该命令可以查看冲突文件(红字标注)
$ git log --graph 命令可以看到分支合并图
$ git checkout --ours xxx/A.java // 抛弃甲的版本,保留乙的
$ git checkout --theirs xxx/A.java // 抛弃乙的版本,完全采用甲的
7.分支管理
$ git merge --no-ff -m "merge with no-ff" dev
--no-ff 表示禁用Fast forward
-m 表示本次合并要创建一个新的commit,所以加上-m参数
$ git log 查看历史
8.BUG分支
$ git stash list 查看工作现场
$ git stash apply 恢复现场
$ git stash drop 删除现场
$ git stash pop 恢复并删除(2,3两步混合)、
9.多人合作
$ git remote 查看远程库信息(origin远程库名称)
$ git remote -v 显示详细信息(可以抓取和推送的origin的地址)
$ git checkout -b dev origin/dev 在远程库上创建分支到本地
$ git pull 抓取库上最新信息
10.创建标签
$ git tag v1.0 创建了一个v1.0的标签
$ git tag 查看所有标签
$ git show v0.9 查看v0.9标签的信息
按Q退出 按S出现log file在按回车 出现 NO log file
$ git tag -a v0.1 -m "version 0.1 released" 3628164
创建带有说明的标签,用-a指定标签名,-m指定说明文字
11.操作标签
$ git tag -d v0.1 删除v0.1的标签
$ git push origin v1.0 推送v1.0标签到远程库
$ git push origin --tags 推送所有标签到远程库
$ git push origin :refs/tags/v0.9 该命令是删除远程库上面的标签
12.生产SSH密钥
$ ssh-keygen -t rsa -C “haiyan.xu.vip@gmail.com” (haiyan.xu.vip@gmail.com为你的邮箱地址可根据自己修改)
密码设置为空 按3下回车
生成两个文件:id_rsa和id_rsa.pub
在id_rsa.pub把里面内容复制到远程库上
cd ~/.ssh 查看是否有密钥
13.退出
ctrl + c 退出当前模式
14.测试和产出
paffe
$ paffe release -opmD --dest remote_hfb_zhenggang 测试修改
$ paffe release -opmD --dest local_hfd_zhenggang 产出线上
feather
$ feather release -opmD --dest remote_hfb_zhenggang 测试修改
$ feather release -opmD --dest local_hfd_zhenggang 产出线上
(opmD 里面的m为md5,最后产出的时候加)
15 添加模组
$ git submodule init 初始化
$ git submodule update 添加模组
16 添加第二个模组
$ git submodule add git@git.ipo.com:hf-dev-fe/feather-ui2.0.git UI2
这样就可以在GIT上面多人协同开发了。
(如果有任何疑问,可在http://www.liaoxuefeng.com/ 上面查看更详细的说明文档)