git使用问题

目录

 

git使用

链接github 下面语句生成ssh key 

问题1

问题2

将本地库上传到新的远程库上

将远程库克隆到本地库

创建分枝

合并的时候如果存在冲突(在分支以及master中均存在修改的时候,无法进行合并)

bug分支:

多人协作:

1.将本地分枝推到远程

2.在本地新建一个文件来模拟另一个可以提交的用户(并克隆远程)

3.创建远程origin/dev分枝到本地,这样用户就也能在dev 上进行开发了git checkout -b dev origin/dev

4.小伙伴们已经向origin/dev分支上推送了提交,而我在我的目录文件下也对同样的文件同个地方作了修改,也试图推送到远程库时,如下:切换到用户1上,对用户1的readme.md文件进行修改,增加“用户1 dev”, git push 发现报错

因此:多人协作工作模式一般是这样的:

Git基本常用命令如下:


git使用

链接github 下面语句生成ssh key 

 ssh-keygen -t rsa -C "[email protected]"

将生成的key 复制到github → setting → key 

配置的是个人的用户名称和电子邮件地址。这两条配置很重要,每次 Git 提交时都会引用这两条信息,说明是谁提交了更新,所以会随更新内容一起被永久纳入历史记录
git config --global user.name "zbzckai"
git config --global user.name "[email protected]'



测试运行下面这句话的时候可能会报错。

问题1

$ ssh -T [email protected]
[email protected]: Permission denied (publickey).

解决办法:

将 ssh-keygen 命令时的位置找到id_rsa和id_rsa.pub文件,再复制到./ssh下,该文件默认安装在了C:\Users\Administrator

问题2

ping github.com  请求超时

原因dns无法解析

解决办法:

1.查询github.com 的IP http://github.com.ipaddress.com/ 


2.打开 C:\Windows\System32\drivers\etc 文件下的 hosts文件
在文件末尾添加 : 192.30.253.112 github.com 保存 . 

git常用的操作:

git clone ***git  克隆远程库

git push 向远程推送

git status 查看本地代码库

git add 文件名 .点代表所有文件,把文件增加到暂存区

git commit -m "修改说明"  提交本次修改  

git reflog 查看版本号

git reset --hard ***回到某个版本下



将本地库上传到新的远程库上

1.建立远程库

2.在本地库的文件夹下运行git remote add origin  **.git  远程库的ssh 路径

3.git push -u origin master 第一次连接要这样输入

把本地库的内容推送到远程,使用 git push命令,实际上是把当前分支master推送到远程。

  由于远程库是空的,我们第一次推送master分支时,加上了 –u参数,Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令。

将远程库克隆到本地库

1.找到合适的文件夹下,git clone [email protected]:zbzckai/TensorFlow_train.git  这样就将远程库克隆岛本地



创建分枝

  查看分支:git branch

  创建分支:git branch name

  切换分支:git checkout name

  创建+切换分支:git checkout –b name

  合并某分支到当前分支:git merge name

  删除分支:git branch –d name

实例:

git checkout -b 分枝名字 (相当于 git branch 分枝 + git checkout 分枝)

在分支中改变源数据并提交

在文件中增加1111.

合并的时候如果存在冲突(在分支以及master中均存在修改的时候,无法进行合并)

解决办法:在master|mergeing的时候重新add commit

①修改dev

②修改master

③合并出现冲突,增加add 并commit



bug分支:

 在开发中,会经常碰到bug问题,那么有了bug就需要修复,在Git中,分支是很强大的,每个bug都可以通过一个临时分支来修复,修复完成后,合并分支,然后将临时的分支删除掉。(在分支上进行操作的时候如果发现了bug问题,此时你想在不保存修改,此时是退不出该分支的)

  比如我在开发中接到一个404 bug时候,我们可以创建一个404分支来修复它,但是,当前的dev分支上的工作还没有提交。比如如下:

 并不是我不想提交,而是工作进行到一半时候,我们还无法提交,比如我这个分支bug要2天完成,但是我issue-404 bug需要5个小时内完成。怎么办呢?还好,Git还提供了一个stash功能,可以把当前工作现场 ”隐藏起来”,等以后恢复现场后继续工作。如下:

所以现在我可以通过创建issue-404分支来修复bug了。

  首先我们要确定在那个分支上修复bug,比如我现在是在主分支master上来修复的,现在我要在master分支上创建一个临时分支,演示如下:

  修复完成后,切换到master分支上,并完成合并,最后删除issue-404分支。演示如下:

 现在,我们回到dev分支上干活了

 工作区是干净的,那么我们工作现场去哪里呢?我们可以使用命令 git stash list来查看下。如下:

工作现场还在,Git把stash内容存在某个地方了,但是需要恢复一下,可以使用如下2个方法:

  1. git stash apply恢复,恢复后,stash内容并不删除,你需要使用命令git stash drop来删除。
  2. 另一种方式是使用git stash pop,恢复的同时把stash内容也删除了。(一定要用完了记着删掉这个stash,不然pull的时候会报这个错误$ git pull
    Enter passphrase for key '/c/Users/zhangzhongkai/.ssh/id_rsa':
    error: Your local changes to the following files would be overwritten by merge:
            README.md
    Please commit your changes or stash them before you merge.
    Aborting
    Updating 089c97c..33f3d4f

  演示如下

当你的分枝整理完了以后在进行合并就好了



多人协作:

1.将本地分枝推到远程

(git push origin local_branch:remote_branch,将本地的分枝推到远程的新分支上去

local_branch必须为你本地存在的分支,remote_branch为远程分支,如果remote_branch不存在则会自动创建分支。

类似,git push origin :remote_branch,local_branch留空的话则是删除远程remote_branch分支。

2.在本地新建一个文件来模拟另一个可以提交的用户(并克隆远程)

3.创建远程origin/dev分枝到本地,这样用户就也能在dev 上进行开发了
git checkout -b dev origin/dev

修改文件 readme.md 增加“用户2 dev”git push 上传到远程作为用户2 的修改

4.小伙伴们已经向origin/dev分支上推送了提交,而我在我的目录文件下也对同样的文件同个地方作了修改,也试图推送到远程库时,如下:切换到用户1上,对用户1的readme.md文件进行修改,增加“用户1 dev”, git push 发现报错

由上面可知:推送失败,因为我的小伙伴最新提交的和我试图推送的有冲突,解决的办法也很简单,上面已经提示我们,先用git pull把最新的提交从origin/dev抓下来,然后在本地合并,解决冲突,再推送。

git pull也失败了,原因是没有指定本地dev分支与远程origin/dev分支的链接,根据提示,设置dev和origin/dev的链接:如下:

git pull也失败了,原因是没有指定本地dev分支与远程origin/dev分支的链接,根据提示,设置dev和origin/dev的链接

git branch --set-upstream-to=dev origin/dev

如果没有pull失败说明已经建立过连接了。

这回git pull成功,但是合并有冲突,需要手动解决,解决的方法和分支管理中的 解决冲突完全一样。解决后,提交,再push:

因此:多人协作工作模式一般是这样的:

  1. 首先,可以试图用git push origin branch-name推送自己的修改.
  2. 如果推送失败,则因为远程分支比你的本地更新早,需要先用git pull试图合并。
  3. 如果合并有冲突,则需要解决冲突,并在本地提交。再用git push origin branch-name推送。

Git基本常用命令如下:

  mkdir:         XX (创建一个空目录 XX指目录名)

  pwd:          显示当前目录的路径。

  git init          把当前的目录变成可以管理的git仓库,生成隐藏.git文件。

  git add XX       把xx文件添加到暂存区去。

  git commit –m “XX”  提交文件 –m 后面的是注释。

  git status        查看仓库状态

  git diff  XX      查看XX文件修改了那些内容

  git log          查看历史记录

  git reset  --hard HEAD^ 或者 git reset  --hard HEAD~ 回退到上一个版本

  (如果想回退到100个版本,使用git reset –hard HEAD~100 )

  cat XX         查看XX文件内容

  git reflog       查看历史记录的版本号id

  git checkout -- XX  把XX文件在工作区的修改全部撤销。

  git rm XX          删除XX文件

  git remote add origin  [email protected]:zbzckai/TensorFlow_train.git关联一个远程库

  git push –u(第一次要用-u 以后不需要) origin master 把当前master分支推送到远程库

  git clone  [email protected]:zbzckai/TensorFlow_train.git  从远程库中克隆

  git checkout –b dev  创建dev分支 并切换到dev分支上

  git branch  查看当前所有的分支

  git checkout master 切换回master分支

  git merge dev    在当前的分支上合并dev分支

  git branch –d dev 删除dev分支

  git branch name  创建分支

  git stash 把当前的工作隐藏起来 等以后恢复现场后继续工作

  git stash list 查看所有被隐藏的文件列表

  git stash apply 恢复被隐藏的文件,但是内容不删除

  git stash drop 删除文件

  git stash pop 恢复文件的同时 也删除文件

  git remote 查看远程库的信息

  git remote –v 查看远程库的详细信息

  git push origin master  Git会把master分支推送到远程库对应的远程分支上

猜你喜欢

转载自blog.csdn.net/zbzckaiA/article/details/84961049
今日推荐