Git命令的使用: 同时配置多个git仓库、mac电脑找不到.pub文件/查看仓库源、查看所在分支、 合并分支、一个项目连接多个仓库、一个项目多个分支、 回滚到上一个版本;git stash


零, 开发时 用的

分支情况

注意:

  1. master(mian):是生产分支,稳定的 一般不在这个分支上 进行修改
  2. develop : 是 开发分支,这个分支是 不稳定的
  3. feature :需求分支,一般来需求 都会在develop分支的基础上,新建一个分支,用于开发新的需求(feature-account-v1.0).
  4. 在需求分支上 改好 需求, 合并到 develop分支上。develop分支再合并到master分支上。

常用git命令:

  • 创建分支: git branch <name>
  • 创建并进入分支:git checkout -b <name>
  • 切换分支:git checkout <name>
  • 查看状态:git status (可以在,添加所有文件前 查看修改了 什么文件)
  • 添加所有文件:git add .
  • 提交:git commit -m "描述文字"
  • 拉取:git pull git pull origin master
  • 推送:git push git push origin master
  • 查看分支:git branch --list
  • 查看分支(包含远程分支):git branch -a
  • 合并其他分支到当前分支:git merge --no-ff -m '描述' < name > (一般用这个)
    比如将develop分支合并到master分支:在master分支上: git merge develop(一般不用)
    上述两种合并的区别:
0、将feature合并到master
         A---B---C feature
         /
D---E---F master

(1)git merge feature:
          A---B---C feature
         /         master
D---E---F 

这种方法会将 feature中的提交信息也放到master中 会看着乱。master回退上一版本是B;

(2)git merge --no-ff  feature:
          A---B---C feature
         /         \
D---E---F-----------G master
这种方法 master分支会清晰,回退到上一版本是F



(一) git命令

1.1 将本地的项目 上传到 对应的仓库 (步骤)

这里的本地开发的文件 不是从git仓库中clone下来的。

1.1 去自己做的文件目录下,打开git.bash (进去)
1.2 初始化: git init 对应的文件中 会多一个.git文件
1.3 连接远程仓库 git remote add origin 仓库地址

  • 报错:
    git error : remote origin already exists
  • 解决方法:
    1.1.1 先删除远程 Git仓库 git remote rm origin
    1.1.2 再添加远程Git仓库 git remote add origin 仓库地址

1.1.4 git add .
指定一个文件: git add src/views/page.vue
1.1.5 git commit -m "随意写"
1.1.6 git pull origin develop

  • 报错
    fatal: refusing to merge unrelated histories
  • 解决
    git pull origin master --allow-unrelated-histories

1.1.7 git push origin develop
完成

1.2 从Git仓库 中 克隆项目(步骤)

  • 对项目 有新修改 更新到仓库:
    1.2.1 git clone 仓库地址
    1.2.2 git add .
    1.2.3 git commit -m "随意写"
    1.2.4 git pull origin develop
    1.2.5 git push origin develop
  • 完成

1.3 git status 查看状态

Alt

image.png

1.4 git checkout -b develop 切分支

大项目中 前端一般在develop分支上

1.5 git branch 确认当前所在分支

git branch -a查看所有分支,包括远程分支

1.6 git remote -v 查看仓库源

1.7 删除本地不需要的分支

1.7.1 删除本地分支 git branch -d 分支名
1.7.2 删除远程分支 git push origin --delete 分支名

1.8 pull之后 看看哪里有什么修改

1.8.1 查看: git diff HEAD^
查看修改的文件 代码
注意:有时候 修改的地方很多,需要退出查看的话,按下: 英文状态下的 q 就可以退出。


(二) Git 同时使用 github gitee(同时使用多个git仓库)

2.1 生成SHH公钥

  ssh-keygen -t rsa -C "xxxxxxxxxx@xxx.com" 

2.2 文件 命名

//这个文件自己命名 是为了区分 github 和 gitee
Generating public/private rsa key pair.
Enter file in which to save the key (/Users/liujing/.ssh/id_rsa): id_rsa_github
//具体路径:
Enter file in which to save the key (C:\Users\64802/.ssh/id_rsa): C:\Users\64802/.ssh/id_rsa_gitlab

2.3 前面回车 后 提示输入该密钥的密码——直接回车

Enter passphrase (empty for no passphrase): 

2.4 再次直接回车

Enter same passphrase again: 

2.5 出现如下界面——成功

