vagrant的学习之Git学习


参考学习网址:

  http://www.runoob.com/git/git-install-setup.html

  http://www.bootcss.com/p/git-guide/

  https://www.cnblogs.com/vastsum/p/5910573.html


(1)安装:

Git 的工作需要调用 curl,zlib,openssl,expat,libiconv 等库的代码,所以需要先安装这些依赖工具。

①Debian/Ubuntu Git 安装命令为:
//安装依赖
$ apt-get install libcurl4-gnutls-dev libexpat1-dev gettext libz-dev libssl-dev
//安装git
$ apt-get install git
//安装完成后,查看版本
$ git --version

②Centos/RedHat 安装命令为:

//安装依赖
$ yum install curl-devel expat-devel gettext-devel openssl-devel zlib-devel
//安装git
$ yum -y install git-core
//查看版本
$ git --version
我的测试环境:ubuntu14.04,所以采用apt-get方式安装。

(2)创建仓库

①把当前目录初始化为git仓库,会生成一个.git的目录。

git init 

②把当前目录初始化为git裸仓库,.git文件目录下的那些文件都会在该目录下,

可以通过添加hooks钩子在仓库的同级目录下新建一个存放项目源码的文件夹,也就是说将git仓库与项目源码分离。

git init --bare

(3)创建本地公钥

打开Shell(Windows下打开Git Bash),创建SSH Key:

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

Git服务器打开RAS认证:

vim /etc/ssh/sshd_config
//修改:
RSAAuthentication yes
PubkeyAuthentication yes
AuthorizedKeysFile .ssh/authorized_keys

在/home/git下创建.ssh目录,然后创建authorized_keys文件,并将本地刚生成的公钥导入进去,

(【shift+$】快捷键可以将光标移动到行尾,然后复制公钥到新的一行)。


(4)克隆项目

git clone 用户名@服务器静态IP:项目绝对路径

示例:git clone git@192.168.1.100:/home/web/study


(5)git 常用命令

查看状态:
git status

添加新文件到版本库暂存区:
(1)添加指定的文件
git add 文件名/目录
(2)添加所有的文件
git add .

暂存区文件提交到git:
git commit -m '版本备注'

删除文件:
(1)删除指定的文件
git rm 文件名/目录
(2)删除git版本库的文件,保留本地的文件
git rm --cached 文件或目录
使用sublime或者phpstorm修改文件名后,特别是只修改大小写后,
提交到git后,并不起作用,
可以使用一下方式:
git mv 文件a 文件b
git add .
git commit -m '修改文件名'

查看提交日志:
git log
git log -p 查看详细信息
git log -p -1 查看最近一次,最后一个参数是数字1
git log --oneline 简短的日志信息
git log --name-status 查看文件具体变化

修改最新一次的提交的描述:
git commit --amend

从暂存区撤回
git reset HEAD 文件名
从暂存区撤回到未修改的状态
git checkout -- 文件名

使用别名替换命令:
把git的add修改为a
git config --global alias.a add
把git的commit修改为c
git config --global alias.c commit

git push 推送
git pull 拉取

git reset --hard 历史commit的ID 回退到历史版本
git reflog

HEAD指向的版本就是当前版本,因此,Git允许我们在版本的历史之间穿梭,
使用命令:git reset --hard commit_id。

穿梭前,用git log可以查看提交历史,以便确定要回退到哪个版本。

要重返未来,用git reflog查看命令历史,以便确定要回到未来的哪个版本

创建.gitignore文件,可以忽略不想提交的文件。
*.txt //忽略以txt结尾的文件
!a.txt //结合上一句,忽略.txt结尾的文件,除了a.txt文件
/verdor //忽略这个目录
/verdor/*.php 忽略verdor子级的以php结尾的文件
/verdor/**/*.php 忽略verdor下的以及子级下的以php结尾的文件


