Git——版本控制系统

Git是一个开源的分布式版本控制系统,它采用了分布式版本库的方式,不必服务器端软件支持。

早建分支,多用分支

1、git安装

在使用一个软件之前必须先安装它,git同理。Git 目前支持 Linux/Unix、Solaris、Mac和 Windows 平台上运行。

Windows平台

前往https://git-scm.com/downloads,下载客户端,

按提示安装,

安装完成。

在开始菜单里找到"Git"->"Git Bash",会弹出 Git 命令窗口,你可以在该窗口进行 Git 操作。

 Mac平台

前往链接:https://git-scm.com/download/mac,里面提供了四种安装思路:

1、使用Homebrew进行安装:

打开终端,输入命令:

brew install git

  即可安装。

2、Xcode:

安装软件Xcode,软件自带git。

3、Binary图形界面安装

打开网址:https://sourceforge.net/projects/git-osx-installer/

下载软件并安装。

4、Building from Source

打开网址:https://mirrors.edge.kernel.org/pub/software/scm/git/

下载安装。

 2、git配置

Git 提供了一个叫做 git config 的工具,专门用来配置或读取相应的工作环境变量。

这些环境变量,决定了 Git 在各个环节的具体工作方式和行为。这些变量可以存放在以下三个不同的地方:

  • /etc/gitconfig 文件:系统中对所有用户都普遍适用的配置。若使用 git config 时用 --system 选项,读写的就是这个文件。
  • ~/.gitconfig 文件:用户目录下的配置文件只适用于该用户。若使用 git config 时用 --global 选项,读写的就是这个文件。
  • 当前项目的 Git 目录中的配置文件(也就是工作目录中的 .git/config 文件):这里的配置仅仅针对当前项目有效。每一个级别的配置都会覆盖上层的相同配置,所以 .git/config 里的配置会覆盖 /etc/gitconfig 中的同名变量。

用户信息

配置个人的用户名称和电子邮件地址:

git config --global user.name "随便一个名字"
git config --global user.email 名字@xxx.com

如果用了 --global 选项,那么更改的配置文件就是位于你用户主目录下的那个,以后你所有的项目都会默认使用这里配置的用户信息。

如果要在某个特定的项目中使用其他名字或者电邮,只要去掉 --global 选项重新配置即可,新的设定保存在当前项目的 .git/config 文件里。

查看配置信息

要检查已有的配置信息,可以使用 git config --list 命令,如图:

 3、建立仓库及操作命令

这是激动人心的一步,毕竟我们费劲八叉的鼓捣半天,就是为了这一步(以及下一步)嘛~

git init

使用当前目录作为Git仓库,我们只需使它初始化。

git init

该命令执行完后会在当前目录生成一个 .git 目录。

或者,我们可以使用自己指定的目录作为Git仓库。

git init newproject

使用后,会在 newproject 目录下会出现一个名为 .git 的目录,所有 Git 需要的数据和资源都存放在这个目录中。

如果当前目录下有几个文件想要纳入版本控制,需要先用 git add 命令:

git add README

git clone

使用 git clone 拷贝一个 Git 仓库到本地,让自己能够查看该项目,或者进行修改。

执行命令:

 git clone [url]

[url] 为你想要复制的项目,就可以了。

git status

git status 以查看在你上次提交之后是否有修改。

$ git status
On branch master

Initial commit

Changes to be committed:
  (use "git rm --cached <file>..." to unstage)

    new file:   README
    new file:   hello.php

git diff

执行 git diff 来查看执行 git status 的结果的详细信息。

git diff 命令显示已写入缓存与已修改但尚未写入缓存的改动的区别。git diff 有两个主要的应用场景。

  • 尚未缓存的改动:git diff
  • 查看已缓存的改动: git diff --cached
  • 查看已缓存的与未缓存的所有改动:git diff HEAD
  • 显示摘要而非整个 diff:git diff --stat

git commit

使用 git add 命令将想要快照的内容写入缓存区, 而执行 git commit 将缓存区内容添加到仓库中。

所以,一般两个命令连续出现:

$ git add hello.py
$ git status -s
A  README
A  hello.py
$ git commit -m '第一次版本提交'
[master (root-commit) d32cf1f] 第一次版本提交
 2 files changed, 4 insertions(+)
 create mode 100644 README
 create mode 100644 hello.py

