安装Git(linux centos平台)

源代码方式安装

1.装依赖

$ yum install curl-devel expat-devel gettext-devel openssl-devel zlib-devel

2.下源代码并编译安装

地址:

http://git-scm.com/download

编译安装:

$ tar -zxf git-1.7.2.2.tar.gz

$ cd git-1.7.2.2

$ make

$ sudo make  install

二进制包安装

$ yum install git-core



使用Git

#建立自己的工作文件夹

sudo mkdir /var/www/site/mycitsm_zyz

cd /var/www/site/mycitsm_zyz

#从代码仓库clone代码

sudo Gitclone ssh://username@ip:port/path/to/example.git  /path/to/workdir



#克隆代码到自己的工作文件夹后先设置用信息以便于识别更新来源

$ git config user.name "username"

$ git config user.email username@example.com

#忽略某些文件

在工作文件夹下创建并编辑.gitignore文件,写入想忽略的内容

例子:

$ cat .gitignore

*.pyc

*.pyo

test_*

*.bak

之后便能够在自己的工作文件夹中编辑并提交代码。



一般工作流程

#更新代码

$vim /path/to/file



#查看文件状态

$git status



#暂存更新

$git add /path/to/file



#本地提交更新

$git commit -m "说明信息"

或通过

$git commit -v 编写更具体的提交说明并将具体的更新内容记录在内。

#推送本地更新到远程仓库

$git push origin master(origin为假定的远程仓库名。master是默认分支)



#从远程仓库拉取新内容

$git pull origin



#获取帮助

$git help

#新建分支

$git branch branchname

#切换分支

$git checkout branchname

#上述两步可合并为一步

$git checkout -b branchname

#合并分支

先切回主分支$git checkout master

再合并分支到主分支$git merge branchname

#查看分支

$git branch

#仅查看未合并分支

$git branch --no-merged

#仅查看已合并分支

$git branch --merged

#删除分支(已合并)

$git branch -d branchname

#删除分支(不管是否已合并)

$git branch -D branchname

#查看未暂存文件的与改动前的差异

$git diff



#查看已暂存文件与上次提交时快照之间的差异

$git diff --cached



#移除文件

$git rm /path/to/file



#仅从跟踪清单删除不从工作文件夹删除

$git rm --cached /path/to/file



#移动文件

$ git mv file_from file_to



#查看提交历史

$ git log



#改动最后一次提交

$ git commit --amend



#取消已暂存文件

$ git reset HEAD /path/to/file



#取消对文件对的改动

$git checkout -- /path/to/file



#回退

$git reset--mixed HEAD~N

$git reset--soft HEAD~N

$git reset--hard HEAD~N

当中N表示近期的N次提交。这里也能够是某次提交后返回的版本号唯一标识(可通过$git log获取到)

--mixed保留修改,回退commit和index

--soft保留修改。回退commit。不回退index

--hard彻底回退到某个版本号



#查看当前远程库

$git remote -v



#从远程库拉取更新

$git fetch origin



#合并拉取的更新的分支到本地分支

$git merge origin/master



以上两步可合并为一步

$git pull origin

