版本控制-Git服务器搭建和常用命令使用
Git是目前世界上最先进的分布式版本控制系统(没有之一)。使用Svn的请参考《版本控制-svn服务器搭建和常用命令(centos 6.3)》,下面介绍Git的常用命令
常用命令
服务器搭建
一、简单版
1、创建版本库
git init
2、新增修改,新增文件到缓存区
git add
3、比较文件的差异
git diff
4、查看仓库状态
git status
5、从缓存区提交修改(新增)到版本库
git commit -m 'add a.txt'
6、查看提交日志
git log (--pretty=oneline)
7、HEAD表示当前版本,HEAD^表示上个版本,HEAD^^上上个版本,HEAD~100表示网上100个版本
8、更新到指定版本(没有撤销本地修改)
git reset --hard HEAD^
git reset --hard # 能区分一个版本的commit id即可
9、查看每一次命令
git reflog
10、撤销工作区的修改
git checkout --file
假设错误修改了readme.txt,并且git add到了缓存区
git reset HEAD readme.txt # 回到最新版本,撤销缓存区的修改
git checkout --readme.txt # 撤销本地修改
11、删除文件
删除本地文件直接rm
删除版本库文件
git rm a.txt
git commit -m‘rm a.txt’
删除暂存区文件
git rm --cache a.txt git checkout HEAD(a.txt) # 会清除工作区和暂存区的修改
二、升级版
1、从github添加远程仓库(origin是远程库默认名称,可以更改)
git remote add origin git@github.com:***/learngit.git
2、把本地的所有修改推送到远程库(push是用本地的master分支,-u是表示第一次将远程库的master和本地的master关联)
git push (-u) origin master
3、克隆一个仓库(支持ssh和https协议,ssh原生且最快)
git clone git@github.com:***/gitskills.git
4、创建一个分支并切换到该分支(git鼓励使用分支)
git checkout -b dev
等于两个命令
git branch dev
git checkout dev
5、分支命令
查看分支:git branch
创建分支:git branch <name>
切换分支:git checkout <name>
创建+切换分支:git checkout -b <name>
合并某分支到当前分支:git merge <name>
删除分支:git branch –d(D) <name>
删除远程分支:git push origin :serverfix
6、查看分支合并情况日志
git log –graph git log --graph --pretty=oneline --abbrev-commit
7、分支管理策略
master是稳定版本,开发的在其他分支上,稳定后合并到master。
合并分支时,加上--no-ff参数就可以用普通模式合并,合并后的历史有分支,能看出来曾经做过合并,而fast forward(默认)合并就看不出来曾经做过合并
git merge --no-ff -m "merge with no-ff" dev
git log --graph --pretty=oneline --abbrev-commit
8、挂起工作场景
git stash # 挂起
git stash list # 查看 git stash pop # 恢复并删除
等于
git stash apply && git stash drop
9、多人协作
用下面命令推送自己的修改
git push origin branch-name
如果推送失败,则因为远程分支比你的本地更新,需要先用 git pull 试图合并;如果合并有冲突,则解决冲突,并在本地提交;没有冲突或者解决掉冲突后,再用下面命令推送就能成功
git push origin branch-name
如果git pull提示“no tracking information”,则说明本地分支和远程分支的链接关系没有创建,用命令
git branch --set-upstream branch-name origin/branch-name
10、标签操作
git tag <name> # 新建标签,默认为HEAD,可以指定commit id
git tag -a <tagname> -m "blablabla..." # 指定标签信息
git tag -s <tagname> -m "blablabla..." # 用PGP签名标签名
git tag # 查看所有标签
git show <tagname> # 看到说明
git tag -d <tagname> # 本地删除标签
git push origin <tagname> # 推送标签到远程仓库
git push origin --tags # 一次性推送所有标签到远程仓库
PGP签名的标签是不可伪造的,因为可以验证PGP签名。验证签名的方法比较复杂
要删除远程仓库的标签需要使用
git tag -d <tagname>
git push origin :refs/tags/<tagname>
三、其他
1、忽略文件
在Git工作区的根目录下创建一个特殊的.gitignore文件,然后把要忽略的文件名填进去,Git就会自动忽略这些文件。我们并不需要从头写.gitignore文件,GitHub已经为我们准备了各种配置文件,只需要组合一下就可以使用了。所有配置文件可以直接在线浏览:https://github.com/github/gitignore
2、配置别名
git config --global alias.co checkout
git config --global alias.ci commit
git config --global alias.br branch
每个仓库的Git配置文件都放在.git/config文件中
四、搭建本地Git服务器
详情可参考廖雪峰官方网站 http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000
1、安装git
yum install git -y [root@master git]# git version
git version 1.7.
2、新建git账号
[root@master git]# useradd git [root@master git]# passwd git [root@master git]# mkdir /data1/git
3、生成ssh key
[root@master git]# su - git [git@master ~]$ ssh-keygen -t rsa [git@master .ssh]$ cd ~/.ssh/ [git@master .ssh]$ touch authorized_keys [git@master .ssh]$ chmod authorized_keys
收集所有需要登录的用户的公钥,就是他们自己的id_rsa.pub
文件,把所有公钥导入到/home/git/.ssh/authorized_keys
文件里,一行一个。
4、初始化git仓库
切回Root账户 [root@master ~]# cd /data1/git/ [root@master git]# git init --bare project.git
Initialized empty Git repository in /data1/git/project.git/ [root@master git]# chown -R git: /data1/git/
5、禁用shell登陆
处于安全考虑一般禁用git账户被远程登陆shell。修改/etc/passwd
[root@master git]# vim /etc/passwd 将 git:x::::/home/git:/bin/bash 修改为
git:x::::/home/git:/usr/bin/git-shell
[root@master git]# su - git
fatal: What do you think I am? A shell?
6、其他地方克隆仓库
现将公钥添加到 authorized_keys文件中
git clone ssh://git@master:322/data1/git/project.git
管理公钥可以使用 Gitosis ,因为authorized_keys文件大了很难管理。管理权限请参考下面
五、Gitolite搭建教程
参考官网 https://git-scm.com/book/zh/v1/服务器上的-Git-Gitolite
1、前期准备
git服务器git@10.16.4.14,git admin机器git@10.16.4.15
root@10.16.4.14$ useradd git
root@10.16.4.14$ passwd git
root@10.16.4.14$ su - git admin git@10.16.4.15
root@10.16.4.15$ useradd git
root@10.16.4.15$ passwd git
root@10.16.4.15$ su - git
root@10.16.4.15$ ssh-keygen -t -P ''
send git.pub to git@10.16.4.14:322/home
2、Admin使用
git clone
git@10.16.4.15 git clone ssh://git@10.16.4.14:322/gitolite-admin
add user
1)获取用户的public ssh key,例如test@10.1.32.164.pub
2)将`1`的pub存放到git@10.16.4.15 /home/git/gitolite-admin/keydir 文件夹下
3)修改/home/git/gitolite-admin/conf/gitolite.conf,赋予`1`用户的仓库权限
4)git add && git commit -m 'add user test...' && git push origin master
5)登陆test@10.1.32.164,git clone `3`中的仓库
3、权限控制
参考 https://git-scm.com/book/zh/v1/服务器上的-Git-Gitolite
参考 http://perthcharles.github.io/2015/08/24/setup-gitolite-service-git-1
4、解决密码过期问题
[git@Dev_10_16_4_15 gitolite-admin]$ git push origin master
WARNING: Your password has expired.
Password change required but no TTY available.
fatal: Could not read from remote repository. Please make sure you have the correct access rights
and the repository exists.
解决命令
[root@Dev_10_16_4_14 ~]# chage -M git
原创文章,转载请备注原文地址 http://www.cnblogs.com/lxmhhy/p/6038243.html
版本控制-Git服务器搭建和常用命令使用的更多相关文章
- 版本控制-svn服务器搭建和常用命令(centos 6.3)
Svn是比较优秀的版本控制工具,虽然功能和性能上无法和Git媲美,但由于其容易搭建和使用的特性,所以在各个小公司还是很受欢迎的.使用Git可参考<版本控制-Git服务器搭建和常用命令使用> ...
- 版本控制-https svn服务器搭建和常用命令(centos 6.3)
Svn是比较优秀的版本控制工具,虽然功能和性能上无法和Git媲美,但由于其容易搭建和使用的特性,所以在各个小公司还是很受欢迎的.使用Git可参考<版本控制-Git服务器搭建和常用命令使用> ...
- Windows下Git服务器搭建[转]
Windows下Git服务器搭建 作为对前两天Git服务器搭建的一个整理,我想分别从服务端和客户端两个角度来记录下整个搭建过程,为了达到目标,我们需要哪些操作. (一)服务端软件和账号的安装配置 ...
- ECS之Git服务器搭建
最简教程 ### . 安装Git 安装Git服务,命令如下: ```Shell $ yum install curl-devel expat-devel gettext-devel openssl-d ...
- Ubuntu中Git服务器搭建
git服务器搭建过程 参考网上资料搭建git服务器过程记录 如下: 需求 硬件需求:一台Ubuntu或者debian电脑(虚拟机),能通过网络访问到. 软件需求:git-core, gitosis, ...
- 基于阿里云服务器的git服务器搭建
使用阿里云Ubuntu 12.0.4 64位操作系统做git服务器. 首先git服务器有两种访问方式可以选择:http方式和ssh的方式,http方式更容易使用. 1.http方式的git服务器搭建以 ...
- 【转】Windows平台下Git服务器搭建
Windows平台下Git服务器搭建 Posted on 2015-05-18 21:29 阿祥当码农 阅读(7637) 评论(0) 编辑 收藏 该文章转自:http://www.codeceo.co ...
- Git系列(1) Windows下Git服务器搭建
作为对前两天Git服务器搭建的一个整理,我想分别从服务端和客户端两个角度来记录下整个搭建过程,为了达到目标,我们需要哪些操作. (一)服务端软件和账号的安装配置 我们这里只需要两个软件git和ssh, ...
- Git-Runoob:Git 服务器搭建
ylbtech-Git-Runoob:Git 服务器搭建 1.返回顶部 1. Git 服务器搭建 上一章节中我们远程仓库使用了 Github,Github 公开的项目是免费的,但是如果你不想让其他人看 ...
随机推荐
- 测试计划(Test Plan)
测试计划(Test Plan) 版权声明:本文为博主原创文章,未经博主允许不得转载. 测试计划的概念: 测试计划是一个文档,描述了进行测试的测试范围,测试策略和方法,测试资源和进度.是对整个测试活动进 ...
- 搭建LNAMP环境(七)- PHP7源码安装Memcached和Memcache拓展
上一篇:搭建LNAMP环境(六)- PHP7源码安装MongoDB和MongoDB拓展 一.安装Memcached 1.yum安装libevent事件触发管理器 yum -y install libe ...
- OPEN CASCADE编译视频
为了帮助OPEN CASCADE新手顺利编译OPEN CASCADE源码,特录制了一个视频, 有了这个视频,OPEN CASCADE的编译再也不麻烦啦!
- Hawk 3. 网页采集器
1.基本入门 1. 原理(建议阅读) 网页采集器的功能是获取网页中的数据(废话).通常来说,目标可能是列表(如购物车列表),或是一个页面中的固定字段(如JD某商品的价格和介绍,在页面中只有一个).因此 ...
- 如何通过官方渠道为Windows 10 添加具有中国特色的字体
Windows 10的变化细节上个人认为要比Windows 8多很多,而且很多功能找到之后还是小惊喜,就是挺多好用的地方居然都不正经宣传一下,微软真是搞得悄悄地干活? 今天为大家介绍一下通过官方途径添 ...
- Oracle 11.2.0.4单实例打PSU,OJVM PSU补丁快速参考
写在前面: 1.Oracel打每个补丁的操作有时存在差异,所以不管多熟悉,都应该在打任何补丁之前阅读新补丁中附带的readme. 2.Oracle每季度都会更新一个最新的PSU,本文最新指的是当前最新 ...
- TeamCity : 配置 Build 过程
Build 过程往往是比较复杂的,因此 TeamCtiy 通过 build 步骤的方式让您可以实现不同的应用场景.您可以在每个 build 步骤中只做一件事情,然后把一系列的 build 步骤组织起来 ...
- Visual Studio 2013 Ultimate因为CodeLens功能导致Microsoft.Alm.Shared.Remoting.RemoteContainer.dll高CPU占用率的折中解决方案
1.为什么Microsoft.Alm.Shared.Remoting.RemoteContainer.dll的CPU占用率以及内存使用率会那么高? 在Visual Studio 2013 Ultima ...
- C# - 多线程 之 锁系统
lock 关键字, Monitor 监控器, using System.Threading: // 提供同步访问对象的机制. public static class Monitor { public ...
- getJson
$.getJSON("<%=basePath%>delivery/auditing.do",{Phones:Phones,currPage:currPage,timst ...