01、版本管理-GIT

一、版本控制

版本控制,通过文档控制记录各个模块的改动,并给每次改动添加序号,用于存储、追踪目录和文件的修改历史。

二、版本控制软件

  • GIT 分布式版本控制系统
  • SVN 集中式版本控制系统

三、git安装

  1、git下载
    - https://git-scm.com/downloads
    - https://pan.baidu.com/s/1kU5OCOB#list/path=%2Fpub%2Fgit
    - 360软件管家
  2、安装git(不要出现中文路径和空格)
  3、配置环境变量(我的电脑 — 右键属性 — 高级系统设置 — 高级 — 环境变量)
    - git命令是bin目录下
  4、检测git是否安装成功
    - cmd 打开命令行
    - 查看git版本
        $ git  - -version 
    - 查看帮助
        $ git help

四、windows命令行常用命令

  • dir 文件列表
  • cls 清屏
  • del 删除文件
  • cd 改变当前目录
  • copy 拷贝文件

Git Bash常用命令(和Linux是一致)
ls 文件列表
cd 改变当前目录
copy 拷贝文件
rm 删除文件
ctrl + l 清屏

五、git命令操作 —— 本地

  • 初始化本地git仓库
  - 切换到仓库文件目录中
     $ cd /dir
  - 初始化本地仓库
    $ git init
  • 添加本地git忽略清单 .gitignore 【说明哪些文件是不需要被管理的】
    忽略规则是一行一个(根目录和其他目录,目录名相同时,即加上对应路径,如果是根目录则是“/”);
$ echo img >> .gitignore    // 其实即是创建一个.gitignore文件,并向内容“img”输出到该文件中 【在windows中不方便创建这种文件】

在项目开发中,有时候想把某些目录或文件加入忽略规则中,但在清单中添加之后发现是无效的。即是某些文件已经被纳入了版本管理中,则修改. gitignore是无效的。解决方法:
$ git rm -r --cached .
$ git add .
$ git commit -m '更新gitignore忽略清单'
最好是在项目开始时,创建好. gitignore文件!

  • 查看本仓库的变更状态
  - $ git status
  - $ git status -s     //   输出简要的变更日志

文件状态说明:
' ' 没有修改
'A' 被添加到本地代码仓库 【add】
'C' 冲突 【clash】
'D' 被删除 【delete】
'I' 被忽略 【ignore】
'M' 被修改 【modification】
'R' 被替换 【replace】
'X' 外部定义创建的版本目录
'?' 文件没有被添加到本地版本库内
'!' 文件丢失或者不完整(不是通过git命令删除的文件)
'~' 受控文件被其他文件阻隔

  • 添加本地托管(暂存)文件
  - 添加指定文件名的文件
      $ git add index.html  
  - 添加通配符匹配的文件
      $ git add *.js
  - 添加所有未托管的文件(忽略.gitignore清单中的列表)
      $ git add .       // 或使用 $ git add —all
  • 提交被托管的文件变化到本地仓库
  $ git commit -m “提交代码对应的版本说明”
  • 对比差异
  $ git diff    // 对比当前版本和存储在本地仓库中最后一个版本的差异
  • 查看提交日志
  $ git log
  • 版本的恢复
  $ git reset - -hard xxxxxx    // xxx是对应版本的hash值前6位

六、git命令操作 —— 服务器

  • 概念区分
  - git是一个工具
  - github是一个网站
  - github网站提供的是git服务(即可以将代码托管到github服务器中)
  - github服务是“免费的”,但免费服务的前提是开源(如果代码需要闭源服务,即是要收费的)
  • github创建代码管理仓库
  • 为仓库添加远端地址(服务器地址)
  - 添加服务器地址并起名叫origin
      $ git remote add origin https://github.com/cxy/Git.git
  - 查看现有的服务器列表
      $ git remote -v
  • git分支(版本库其实就是一个时间轴)
  - 查看分支
      $ git branch
  - 查看分支的日志信息
      $ git branch -v
  - 新建分支
      $ git branch version2 // 新的分支version2(主分支是master)
  - 切换分支
      $ git checkout version2
  • 将代码提交到服务器
  $ git push -u origin master  // 提交到服务器中的master分支
  • 获取服务器中代码
  $ git pull origin master    // 从master分支中获取代码
  • 克隆(下载服务器代码)

  - 将远程服务器中代码克隆一份到本地   
    $ git clone https://github.com/userName/projectName test 
GIT常用命令

七、github为对应项目生成网站页面

  1、将新的工程项目提交到github中 (默认是master分支)
  2、创建新的分支gh-pages
  3、将新的分支gh-pages代码提交到github中   
  4、https://username.github.io/repository  (访问项目主页)
  扩展: 将主页绑定域名(前提是自己有域名)
  // 用户名: liming
  1、github中创建仓库名为 liming.github.io
  2、将github代码仓库克隆到本地
    $ git clone https://github.com/liming/liming.github.io
  3、在本地添加对应代码,然后上传到liming.github.io仓库中
  4、https://liming.github.io(访问项目主页)
  注: 如果仓库名和用户名不一致的,请用https://username.github.io/repositoryName这种方式访问

参考: https://pages.github.com/

八、HTTPS和SSH方式

  • HTTPS方式
  - git remote add origin https://github.com/iphone3.test.git
  - git push -u origin master 或 git pull origin master
  【每次操作都需要输入账号密码】
  • SSH方式(要进行了SSH认证)
  - git remote add origin git@github.com:iphone3/test.gti
  - git push -u origin master 或 git pull origin master

创建的仓库中,操作可以是HTTPS和SSH的选择

九、GIT SSH认证

1、创建 .ssh 目录

$ mkdir  ~/.ssh

2、切换到.ssh目录中

$ cd  ~/.ssh

3、配置全局的name和email(如果已经设置,即忽略该操作,这是用于标示一个人)

  $ git config - -global user.name "cxy"  // 两个横杆,中间不需要空格
  $ git config - -global user.email "cxy@example.com"

4、生成key

  $ ssh-keygen -t rsa -C "cxy@example.com"   // 与上面填写的邮箱与之对应
  备注: 连续三次回车,密码是设置为空

5、复制.ssh目录中的id_rsa.pub文件内容,即是key (当前用户的目录下)

  // 查看绝对路径的命令
  $ pwd 
  例如: c:\User\cxy\.ssh\id_rsa.pub

6、在github中添加key

View profile and more -> settings -> SSH and GPG keys -> New SSH key

7、检测是否添加成功

  $ ssh git@github.com
  提示: Hi xxx! You've successfully authenticated, but GitHub does not provide shell access. 说明设置成功
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,928评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,192评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,468评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,186评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,295评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,374评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,403评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,186评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,610评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,906评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,075评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,755评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,393评论 3 320
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,079评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,313评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,934评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,963评论 2 351

推荐阅读更多精彩内容