Your identification has been saved in id_rsa_test.
Your public key has been saved in id_rsa_test.pub.
The key fingerprint is:
SHA256:hUxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxV4 263xxxx631@qq.com
The key's randomart image is:
+---[RSA 3072]----+
|     .o     . .  |
|     .           |
|    o   . .      |
|     +   .       |
|    +  +S  .     |
|. ===.+ ... + .  |
|..+Eo+o..oo= o   |
|o+==OX ....#.    |
|*=+===+EoO.      |
+----[SHA256]-----+

2.6 打开文件 id_rsa_github.pub,复制文件中的公钥
我的路径是:C:\Users\64802\.ssh 下面

mac 电脑上可能找不到对应路径:按 command + shift +G,在弹框中 输路径就可以了

2.7 进入自己的github仓库
在 设置 中,添加新的SSH——将上面复制的公钥粘贴进入就好
以github为例,添加

2.8 gitee配置方式如上,在命名区分github就可以:

//这个文件自己命名 是为了区分 github 和 gitee
Generating public/private rsa key pair.
Enter file in which to save the key (/Users/liujing/.ssh/id_rsa): id_rsa_gitee

2.9 添加配置文件(重点)

.ssh/目录下 ,新建config文件:写入如下的内容

# github
Host github.com
HostName github.com
PreferredAuthentications publickey //这一行 可不写
IdentityFile ~/.ssh/id_rsa_github

# gitee
Host gitee.com
HostName gitee.com
PreferredAuthentications publickey // 这一行 可不写
IdentityFile ~/.ssh/id_rsa_gitee

//现在自己电脑上用的 
Host github.com
    HostName github.com
    IdentityFile ~/.ssh/id_rsa

Host gitee.com
    HostName gitee.com
    IdentityFile ~/.ssh/id_rsa_gitee

Host 192.168.1.110
     HostName 192.168.1.110
     IdentityFile ~/.ssh/id_rsa_gitblit

2.10 测试连接

# 测试 Github 连接
$ ssh -T git@github.com

# 测试 Gitee 连接
$ ssh -T git@gitee.com

第一次连接需要添加到可信任列表

The authenticity of host 'github.com (13.250.177.223)' can't be established.
ECDSA key fingerprint is SHA256:xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx.
ECDSA key fingerprint is MD5:xx:xx:xx:xx:xx:xx:xx:xx:xx:xx:xx:xx:xx:xx:xx:xx:xx.
Are you sure you want to continue connecting (yes/no)? yes     //输入 yes 并回车

2.11 完成
出现如下信息 表示完成 可以使用SSH

# Github
Hi Yourname! You've successfully authenticated, but GitHub does not provide shell access.

# Gitee
Hi Yourname! You've successfully authenticated, but GITEE.COM does not provide shell access.

(三)一个项目连接多个仓库

3.1 连接多个git仓库时 同时 pull push

PS D:\SCLWork\文荣手机端\W1穿综报产信息报表\项目\wenrongapp> git remote set-url --add origin ssh://scl@192.168.1.110:29418/~scl/wenrong_app_chuanzongbaobiao.git 
PS D:\SCLWork\文荣手机端\W1穿综报产信息报表\项目\wenrongapp> git remote -v
origin  git@gitee.com:shen-cailing/wenrong-app.git (fetch)
origin  git@gitee.com:shen-cailing/wenrong-app.git (push)
origin  ssh://scl@192.168.1.110:29418/~scl/wenrong_app_chuanzongbaobiao.git (push)
PS D:\SCLWork\文荣手机端\W1穿综报产信息报表\项目\wenrongapp> 

3.2 只是简单的想要给项目添加多个git仓库

git remote add workgit  '仓库地址'
git remote rename old_name new_name  //仓库名字 重命名

workgit 自己命名的
后续pull push 都是用 (workgit):

git pull workgit master
git push workgit master

刚刚新建git仓库时:将项目添加到仓库

 git push -u gitee platform

3.3 多个git仓库,多个账户信息

3.3.1 这是设置的全局的账户信息

git config --global user.name "xxx"
git config --global user.email "xxx@163.com"

// 取消全局
git config --global --unset user.name
git config --global --unset user.email

3.3.2查看自己配置的账户信息

git config --list

// 查看指定的配置信息
git config user.name

3.3.3 给项目 配置 不同的git账户信息
在对应项目下:

git config user.name "xxx"
git config user.email "xxx@163.com"

