写点什么

Git,GitHub 和 Gitee

作者:阿柠xn
  • 2022 年 9 月 29 日
    陕西
  • 本文字数:3192 字

    阅读完需:约 10 分钟

Git,GitHub 和 Gitee

git 是一个版本控制工具


github 是一个用 git 做版本控制的项目托管平台。Gitee 同理

主流版本控制器

  • Git

  • SVN(Subversion)

  • CVS(Concurrent Versions System)

  • VSS(Micorosoft Visual SourceSafe)

  • TFS(Team Foundation Server)

  • Visual Studio Online


版本控制产品非常的多(Perforce、Rational ClearCase、RCS(GNU Revision Control System)、Serena Dimention、SVK、BitKeeper、Monotone、Bazaar、Mercurial、SourceGear Vault),现在影响力最大且使用最广泛的是 Git 与 SVN

版本控制分类

  1. 本地版本控制 记录文件每次的更新,可以对每个版本做一个快照,或是记录补丁文件,适合个人用,如 RCS。

  2. 集中版本控制 SVN 所有的版本数据都保存在服务器上,协同开发者从服务器上同步更新或上传自己的修改。 所有的版本数据都存在服务器上,用户的本地只有自己以前所同步的版本,如果不连网的话,用户就看不到历史版本,也无法切换版本验证问题,或在不同分支工作。而且,所有数据都保存在单一的服务器上,有很大的风险这个服务器会损坏,这样就会丢失所有的数据,当然可以定期备份。代表产品:SVN、CVS、VSS

  3. 分布式版本控制 Git 每个人都拥有全部的代码!安全隐患!

  4. 所有版本信息仓库全部同步到本地的每个用户,这样就可以在本地查看所有版本历史,可以离线在本地提交,只需在连网时 push 到相应的服务器或其他用户那里。由于每个用户那里保存的都是所有的版本数据,只要有一个用户的设备没有问题就可以恢复所有的数据,但这增加了本地存储空间的占用。

  5. 不会因为服务器损坏或者网络问题,造成不能工作的情况!

Git 与 SVN 的主要区别

SVN 是集中式版本控制系统,版本库是集中放在中央服务器的,而工作的时候,用的都是自己的电脑,所以首先要从中央服务器得到最新的版本,然后工作,完成工作后,需要把自己做完的活推送到中央服务器。集中式版本控制系统是必须联网才能工作,对网络带宽要求较高。


Git 是分布式版本控制系统,没有中央服务器,每个人的电脑就是一个完整的版本库,工作的时候不需要联网了,因为版本都在自己电脑上。协同的方法是这样的:比如说自己在电脑上改了文件 A,其他人也在电脑上改了文件 A,这时,你们两之间只需把各自的修改推送给对方,就可以互相看到对方的修改了。Git 可以直接看到更新了哪些代码和文件!


Git 是目前世界上最先进的分布式版本控制系统。

基本的 linux 命令

因为 git bash 使用的是 Linux 的基本命令所以应该了解一些基本的。git cmd 就是使用 windows 下的基本命令。


1)、cd : 改变目录。

2)、cd . . 回退到上一个目录,直接 cd 进入默认目录

3)、pwd : 显示当前所在的目录路径。

4)、ls(ll): 都是列出当前目录中的所有文件,只不过 ll(两个 ll)列出的内容更为详细。

5)、touch : 新建一个文件 如 touch index.js 就会在当前目录下新建一个 index.js 文件。

6)、rm: 删除一个文件, rm index.js 就会把 index.js 文件删除。

7)、mkdir: 新建一个目录,就是新建一个文件夹。

8)、rm -r : 删除一个文件夹, rm -r src 删除 src 目录 rm -rf / 切勿在 Linux 中尝试!删除电脑中全部文件! 9)、mv 移动文件, mv index.html src index.html 是我们要移动的文件, src 是目标文件夹,当然, 这样写,必须保证文件和目标文件夹在同一目录下。

10)、reset 重新初始化终端/清屏。

11)、clear 清屏。

12)、history 查看命令历史。

13)、help 帮助。

14)、exit 退出。

15)、#表示注释

Git 的基本理论

Git 本地有三个工作区域:工作目录(Working Directory)、暂存区(Stage/Index)、资源库(Repository 或 Git Directory)。如果在加上远程的 git 仓库(Remote Directory)就可以分为四个工作区域。文件在这四个区域之间的转换关系如下:


  • Workspace:工作区,就是你平时存放项目代码的地方

  • Index / Stage:暂存区,用于临时存放你的改动,事实上它只是一个文件,保存即将提交到文件列表信息

  • Repository:仓库区(或本地仓库),就是安全存放数据的位置,这里面有你提交到所有版本的数据。其中 HEAD 指向最新放入仓库的版本

  • Remote:远程仓库,托管代码的服务器,可以简单的认为是你项目组中的一台电脑用于远程数据交换

