GIT与项目
创建GitHub账号
本地Git仓库和GitHub仓库之间的传输是通过SSH加密的
step1:创建项目的SSH Key
ssh-keygen -t rsa -C "your email@example.com"
创建完成后,在用户目录里找到.ssh目录,里面有id_rsa和id_rsa.pub两个文件。这两个就是SSH Key的密钥对,id_rsa是私钥,不能泄露出去,id_rsa.pub是公钥,可以放心的告诉他人
step2:登陆GitHub注册或登陆账号,打开“settings”的“SSH Keys”页面,然后,点击“New SSH Key”,填上任意title,在key文本框里黏贴id_rsa.pub的文本内容,点“Add Key”,你就应该看到已添加的Key。
创建远程仓库
-
登陆GitHub
-
在右上角找到“+”点击“new repository”按钮,创建一个新的仓库
从远程仓库克隆
-
将GitHub上的项目,克隆到本地一份
-
git clone git@github.com:账号名/项目名.git
与远程库交互
-
从远程库获取到本地
git pull
-
将本地代码提交到远程库
- git push origin master
- 提示:每次提交前,需要先获取,解决冲突后再次提交
本地仓库
-
创建空目录(本地仓库)和git本地角色
mkdir -p repo/example cd repo/example git config --global user.name "Your Name" git config --global user.email "email@example.com"
-
在目录下初始化本地仓库
- git init
-
创建成功后,目录下就是一个版本库,这个目录里所有文件都可以被Git管理起来,每个文件的修改、删除,Git都能跟踪,以便任何时刻可以追踪 历史,或在必要时回退版本
文件管理
-
本地仓库分为三部分:工作区,暂存区,仓库区,其中暂存区、仓库区是版本库部分
工作区和暂存区
-
使用ide打开目录,创建项目,将文件添加到暂存区
-
git add 文件1 文件2 ... git add 目录
-
使用暂时区的内容恢复到工作区的内容
git checkout --文件名
-
查看暂存区的状态
git status
暂存区到仓库区
- 将暂存区的记录添加到仓库区
git commit -m '提交时的备注信息'
-
查看仓库区的历史
当前版本的历史版本:git log 简版显示:git log --pretty=oneline 历史命令:git reflog
-
在Git中,使用HEAD表示当前版本,也就是最新版本,上个版本就是HEAD^,上上个版本是HEAD^^,当然往上100个版本写^数不过来,所以写成HEAD~100
-
对比工作区和仓库区中某版本文件的不同
git diff HEAD --文件名
-
回退历史版本到暂存区
git reset HEAD^或版本号
git show 版本号 //查看具体版本号的详细修改 git branch //查看本地所有分支,为master分支 git checkout -b master1 origin/master //1:新建一个新分支master1)----简历新分支master1跟踪远程分支master, --- 此时git branch查看分支,为master 、master1 2个分支; ------------------在新分支master1操作--------- git cherry-pick 版本号 //2:复制内容倒master1----复制版本号的对应修改到master1 git status //此时gitstatus 会显示有一个待提交 是刚复制的点 git pull origin master //拉取master的最新内容倒master1 git push origin master1:master //3:将找回内容提交到master----将本地的修改(刚复制的点)master1提交到master(注意master1后不要带空格 不然会将远程的master干掉) git branch -r //查看远程分支 git branch -d master //4:删除本地分支master----删除本地master分支 --- 此时git branch 查看本地分支,只有master1一个本地分支 git branch -m master1 master //5:将master1重命名为master----将master1重命名为master --- 此时git branch 查看本地分支,是master分支