在项目开发中使用Git版本号控制工具以提高效率的更多相关文章

  1. 项目开发中的git简单使用

    原文地址: https://www.zhuyilong.fun/tech/the-blog-git.html 示例远程仓库地址: https://github.com/zhu-longge/gitWo ...

  2. 团队项目开发中,常见的版本控制有svn,git

    团队项目开发中,常见的版本控制有svn,git

  3. 开发中关于Git那些事

    如果你想精通Git,直接到 Git官网 把这本ProGit掌握已足以Pro Git 此文主要介绍一切开发中常用的git命令和一些配置技巧(诸如git别名配置,log打印技巧,版本回退以及分支管理等). ...

  4. 炼金术(1): 识别项目开发中的ProtoType、Demo、MVP

    软件开发是很分裂的,只有不断使用原则和规律,才能带来质量. 只要不是玩具性质的项目,项目应该可以大概划分为0-1,1-10,10-100,100-1000四个种重要阶段.其中,0-1是原型验证性的:1 ...

  5. fir.im Weekly - iOS开发中的Git流程

    本期 fir.im Weekly 收集了微博上的热转资源,包含 Android.iOS 开发工具.源码等好用的轮子,还有一些 APP 设计的 Tips,希望对你有用. 精仿知乎日报 iOS 端 @我偏 ...

  6. 开发中关于Git那些事(续:Git变基)

    其实上一篇写的内容仅仅是Git的冰山一角,如果你认为Git就是简简单单的几行命令,那只能说明你还没有真正了解Git这个强大的内容寻址文件系统.这篇文章,还是接着介绍一些实用但是很少有人知晓的一些命令, ...

  7. 项目开发中的一些注意事项以及技巧总结 基于Repository模式设计项目架构—你可以参考的项目架构设计 Asp.Net Core中使用RSA加密 EF Core中的多对多映射如何实现? asp.net core下的如何给网站做安全设置 获取服务端https证书 Js异常捕获

    项目开发中的一些注意事项以及技巧总结   1.jquery采用ajax向后端请求时,MVC框架并不能返回View的数据,也就是一般我们使用View().PartialView()等,只能返回json以 ...

  8. Angular 项目开发中父子组件传参

    在项目开发中经常会遇到 组件之间传参的问题.今天总结下在使用angular的项目中父子组件传参的问题: 1.父组件向子组件传参: 然后在父组件中 然后在父组件的html中 然后就可以在子组件中使用了 ...

  9. 《Maven在Java项目开发中的应用》论文笔记(十七)

    标题:Maven在Java项目开发中的应用 一.基本信息 时间:2019 来源:山西农业大学 关键词:Maven:Java Web:仓库:开发人员:极限编程; 二.研究内容 1.Maven 基本原理概 ...

随机推荐

  1. RabbitMQ - Publisher的消息确认机制

    queue和consumer之间的消息确认机制:通过设置ack.那么Publisher能不到知道他post的Message有没有到达queue,甚至更近一步,是否被某个Consumer处理呢?毕竟对于 ...

  2. HDU_1176_免费馅饼

    http://acm.hdu.edu.cn/showproblem.php?pid=1176 参考自:http://blog.csdn.net/xcszbdnl/article/details/787 ...

  3. centos 搭建pptp

    很多朋友不会在CENTOS 在安装vpn,因为对于菜鸟来说安装VPN的确是个头晕的事情,特别是安装openvpn,不过安装pptp就稍微简单一点,国内网上有很多安装pptp的教程,但是都很繁杂,我在国 ...

  4. Redis系列(九)--几道面试题

    这里只是一点面试题,想了解更多,可以查看本人的Redis系列:https://www.cnblogs.com/huigelaile/category/1461895.html 1.Redis和Memc ...

  5. 并查集(Union Find)的基本实现

    概念 并查集是一种树形的数据结构,用来处理一些不交集的合并及查询问题.主要有两个操作: find:确定元素属于哪一个子集. union:将两个子集合并成同一个集合. 所以并查集能够解决网络中节点的连通 ...

  6. STL源码分析之第二级配置器

    前言 第一级是直接调用malloc分配空间, 调用free释放空间, 第二级三就是建立一个内存池, 小于128字节的申请都直接在内存池申请, 不直接调用malloc和free. 本节分析第二级空间配置 ...

  7. c++运行程序闪退

        以最简单程序为例       法一:在主函数末尾下一行getchar();即可.需要注意的是这种方法并不适合所有程序,       法二:<1>先在程序开头加上头文件#includ ...

  8. 爬虫之Re库

    一.常见匹配模式 \W # 匹配字母数字及下划线 \W # 匹配非字母数字下划线 \s # 匹配任意空白字符,等价于[\t\n\r\f] \S # 匹配任意非空字符 \d # 匹配任意数字,等价于[0 ...

  9. Python利用带权重随机数解决抽奖和游戏爆装备问题

    关于带权随机数 为了帮助理解,先来看三类随机问题的对比: 1.已有n条记录,从中选取m条记录,选取出来的记录前后顺序不管. 实现思路:按行遍历所有记录,约隔n/m条取一个数据即可 2.在1类情况下,还 ...

  10. Python学习之前

    编程语言的分类: 1.机器语言:直接以0和1编写指令代码,计算机能直接识别处理: 特点:运行速度最快,太复杂,开发效率低,可执行操作最多. 2.汇编语言:本质上依然是机器语言,用英文代替0和1,更容易 ...