Pre
Git - 入门到熟悉_Git基本概念与核心命令
Git - 入门到熟悉_分支管理
常用命令
git remote [-v]
git remote add origin http:xxx.xxx
git remote remove origin
git push --set-upstream origin master
git branch --track --set-upstream-to=origin/test test
演示
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$ git remote -v
origin https://gitee.com/yangshangwei/gitProject.git (fetch)
origin https://gitee.com/yangshangwei/gitProject.git (push)
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$ git remote add test https://gitee.com/yangshagnwei/test.git
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$ git remote -v
origin https://gitee.com/yangshangwei/gitProject.git (fetch)
origin https://gitee.com/yangshangwei/gitProject.git (push)
test https://gitee.com/yangshagnwei/test.git (fetch)
test https://gitee.com/yangshagnwei/test.git (push)
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$ git remote remove test
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$ git remote -v
origin https://gitee.com/yangshangwei/gitProject.git (fetch)
origin https://gitee.com/yangshangwei/gitProject.git (push)
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$
多个远程仓库演示
第一个仓库
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$ git remote -vv
origin https://gitee.com/yangshangwei/gitProject.git (fetch)
origin https://gitee.com/yangshangwei/gitProject.git (push)
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$ mkdir -p src/main/java/com/artisan
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$ echo 'package com.artisan' > src/main/java/com/artisan/Hello.java
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$ git status
On branch master
Your branch is up to date with 'origin/master'.
Untracked files:
(use "git add <file>..." to include in what will be committed)
src/
nothing added to commit but untracked files present (use "git add" to track)
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$ git add -A ;git commit -am '7 commit' ; git push
warning: LF will be replaced by CRLF in src/main/java/com/artisan/Hello.java.
The file will have its original line endings in your working directory
[master b685db4] 7 commit
1 file changed, 1 insertion(+)
create mode 100644 src/main/java/com/artisan/Hello.java
Enumerating objects: 9, done.
Counting objects: 100% (9/9), done.
Delta compression using up to 12 threads
Compressing objects: 100% (2/2), done.
Writing objects: 100% (8/8), 502 bytes | 502.00 KiB/s, done.
Total 8 (delta 0), reused 0 (delta 0), pack-reused 0
remote: Powered by GITEE.COM [GNK-6.4]
To https://gitee.com/yangshangwei/gitProject.git
9f302ff..b685db4 master -> master
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$ git status
On branch master
Your branch is up to date with 'origin/master'.
nothing to commit, working tree clean
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$ git branch -avv
* master b685db4 [origin/master] 7 commit
remotes/origin/master b685db4 7 commit
好了,提交到 https://gitee.com/yangshangwei/gitProject.git 分支了,我们去gitee上查看一把
第二个仓库
新建 仓库 gitProject2
首先我们先新建个仓库 gitProject2
上传至远程新仓库
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$ git remote add origin2 https://gitee.com/yangshangwei/gitProject2.git
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$ git remote
origin
origin2
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$ git remote -vv
origin https://gitee.com/yangshangwei/gitProject.git (fetch)
origin https://gitee.com/yangshangwei/gitProject.git (push)
origin2 https://gitee.com/yangshangwei/gitProject2.git (fetch)
origin2 https://gitee.com/yangshangwei/gitProject2.git (push)
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$ git push --set-upstream origin2 master
Enumerating objects: 20, done.
Counting objects: 100% (20/20), done.
Delta compression using up to 12 threads
Compressing objects: 100% (8/8), done.
Writing objects: 100% (20/20), 1.46 KiB | 749.00 KiB/s, done.
Total 20 (delta 1), reused 0 (delta 0), pack-reused 0
remote: Powered by GITEE.COM [GNK-6.4]
To https://gitee.com/yangshangwei/gitProject2.git
* [new branch] master -> master
Branch 'master' set up to track remote branch 'master' from 'origin2'.
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$
执行完 git push --set-upstream origin2 master 后 ,后面再 git push 其实是上传到了 origin2 分支,可以看下
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$ git branch -avv
* master b685db4 [origin2/master] 7 commit
remotes/origin/master b685db4 7 commit
remotes/origin2/master b685db4 7 commit
可以发下 master 对应的分支 为 origin2/master 。
orgin2 对应了我们的 git remote add origin2 https://gitee.com/yangshangwei/gitProject2.git gitProject2 项目 。
我们来验证下
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$ pwd
/d/opt/gitdemo/gitProject
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$ echo 'artisan git git git ' > README.MF
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$ git push
Everything up-to-date
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$ git status
On branch master
Your branch is up to date with 'origin2/master'.
Changes not staged for commit:
(use "git add <file>..." to update what will be committed)
(use "git restore <file>..." to discard changes in working directory)
modified: README.MF
no changes added to commit (use "git add" and/or "git commit -a")
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$ git add -A ;
warning: LF will be replaced by CRLF in README.MF.
The file will have its original line endings in your working directory
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$ git commit -am '8 commit';
[master 36a0f02] 8 commit
1 file changed, 1 insertion(+), 4 deletions(-)
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$ git push
Enumerating objects: 5, done.
Counting objects: 100% (5/5), done.
Delta compression using up to 12 threads
Compressing objects: 100% (2/2), done.
Writing objects: 100% (3/3), 284 bytes | 284.00 KiB/s, done.
Total 3 (delta 0), reused 0 (delta 0), pack-reused 0
remote: Powered by GITEE.COM [GNK-6.4]
To https://gitee.com/yangshangwei/gitProject2.git
b685db4..36a0f02 master -> master
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$
上传至远程原仓库
那如果要 push 到 原来的 origin 这个远程地址呢 ,执行 git push origin 指定分支名即可。
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$ git push origin
Enumerating objects: 5, done.
Counting objects: 100% (5/5), done.
Delta compression using up to 12 threads
Compressing objects: 100% (2/2), done.
Writing objects: 100% (3/3), 284 bytes | 284.00 KiB/s, done.
Total 3 (delta 0), reused 0 (delta 0), pack-reused 0
remote: Powered by GITEE.COM [GNK-6.4]
To https://gitee.com/yangshangwei/gitProject.git
b685db4..36a0f02 master -> master
artisan@LAPTOP-JF3RBRRJ MINGW64 /d/opt/gitdemo/gitProject (master)
$
当然了在IDEA中的操作就简单了
选择就可以了。
|