一、Git的安装
git安装有多种方式,这里写一下源代码构建安装的方式:
- 下载Git源代码压缩归档文件
wget https://mirrors.edge.kernel.org/pub/software/scm/git/git-2.26.2.tar.xz - 解压缩和解归档
xz -d git-2.26.2.tar.xz
tar -xf git-2.26.2.tar - 进入git源代码文件夹执行安装前的准备工作
cd git-2.26.2
yum install zlib-devel libcurl-devel
./configure --prefix=/usr/local - 构建和安装
make && make install - 检查安装是否成功
git --version
二、Git的工作流程
基本的 Git 工作流程如下:
在工作区中修改文件。
将你想要下次提交的更改选择性地暂存,这样只会将更改的部分添加到暂存区。
提交更新,找到暂存区的文件,将快照永久性存储到 Git 目录。
小结:
1、任何对象都是在工作区中诞生和被修改;
2、任何修改都是从进入index区才开始被版本控制;
3、只有把修改提交到本地仓库,该修改才能在仓库中留下痕迹;
4、与协作者分享本地的修改,可以把它们push到远程仓库来共享。
三、Git的常用命令
git init
—— 新建git仓库
git add 文件/文件夹
—— 将文件添加到缓存区中
git add -A
--- 添加所有内容到缓存区中
git status
——— 查看git状态
git commit -m ‘提交信息’
—— 将缓存区中的内容全部提交到git本地仓库中
git log
——- 查看提交日志
git reset -- hard HEAD
—— 让工作目录中的内容和仓库中的内容保持一致
git reset --hard HEAD^
—— 回到上一个版本
git reset -- hard 版本号
—— 回到指定的版本
git checkout 文件名
—— 从暂存区中恢复工作目录中的内容(让工作区中的指定文件,回到上次提交的时候的状态)
git clone <url>
- 将服务器上的项目(仓库)克隆 (使用https地址需要输入密码,使用ssh地址需要添加公钥)
git remote add origin 地址
----- 关联远程仓库(只需要关联一次)
git push [-u] origin master
----- 提交(-u在第一次提交分支的时候才用)
git push
— 将本地仓库的内容提交到远程仓库master分支上
git push origin 分支名
— 将本地仓库的内容提交到远程仓库对应的分支上, 如果分支不存在会自动创建
git pull
— 将远程仓库中的内容更新到本地仓库和工作区中
git reflog
— 查看未来的版本号。
四、分支管理
创建仓库会默认给我们创建一个master分之,这个分之一般作为提交和发布分之;开发一般会自己创建一个develop分之,用来开发和测试;多人协作的时候还可能根据不同的人或者(不同的功能)创建不同的分之,用来独立开发
常见分之: master(主要是合并develop), develop(主要合并下面的其他分支), 功能/人员分之(开发)
git branch [-a]
- 查看分之
git branch 分之名
- 创建分之
git checkout 分支名
- 切换分之
git checkout -b 分之名
- 切换并创建新的分之
git diff 分之1 分之2
- 查看两个分之之间的差异
git merge 分之名
- 让当前分之和指定分之进行合并
注意: 切换分之、push、pull,这些操作前要保证工作区是clean
怎么避免冲突: 不要发生多个分之对同一个文件在同一个版本下进行修改(和同伴确认和商量)
五、Git连接远程仓库时的免密方法(以gitee(码云)为例)
1、先ls -a | gerp .ssh 看一下电脑有没有一个.ssh的隐藏文件。
2、cd .ssh
3、ssh-keygen -t rsa -b 2048 -C "youemail@qq.com" (-C 后填写自己的邮箱)之后输入码云注册的密码。
4、cat ~/.ssh/id_rsa.pub 就会出现公钥,将其复制下来部署到Gitee个人设置的SSH公钥部署中。