Git 远程操作仓库

Git 远程操作仓库(Github)

引入

使用到的 Git 命令都在本地执行,如果你想通过 Git 分享你的代码或者与其他开发人员合作。 你就需要将数据放到一台其他开发人员能够连接的服务器上。当然这台服务器可以是一台联网的电脑,也可以是GitHub托管平台。嘿,通过Git操作GitHub上的仓库,想想还是刺激的,开始吧我们。

[外链图片转存中…(img-QB1rhKtW-1600961726834)]

工作区可以commit到本地仓库,本地仓库可以通过push上传到Github托管,而本地也能通过pull指令下载云端的仓库。常见的这4个操作如下:
  • git remote 远程仓库操作

  • git fetch 从远程获取代码库

  • git pull 下载远程代码并合并

  • git push 上传远程代码并合并

建立连接

在所有的工作开始之前,我们必须要建立起Github和本地的连接,分为4步:

1.注册一个GitHub account

2.生成本地密钥sshKey

# 执行如下指令
# 这条指令生成本地shhKey,一般放在~/.ssh目录下的id_rsa.pub文件
# 执行完毕之后去目录下找到它
$ ssh-keygen -t rsa -C "你的邮箱@qq.com"

在这里插入图片描述

3.GitHub端确认sshKey

我想你肯定找到了sshKey,是时候去gitHub上确认sshKey了
进入目:/settings/keys
新建SSH keys

在这里插入图片描述

4.git bash中输入指令以确认连接

# 执行如下指令连接到Github托管:
$ ssh -T [email protected]
# 下图展示连接成功

在这里插入图片描述

创建本地仓库

# 接下来肯定是你很熟悉的操作了,我们在本地新建一个仓库,叫做testRepository,用于测试:
$ mkdir testRepository

$ cd testRepository/

$ git init

$ vim README.md

$ vim hello.cpp

$ ls
hello.cpp  README.md

$ git add .

$ git commit . -m 'commit 1: add README and hello.c'

$ git log --oneline
3b5640b (HEAD -> master) commit 1: add README and hello.c

创建远程库并且push提交

  • 手动在GitHub上创建一个空的仓库,取名为testRepository
  • 然后再git bash执行如下指令:
# 添加一个新的远程仓库,指定一个别名,以便将来引用
$ git remote add [shortname] [url]
# push添加到仓库
$ git push -u origin master

# eg:
$ ssh -T [email protected]												# 连接GitHUb
$ git remote add origin [email protected]:LinXiaoDe/testRepository.git	# 连接某一个仓库
$ git push -u origin master											# 执行操作
  • 成功push
    在这里插入图片描述

常用操作

0.连接仓库

$ ssh -T [email protected]												# 连接GitHUb
$ git remote add origin [email protected]:LinXiaoDe/testRepository.git	# 连接某一个仓库

1. 查看当前的远程库

  • $ git remote:查看当前配置有哪些远程仓库,可以用命令:
$ git remote
origin
$ git remote -v
origin  [email protected]:LinXiaoDe/testRepository.git (fetch)
origin  [email protected]:LinXiaoDe/testRepository.git (push)

执行时加上 -v 参数,你还可以看到每个别名的实际链接地址。


2.提取远程仓库

Git 有两个命令用来提取远程仓库的更新。

  • git fetch [alias] :从远程仓库[alias]下载新分支与数据
该命令执行完后需要执行 git merge 远程分支到你所在的分支
  • git merge [alias]/[branch]:从远端仓库提取数据并尝试合并到当前分支:
该命令就是在执行 git fetch 之后紧接着执行 git merge 远程分支到你所在的任意分支
  • eg:
假设你配置好了一个远程仓库,并且你想要提取更新的数据,你可以首先执行
$ git fetch [alias]	 			# 告诉 Git 去获取它有你没有的数据,然后你可以执行 
$ git merge [alias]/[branch]	# 将服务器上的任何更新(假设有人这时候推送到服务器了)合并到你的当前分支
  • eg:
# 假设我们在 Github 在线修改:" README.md" 
# 然后我们在本地更新修改。
$ git fetch origin								# 获取你没有的数据

remote: Counting objects: 3, done.
remote: Compressing objects: 100% (2/2), done.
remote: Total 3 (delta 0), reused 0 (delta 0), pack-reused 0
Unpacking objects: 100% (3/3), done.
From github.com:tianqixin/runoob-git-test
0205aab..febd8ed  master     -> origin/master 	# 说明 master 分支已被更新,我们可以使用以下命令将更新同步到本地:

$ git merge origin/master						# 将服务器上的任何更新(假设有人这时候推送到服务器了)合并到你的当前分支

Updating 0205aab..febd8ed
Fast-forward
 README.md | 1 +
 1 file changed, 1 insertion(+)

3.推送到远程仓库

  • git push [alias] [branch]:推送你的新分支与数据到某个远端仓库命令:

  • eg

$ git push origin master    # 推送到 Github

重新回到我们的 Github 仓库,可以看到文件已经提交上来了:


4. 删除远程仓库

  • git remote rm [alias]:删除远程仓库你可以使用命令:

  • eg

$ git remote -v
origin    [email protected]:tianqixin/runoob-git-test.git (fetch)
origin    [email protected]:tianqixin/runoob-git-test.git (push)

# 添加仓库 origin2
$ git remote add origin2 [email protected]:tianqixin/runoob-git-test.git

$ git remote -v
origin    [email protected]:tianqixin/runoob-git-test.git (fetch)
origin    [email protected]:tianqixin/runoob-git-test.git (push)
origin2    [email protected]:tianqixin/runoob-git-test.git (fetch)
origin2    [email protected]:tianqixin/runoob-git-test.git (push)shell

# 删除仓库 origin2
$ git remote rm origin2
$ git remote -v
origin    [email protected]:tianqixin/runoob-git-test.git (fetch)
origin    [email protected]:tianqixin/runoob-git-test.git (push)

猜你喜欢

转载自blog.csdn.net/weixin_44307065/article/details/108785930