陈拓 [email protected] 2020/03/06-2020/03/08
Gitee和GitHub都是基于Git的代码管理平台。
Github是国外的,Gitee是国内的。
Gitee和GitHub都要用Git命令操作。
要使用Git命令先要在电脑上安装Git工具软件。
下面在树莓派上以Gitee为例演示Git的基本操作。
在电脑上用putty登录树莓派,如果不熟悉请看《电脑连接树莓派3B+》
https://blog.csdn.net/chentuo2000/article/details/103332186
如果没有安装。
sudo apt-get install git
https://gitee.com/chentuo2000/My-ESP8266
告诉git你的名字,这个名字会出现在你的提交记录中。
git
config --global user.name
"chentuo"
然后是你的Email,同样,这个Email也会出现在你的提交记录中,请尽量保持此Email和您的码云的注册Email一致。
git
config --global user.email
"[email protected]"
ls -la
全局设置保存在.gitconfig中,查看全局设置cat .gitconfig。
把我在gitee上创建的仓库克隆到本地。
git clone https://gitee.com/chentuo2000/My-ESP8266.git
ls –l
cd My-ESP8266/
这个目录和普通的目录有什么不同呢?ls –la
它比普通的目录多了一个.git目录,里面存放仓库信息。
在云端创建一个子目录tarballs,用git pull命令同步到本地仓库。
git pull
往本地目录tarballs中复制一个文件。
cp esp/esp-open-sdk/./crosstool-NG/.build/tarballs/binutils-2.25.1.tar.gz My-ESP8266/tarballs/
cd My-ESP8266/
命令用于查看项目的当前状态。
命令将该文件添加到缓存。
git add tarballs/binutils-2.25.1.tar.gz
再看看状态的变化,状态命令加-sb参数,以获得简短的结果输出。
git status -sb
绿色的A表示Add成功。
然后使用git commit -m "注释"命令将add过的内容提交到本地仓库,并添加一些注释信息,方便阅读。
git commit -m "编译esp-open-sdk的依赖库"
再看看状态:
git status -sb
git status
提示:在主分区,1个提交的分支前缀是origin/master,使用git push发布本地提交。
工作树已经清空了。
同步云端仓库git push
git status
git status -sb
上传完成,没有提交的文件了,工作树清空。
注意:一次上传有100MB的限制。
工作区就是上面我们git clone下来的整个项目目录My-ESP8266。
缓存区是一个隐藏的区域,用git add添加。
本地仓库也是隐藏的,用git commit命令将缓存区的文件提交到本地仓库。
用git push将本地仓库同步到云端。
上传文件列表ls -l tarballs/
git add file_1 file_2 file_3
多个文件用 空格 隔开。
文件比较多时可以使用通配符*添加所需要的文件。
也可以整个目录add,像这样:git add . 意思是把当前目录(.表示当前目录)里面的变动都加到缓存。
或者用git add tarballs/g*将目录tarballs中以g开头的文件添加到缓存。
或者像下面。
git add tarballs
git status
git status –sb
看看目录
可以看到,只添加了新文件,之前我们上传过的文件binutils-2.25.1.tar.gz,因为没有变化,所以并没有添加到缓存。
用use git reset HEAD
git reset HEAD tarballs/cloog-0.18.4.tar.gz
git status
git status -sb
可以看到tarballs/cloog-0.18.4.tar.gz已经从缓存中移除了。
git reset命令中的HEAD指向当前我们所在版本库,是一个地址指针的头。
看看日志git log
有3个commit,每个commit对应一个指针:
e07cfbf37e2af1fc1ded1b196178b0231e88a9c4
2eae215d0213343fa07f66a5d1116e24ae2f8406
d9c752f40aa055831eefa02b36b5e928c7fca155
再看看简短日志git log –oneline(一条提交信息用一行显示)
e07cfbf、2eae215、d9c752f是3个指针地址的头,HEAR当前指向master地址的头e07cfbf
所以下面两句作用是一样的。
git reset HEAD tarballs/cloog-0.18.4.tar.gz
git reset e07cfbf tarballs/cloog-0.18.4.tar.gz
例如:
git reset e07cfbf tarballs/expat-2.1.0.tar.gz
git status -sb
缓存清空了,有2个未操作的新文件。
之前我们上传过的文件binutils-2.25.1.tar.gz有问题,重新下载,和之前比较大小有变化:
添加目录tarballs到缓存
git add tarballs
看看状态:
tarballs/binutils-2.25.1.tar.gz是修改过Modified的文件
tarballs/cloog-0.18.4.tar.gz
tarballs/expat-2.1.0.tar.gz
是新Add的文件,也就是没有和云端同步过的文件。
git commit -m '提交多个文件'
看状态:
可以用git commit --amend打开编辑器修改。
如果想撤回,可以用:
git reset --soft撤回git commit –m
git reset --mix撤回git commit –m和git add
git reset –-hard回退git commit –m、git add和工作区
同步云端仓库git push
Your branch is ahead of 'origin/master' by 2 commits.
这表示在你之前已经有2个commit而没有push到远程分支上,所以需要先git push origin **将本地分支提到远程仓库。
如果不想同步云端,也可以用git reset --hard HEAD~x取消,这里的x表示的就是在这之前已经有多少次的提交,这句命令的意思就是直接回退到x 个commit之前
注意:这两次提交所改动的代码文件都没有了,慎用!
在我们这里:
git reset --hard HEAD~2
git status
git status -sb
缓存已经清空了,目录中相关的文件也删除了。
在上面的操作中我们先在gitee上创建仓库,再克隆到本地。如果我们在本地已经有了一个项目目录要上传的gitee上,可以像下面这样操作。
mkdir My-ESP32
cd My-ESP32
git init
git init的功能就是将本地目录初始化为本地仓库。
查看目录ls –la
多了一个隐藏目录.git
查看状态git status
touch README.md
nano README.md
写一些内容,保存,退出。
查看状态git status
git status –sb
?? README.md是一个新文件。
查看状态:
查看状态:
git remote add origin https://gitee.com/chentuo2000/My-ESP32.git
执行完这个命令在本地的.git/config中写了远程信息[remote "origin"]
Origin是Git默认的远程仓库名字,也可以改成别的名字,但最好是遵从习惯,这样你一看到origin就知道是远程仓库。
git push -u origin master
master是默认的本地分支,origin/master是默认远程分支origin/master。
查看云端仓库:
7. 分支
Origin默认远程服务器
origin/master默认远程分支
master默认本地分支
为了不受其他开发人员的影响,每个人可以在主分支上建立自己的专属分支,自己的开发工作完成后可以将自己分支上的工作合并到主分支。
因为每一次提交的历史记录都会被保存,所以当发生问题时,定位和修改造成问题的提交就容易多了。
Git分支是由指针管理的,所以创建、切换、合并、删除分支都非常快,非常适合大型项目的开发。
主分支(默认创建的Master分支)只用来发布重大版本(对于每个版本可以创建不同的标签,以便于查找),日常开发应该在另一条分支上进行。
例如,在一个项目的进行中,你遇到了一个问题,解决方案不确定,但是你不希望因此影响到当前的开发,那么你可以为此创建一个分支,分支包含目前主干上的所有内容,然后在分支上测试你的方案,而丝毫不影响主干的进行;如果可行那么可以通过合并分支功能将你的更新应用到主干,反之你可以放弃它。
1) 查看本地分支git branch
2) 查看远程分支git branch –-r
3) 查看所有分支git branch –-all
分支前有一个 * 号代表当前分支。
1) 创建分支:git branch <分支名称>
2) 切换分支:git checkout <分支名称>
3) 创建并切换分支:git checkout -b <分支名称>
1) 先切换到master分支:git checkout master
2) 再将分支的代码合并到master:git merge <分支名称>
在合并分支的时候如果代码会有冲突,需要自己去处理这些冲突。
1) 删除本地分支:git branch -d <分支名称>
2) 删除远程分支:git push origin <分支名称>
误删的分支可以恢复。
1) 使用git log查出分支的提交号
2) git branch <分支名称> <提交号>
即创建提交号历史版本的一个分支,分支名称随意。
1) 查询分支:git log
2) 查询分支简短显示:git log –oneline
3) 查看分支图:git log --graph
可以带参数:
git log --graph --pretty=oneline --abbrev-commit
git branch -m <当前分支名> <新的分支名>
其他的用法请看后面的参考文档。