配置好之后 查看信息:
一个是全局的账户信息,一个是特殊的账户信息,会优先使用特殊的账户信息(下面的)
在这里插入图片描述

3.4 用邮箱 进行 匹配,账号

在这里插入图片描述

(四)、合并分支 merge

首先有两个分支,一个是master分支(本地开发分支),一个prod分支(正式分支);
在master分支上开发完,将master分支合并到prod分支上

4.1 步骤(都是在 本地分支上操作)
(1) 在本地master分支上开发完后,先pull 再push 将修改的内容都更新一下。
(2) 将分支切换到 本地prod分支 (注意:本地分支没有origin)(也可以用 git checkout master 切换)
image.png

(3) 切换到prod分支后,先pull一下,代码同步。
(4) 合并 - 合并分支 (也可以用git命令:git merge master 合并)
注意:在 ‘合并到的分支’ 下(这里是prod分支) 操作,选择合并的分支(这里是本地的master)
一下图只是看 分支-合并分支在哪里:

image.png

(5) 合并操作完成,push 就好(这里是prod分支上操作)

(五)、git revert -n 版本号撤销某个版本的操作

特别注意:git revert -n 版本号 只是撤销这个版本号 提交的修改,不影响其他版本号

步骤:

5.1 git log 查看所有的版本信息
git log 查看仓库的所有版本号信息
5.2 git revert -n 版本号 撤销到对应的版本号
目标版本号
代码
5.3 执行完前面的代码 会产生 冲突
执行完冲突后,git add . git commit -m '提交信息' git push origin master push到仓库

5.4 再来查看版本信息 会发现多了一个版本信息
新多出来的版本
5.5 最后的结果
撤销的目标版本
结果

注意:从结果可以看到,只撤销了对应版本的操作(这里是page.vue文件不见了),但是不影响huigun.vue的文件

(六)、git reset --hard 版本号

退回到 这个版本状态,其后面的版本都会没有

步骤:
6.1 git log 查看所有版本:
查看所有版本
6.2 git reset --hard 版本号 回退到对应的版本号

注意仔细看 回退的结果 中间的版本号里的信息都不见了:

注意回退结果

6.3 将结果推送上去

注意:git push 可能会报错 需要git push -f 强制推送

推送

6.4 代码结果:
在这里插入图片描述

(七) 恢复 单个文件 到上一版本

7.1查看对应文件的版本信息
查看对应文件的版本信息
7.2 git checkout 版本信息 文件路径
在这里插入图片描述
7.3将代码 push 上去

7.4结果
结果

(八)恢复多个文件/恢复文件夹

//恢复单个文件
git checkout 版本信息 src/views/ceshi.vue

//恢复多个文件 用通配符 *
git checkout 版本信息 src/views/ce*.vue

//恢复文件夹
git checkout 版本信息 src/views/

(九) git stash

项目中 有多个分支 1 2, 当前在分支1 中开发,但是现在需要切换到分支2处理其他的问题.
如果不将当前分支的代码commit 使当前分支目录干净是不被允许切换的.
所以需要用stash 暂存 代码 , 是当前分支目录干净 就可以切换了

// 保存当前未 commit 的代码
git stash

//保存当前未 commit 的代码 且 添加备注
git stash save "自己写的备注"

// 列出所有的stash记录  多个记录可以看版本
git stash list

//删除 stash 的所有记录
git stash clear

//应用最近一次的 stash
git stash apply

//应用最近一次的 stash 且 删除该记录
git stash pop

//删除最近一次的stash
git stash drop

自己的运用

PS D:\SCLWorks> git stash save "工位机布轴数修改"
Saved working directory and index state On gwj: 工位机修改

PS D:\SCLWorks> git stash save "app布轴数修改"
Saved working directory and index state On master: app修改

//有这么两条stash 记录
PS D:\SCLWorks> git stash list  
stash@{0}: On master: app修改
stash@{1}: On gwj: 工位机修改

//应用指定记录于当前分支
PS D:\SCLWorks\常山纺织APP\任务\w5-收布落布\csappweb> git stash pop 1

十、在本地commit时,想要修改commit信息

提交了commit信息 但是还没有 push到仓库 ,可以修改信息

// 1、可以看到所有版本
git log
// 2、输入一下命令
git commit --amend
// 3、输入 i 插入模式
修改一下 commit的那串文字信息
// 4、文字修改好了 Esc 、 然后 :wq 保存退出
// 5、然后接下来 push 操作就可以
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值