vagrant的学习之Git学习的更多相关文章

  1. 【学习总结】Git学习-参考廖雪峰老师教程-总

    公元2018-10-21 实验室台式机 win7 64位 参考教程: 廖雪峰Git教程 其他资料:Git-book 北大一只总结的笔记,最终整理的时候可以参考:Git笔记 评论区看到的另一个人,总结在 ...

  2. Git 学习看这篇就够了!

    Git是一个开源的分布式版本控制系统,可以有效.高速的处理从很小到非常大的项目版本管理. 可能新手会问"git和github有什么关系啊?" git是一个版本控制工具: githu ...

  3. Git学习笔记与IntelliJ IDEA整合

    Git学习笔记与IntelliJ IDEA整合 一.Git学习笔记(基于Github) 1.安装和配置Git 下载地址:http://git-scm.com/downloads Git简要使用说明:h ...

  4. git学习之branch分支

    作为新手,站在我的角度肤浅的来理解,分支就是相当于开辟了一个新的临时工作区,在这个工作区进行文件代码改动,然后在合并到master主工作区,这样能保证主工作区的安全性和稳定性,对于团队协作尤为重要. ...

  5. git学习(一):建立本地仓库和基本命令

    前沿 最近一直在做目标跟踪,开始一直是通过文件按日期命名的方式来区分版本的,实在是太麻烦了,现在下定决心学习一下git命令 基本概念 集中式:有一台中央服务器,每个人把需要改的部分拿回去改完再送回来 ...

  6. git学习手册

    #git学习手册 git: Git是一个开源的分布式版本控制系统,可以有效.高速的处理从很小到非常大的项目版本管理.[2] Git 是 Linus Torvalds 为了帮助管理 Linux内核开发而 ...

  7. git学习【转载】

    最近参与别人的github项目时,学习了Git的使用,首先需要在https://github.com/网站上注册账号和邮箱,然后fork一个开源项目,然后下载目前Windows下最新版本的git,下载 ...

  8. Git学习笔记(10)——搭建Git服务器

    本文主要记录了Git服务器的搭建,以及一些其他的配置,和最后的小总结. Git远程仓库服务器 其实远程仓库和本地仓库没啥不同,远程仓库只是每天24小时开机为大家服务,所以叫做服务器.我们完全可以把自己 ...

  9. Git学习笔记(四)

    一.忽略特殊文件 在Git工作区的根目录下创建一个特殊的.gitignore文件,然后把要忽略的文件名填进去,Git就会自动忽略这些文件. 不需要从头写.gitignore文件,GitHub已经为我们 ...

随机推荐

  1. 【学习笔记】C++文件操作详解(ifstream、ofstream、fstream)

    C++ 通过以下几个类支持文件的输入输出: ofstream: 写操作(输出)的文件类 (由ostream引申而来) ifstream: 读操作(输入)的文件类(由istream引申而来) fstre ...

  2. FragmentTabHost实现标签卡效果

    转载请注明原文链接:http://www.cnblogs.com/yanyojun/p/8099523.html 代码已上传到github:https://github.com/YanYoJun/Fr ...

  3. laravel学习笔记(三)

    模型传值 路由: Route::get('/posts/{post}','\App\Http\Controllers\PostController@show'); 方法: public functio ...

  4. pocket API学习笔记

    最近安装了pocket离线阅读软件. 为了收藏需要的URL,每次都要打开浏览器.然后按google工具条上的pocket+. 网页多的时候,这个过程就非常缓慢. 根据pocket网站的API介绍,我可 ...

  5. SQLite -创建表

    SQLite -创建表 SQLite CREATE TABLE语句用于创建一个新表在任何给定的数据库.创建一个基本表包括表命名和定义其列,每列的数据类型 语法: CREATE TABLE语句的基本语法 ...

  6. Java并发编程之原子操作类

    什么是原子操作类当更新一个变量的时候,多出现数据争用的时候可能出现所意想不到的情况.这时的一般策略是使用synchronized解决,因为synchronized能够保证多个线程不会同时更新该变量.然 ...

  7. Linux-04 Linux中Tomcat和MySQL的安装

    1.下载apache-tomcat-7.0.79-tar.tar2.解压到当前用户目录,改名为tomcat [hduser@node1 ~]$ tar -zxvf apache-tomcat-7.0. ...

  8. sin_addr.s_addr和sin_addr.S_un.S_addr

    sin_addr.s_addr和sin_addr.S_un.S_addr 先mark一下,等下写

  9. [JOYOI] 1071 LCIS

    拖了好久的LCIS f[i][j]表示a串前i个,b串以b[j]结尾的LCIS长度. 转移时考虑a[i]和b[j]是否相等,如果不等: 那么既然是以j结尾,说明a串前i-1位有一个字符和b匹配了,所以 ...

  10. 同一SQL语句在PLSQL Developer与SQL * PLUS工具中执行结果不一致

    背景 今天遇到如下问题,同一sql语句在PLSQL Developer与SQL*PLUS工具中执行结果不一致, sql语句如下 SELECT 'GROUPHEALTH_SEND_EMAIL' as i ...