如果你觉得 git add 提交缓存的流程太过繁琐,Git 也允许你用 -a 选项跳过这一步。命令格式如下:

$ git commit -a

再执行以下命令:

 

$ git commit -am '第一次修改文件'
[master 71ee2cb] 第一次修改文件
 1 file changed, 1 insertion(+)

git reset HEAD

git reset HEAD 命令用于取消已缓存的内容。

操作如下:

$ git status -s
 M README
 M hello.py
$ git add .
$ git status -s
M  README
M  hello.py
$ git reset HEAD hello.py
Unstaged changes after reset:
M    hello.py
$ git status -s
M  README
M hello.py

现在你执行 git commit,只会将 README 文件的改动提交,而 hello.py 是没有的。

$ git commit -m '修改'
[master f50cfda] 修改
 1 file changed, 1 insertion(+)
$ git status -s
 M hello.py

可以看到 hello.py 文件的修改并未提交。

这时我们可以使用以下命令将 hello.php 的修改提交:

git rm

如果只是简单地从工作目录中手工删除文件,运行 git status 时就会在 Changes not staged for commit 的提示。

要从 Git 中移除某个文件,就必须要从已跟踪文件清单中移除,然后提交。可以用以下命令完成此项工作

$ git rm <file>

如果删除之前修改过并且已经放到暂存区域的话,则必须要用强制删除选项 -f

$ git rm -f <file>

如果把文件从暂存区域移除,但仍然希望保留在当前工作目录中,换句话说,仅是从跟踪清单中删除,使用 --cached 选项即可

$ git rm --cached <file>

git mv

git mv 命令用于移动或重命名一个文件、目录、软连接。

$ git mv README  README.md
$ ls
README.md

 

4、远程仓库

 如果你想通过 Git 分享你的代码或者与其他开发人员合作。 你就需要将数据放到一台其他开发人员能够连接的服务器上。

常用的便是GitHub和国内的码云(gitee)。

添加远程仓库

由于你的本地 Git 仓库和 远程仓库(GitHub、码云)之间的传输是通过SSH加密的,所以我们需要配置验证信息:

使用以下命令生成 SSH Key:

$ ssh-keygen -t rsa -C "youremail@example.com"

后面的 your_email@youremail.com 改为你的邮箱,之后会要求确认路径和输入密码,我们这使用默认的一路回车就行。成功的话会在 ~/ 下生成 .ssh 文件夹,进去,打开 id_rsa.pub,复制里面的 key

然后,登陆码云,选择右上角用户头像 -> 设置,然后选择 "SSH公钥",填写一个便于识别的标题,然后把用户主目录下的 .ssh/id_rsa.pub 文件的内容粘贴进去:

 

 接下来,创建一个仓库或选择一个已有仓库;并查看链接信息:

 

 

然后,我们在本地库上使用命令 git remote add 把它和 Gitee 的远程库关联:

$ git remote add origin git@gitee.com:XXXXXXX/rXXXXXXXX.git

之后,就可以正常地用 git push 和 git pull 推送了!

(才怪咧~!)

在这之后,才是踩坑的开始......

5、踩坑

关联远程仓库后,最好先查看远程库信息:

$ git remote -v
origin	git@gitee.com:XXXX/learn.git (fetch)
origin	git@gitee.com:XXXX/learn.git (push)

现在可以看到,origin 已经被关联到 Gitee 的远程库了。

但是如果此时直接使用 git push命令的话,大概率会出现错误:

git push error:failed to push some refs to https://xxxxxxx

这是因为远程仓库中有着本地仓库没有的文件,比如:README.md。

所以,我们需要先使用git pull命令,随后才能push新的代码到远程仓库。

随后,当你push代码时,会发现可能依然会报错:

error: GE007: Your push would publish a private email address.

这是虾米意思呢?

意思是说,你的邮箱地址有暴露风险,此时你需要这样做:

 

 

git的基本应用就这些,不排除后续使用过程中继续更新的可能~

posted @ 2020-07-03 11:14  qingyun_guo  阅读(182)  评论(0编辑  收藏  举报