工作流程

git 的工作流程一般是这样的:


1、在工作目录中添加、修改文件;


2、将需要进行版本管理的文件放入暂存区域;


3、将暂存区域的文件提交到 git 仓库。


因此,git 管理的文件有三种状态:已修改(modified),已暂存(staged),已提交(committed)

本地仓库搭建

1、创建全新的仓库,需要用 GIT 管理的项目的根目录执行:


# 在当前目录新建一个Git代码库$ git init
复制代码


2、执行后可以看到,仅仅在项目目录多出了一个.git 目录,关于版本等的所有信息都在这个目录里面。

克隆远程仓库

1、另一种方式是克隆远程目录,由于是将远程服务器上的仓库完全镜像一份至本地


# 克隆一个项目和它的整个代码历史(版本信息)$ git clone [url]  # https://gitee.com/kuangstudy/openclass.git
复制代码

GitHub 删除仓库

仓库的 setting 里,在 option 那一栏,滑到最底下有一个 delete,输入仓库的名字就可以删除了。

GitHub 创建仓库

license 选项是决定你的项目的开源协议的,add a readme file 将会在仓库下方有一个阅读文档。 添加文件,addfile 里的 uploadfile

GIT 文件操作

版本控制就是对文件的版本控制,要对文件进行修改、提交等操作,首先要知道文件当前在什么状态,不然可能会提交了现在还不想提交的文件,或者要提交的文件没提交上。


  • Untracked: 未跟踪, 此文件在文件夹中, 但并没有加入到 git 库, 不参与版本控制. 通过 git add 状态变为 Staged.

  • Unmodify: 文件已经入库, 未修改, 即版本库中的文件快照内容与文件夹中完全一致. 这种类型的文件有两种去处, 如果它被修改, 而变为 Modified. 如果使用 git rm 移出版本库, 则成为 Untracked 文件

  • Modified: 文件已修改, 仅仅是修改, 并没有进行其他的操作. 这个文件也有两个去处, 通过 git add 可进入暂存 staged 状态, 使用 git checkout 则丢弃修改过, 返回到 unmodify 状态, 这个 git checkout 即从库中取出文件, 覆盖当前修改 !

  • Staged: 暂存状态. 执行 git commit 则将修改同步到库中, 这时库中的文件和本地文件又变为一致, 文件为 Unmodify 状态. 执行 git reset HEAD filename 取消暂存, 文件状态为 Modified

查看文件状态

上面说文件有 4 种状态,通过如下命令可以查看到文件的状态:


#查看指定文件状态git status [filename]#查看所有文件状态git status
复制代码

忽略文件

有些时候我们不想把某些文件纳入版本控制中,比如数据库文件,临时文件,设计文件等


在主目录下建立".gitignore"文件,此文件有如下规则:


  1. 忽略文件中的空行或以井号(#)开始的行将会被忽略。

  2. 可以使用 Linux 通配符。例如:星号(*)代表任意多个字符,问号(?)代表一个字符,方括号([abc])代表可选字符范围,大括号({string1,string2,...})代表可选的字符串等。

  3. 如果名称的最前面有一个感叹号(!),表示例外规则,将不被忽略。

  4. 如果名称的最前面是一个路径分隔符(/),表示要忽略的文件在此目录下,而子目录中的文件不忽略。

  5. 如果名称的最后面是一个路径分隔符(/),表示要忽略的是此目录下该名称的子目录,而非文件(默认文件或目录都忽略)。


#为注释*.txt        #忽略所有 .txt结尾的文件,这样的话上传就不会被选中!!lib.txt     #但lib.txt除外/temp        #仅忽略项目根目录下的TODO文件,不包括其它目录tempbuild/       #忽略build/目录下的所有文件doc/*.txt    #会忽略 doc/notes.txt 但不包括 doc/server/arch.txt
复制代码

使用码云

  1. 设置本机绑定 SSH 公钥,实现免密码登录!(免密码登录,这一步挺重要的,码云是远程仓库,我们是平时工作在本地仓库!)


# 进入 C:\Users\Administrator.ssh 目录# 生成公钥,下面的命令输入到gitbash里面去,会在上面的目录里多出两个文件ssh-keygen
复制代码


  1. 将公钥信息 public key 添加到码云账户中即可!

  2. 只有你将这个公钥信息加入到 gitee 或者 GitHub 中去,才能够识别你的机器让你 clone 代码。

  3. GitHub 同理。

发布于: 刚刚阅读数: 3
用户头像

阿柠xn

关注

还未添加个人签名 2022.08.29 加入

还未添加个人简介

评论

发布
暂无评论
Git,GitHub和Gitee_git_阿柠xn_InfoQ写作社区