版本控制系统(Version Control System): 是一种记录一个或若干文件内容变化,以便将来查阅特定版本修订情况的系统。版本控制系统不仅可以应用于软件源代码的文本文件,而且可以对任何类型的文件进行版本控制。
常见的版本控制系统有:cvs、svn、git
关于版本控制
本地版本控制系统
本地版本控制系统就是在一台机器上,记录版本的不同变化,保证内容不会丢失
缺点:如果多人开发,每个人都在不同的系统和电脑上开发,没办法协同工作。
集中式版本控制系統
svn/cvs 都是集中式的版本控制系统
分布式版本控制系统
git 是分布式的版本控制系统。
Git 是一款免费、开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。
Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。
下载地址
# 推荐使用国内镜像下载 http://npm.taobao.org/mirrors/git-for-windows 1. 不要安装在中文目录 2. 不要使用桌面管理软件
安装很简单,一直下一步即可。在任意的目录下右键,能够出现下图,表示安装成功了。
git 用法方式主要有两种,
bash 是 linux 系统的命令,因此学习 git 前,我们先学习一下 bash
# cd 改变目录 (change directory) cd images #进入images文件夹 cd .. #进入上一层目录 cd ~ #进入用户根目录 # tab 自动补全,当我们输命令或者目录很长时,可以使用tab键进行自动补全。 # 按两次tab,会把所有符合要求的内容都列出来。 # pwd 打印当前目录的路径 (print work directory) pwd # ls 展示当前目录列表(list) ls # 展示当前目录 ls -a # 展示全部内容,包括隐藏文件 ls -l # 以列表的形式展示内容 ls -al # 以列表的形式展示所有的内容,包括隐藏文件。 ls --help # 查看ls所有的参数。 ls -l images # 展示images目录下的文件,如果没有写目录,默认展示当前目录。 # clear reset清屏 clear # 清除屏幕内容,滚动条,保留了历史 reset # 重置,历史记录没了。 # mkdir 创建一个文件夹 (make directory) mkdir css # 创建一个css的文件夹 mkdir css img js # 创建了三个文件夹 # rmdir 删除一个空的文件夹(没啥用) rmdir img # 删除文件夹 # touch 创建文件 touch index.html #创建了一个index.html文件 touch css/index.css # 在css目录下创建idnex.css文件 # rm 删除一个文件获取文件夹 rm index.html # 删除index.html文件 rm js # 删除空的js文件夹 rm -r css # 递归删除一个文件夹 # mv 移动文件(move) mv index.html js # 将html文件移动到js文件夹中 mv index.html index2.html # 将index.html重命名为index2.html # cp 复制文件(cp) cp index.html index2.html # 复制index.html文件,命名为index2.html cp -r css css02 # 如果复制的是文件夹,需要使用-r参数。 # cat 查看文件全部内容 cat index.html # less 查看文件部分内容 less index.html # q退出查看
# 初始化git仓库,会在当前目录生成一个隐藏文件夹 .git 不要去修改这个文件夹下的任意东西。 git init # 查看git的状态 ,如果此时新建一个文件,那么这个文件是没有被追踪的,说白了git还没有管理这个新建的文件 git status # 让git管理这个新建的文件 git add index.html # 让文件由暂存区提交到仓库区。此时文件才真正的被git管理了。 # 如果提交日志乱码,右键-->options-->Text-->将编码改成utf-8 git commit -m '第一次提交' # 查看提交日志 git log
如果第一次使用 git,会要求设置用户名和邮箱
# git config user.name 你的目标用户名 # git config user.email 你的目标邮箱名 # 这种配置方式只有在当前仓库生效 git config user.name shuaige git config user.email 669104343@qq.com # 可以使用--global参数,配置全局的用户名和邮箱,这样别的git仓库就不需要重新配置了。 # 如果同时配置了局部的和全局的,那么局部的用户名和邮箱将会生效。 git config --global user.name shuaige git config --global user.email 669104343@qq.com # 查看配置信息 git config --list
git git add 文件名
将版本回退到上一次提交
在仓库中,有些文件是不想被 git 管理的,比如数据的配置密码、写代码的一些思路等。git 可以通过配置从而达到忽视掉一些文件,这样这些文件就可以不用提交了。
# 忽视idea.txt文件 idea.txt # 忽视.gitignore文件 .gitignore # 忽视css下的index.js文件 css/index.js # 忽视css下的所有的js文件 css/*.js # 忽视css下的所有文件 css/*.* # 忽视css文件夹 css
分支就是科幻电影里面的平行宇宙,当你正在电脑前努力学习 Git 的时候,另一个你正在另一个平行宇宙里努力学习 SVN。
如果两个平行宇宙互不干扰,那对现在的你也没啥影响。不过,在某个时间点,两个平行宇宙合并了,结果,你既学会了 Git 又学会了 SVN!
所有的程序员都可以通过远程仓库来进行版本的共享,达到所有人的代码一致的效果。
每次 push 和 pull 操作都需要带上远程仓库的地址,非常的麻烦,我们可以给仓库地址设置一个别名
使用仓库别名替代仓库地址。仓库别名相当于一个变量,仓库地址就是对应的值。
git 与 github 没有直接的关系。
github 官网
开源中国 - git 码云
1. gitHub是一个面向开源及私有软件项目的托管平台,因为只支持git 作为唯一的版本库格式进行托管,故名gitHub。 2. github免费,代码所有人都能看到,但是只有你自己能修改。付费的可以隐藏。
在 github 上创建一个项目,获取到仓库的地址。然后就可以将本地的代码推送到远程的服务器上。
(对称加密与非对称加密)
每次 push 代码,都需要输入用户名跟密码,非常的麻烦。因此我们可以配置一个 SSH 免密码登陆。
首先,确保本地已经安装过 git 客户端,idea 会进行自动检测,如果没有,或者想进行手动调整,需要在这里重新配置。配置成功之后可以通过点击 Test 按钮测试是否 OK!
选中指定项目右键,选择 Git 将项目添加到版本控制,然后使用 Commit Directory 提交项目到本地仓库。
注意:如果没有配置 ssh 公钥,第一次本地推送,需要输入 GitHub 或 gitee 远程仓库用户名密码。
0、安装. ignore 插件
点击 File->Settings ,找到 Plugins 搜索 ignore,然后 install,OK 重启 idea
1、创建项目,在项目中添加. gitignore 文件
建议. gitignore 文件内容
###################################################################### # Build Tools .gradle /build/ !gradle/wrapper/gradle-wrapper.jar target/ !.mvn/wrapper/maven-wrapper.jar ###################################################################### # IDE ### STS ### .apt_generated .classpath .factorypath .project .settings .springBeans ### IntelliJ IDEA ### .idea *.iws *.iml *.ipr out gen ### NetBeans ### nbproject/private/ build/* nbbuild/ dist/ nbdist/ .nb-gradle/ ###################################################################### # Others *.log *.xml.versionsBackup !*/build/*.java !*/build/*.html !*/build/*.xml # .gitignore文件内容编写规则 *.a # 忽略所有 .a 结尾的文件 !lib.a # 但 lib.a 除外 /TODO # 仅仅忽略项目根目录下的 TODO 文件,不包括 subdir/TODO build/ # 忽略 build/ 目录下的所有文件 doc/*.txt # 会忽略 doc/notes.txt 但不包括 doc/server/arch.txt
2、创建本地仓库
$ git init
3、创建个人分支
$ git checkout -b dev
4、添加文件到版本控制,提交到本地仓库
$ git add . $ git commit -m "first commit"
5、推送到远程仓库
$ git push https://gitee.com/liyunyi/ssm.git dev
6、合并分支推送到主分支
$ git checkout master $ git merge dev $ git push https://gitee.com/liyunyi/ssm.git master
附件:命令大全
1、仓库
# 在当前目录新建一个Git代码库 $ git init # 新建一个目录,将其初始化为Git代码库 $ git init [project-name] # 下载一个项目和它的整个代码历史 $ git clone [url]
2、配置
# 显示当前的Git配置 $ git config --list # 编辑Git配置文件 $ git config -e [--global] # 设置提交代码时的用户信息 $ git config [--global] user.name "[name]" $ git config [--global] user.email "[email address]"
3、增加 / 删除文件
# 添加指定文件到暂存区 $ git add [file1] [file2] ... # 添加指定目录到暂存区,包括子目录 $ git add [dir] # 添加当前目录的所有文件到暂存区 $ git add . # 添加每个变化前,都会要求确认 # 对于同一个文件的多处变化,可以实现分次提交 $ git add -p # 删除工作区文件,并且将这次删除放入暂存区 $ git rm [file1] [file2] ... # 停止追踪指定文件,但该文件会保留在工作区 $ git rm --cached [file] # 改名文件,并且将这个改名放入暂存区 $ git mv [file-original] [file-renamed]
4、代码提交
# 提交暂存区到仓库区 $ git commit -m [message] # 提交暂存区的指定文件到仓库区 $ git commit [file1] [file2] ... -m [message] # 提交工作区自上次commit之后的变化,直接到仓库区 $ git commit -a # 提交时显示所有diff信息 $ git commit -v # 使用一次新的commit,替代上一次提交 # 如果代码没有任何新变化,则用来改写上一次commit的提交信息 $ git commit --amend -m [message] # 重做上一次commit,并包括指定文件的新变化 $ git commit --amend [file1] [file2] ...
5、分支
# 列出所有本地分支 $ git branch # 列出所有远程分支 $ git branch -r # 列出所有本地分支和远程分支 $ git branch -a # 新建一个分支,但依然停留在当前分支 $ git branch [branch-name] # 新建一个分支,并切换到该分支 $ git checkout -b [branch] # 新建一个分支,指向指定commit $ git branch [branch] [commit] # 新建一个分支,与指定的远程分支建立追踪关系 $ git branch --track [branch] [remote-branch] # 切换到指定分支,并更新工作区 $ git checkout [branch-name] # 切换到上一个分支 $ git checkout - # 建立追踪关系,在现有分支与指定的远程分支之间 $ git branch --set-upstream [branch] [remote-branch] # 合并指定分支到当前分支 $ git merge [branch] # 选择一个commit,合并进当前分支 $ git cherry-pick [commit] # 删除分支 $ git branch -d [branch-name] # 删除远程分支 $ git push origin --delete [branch-name] $ git branch -dr [remote/branch]
6、标签
# 列出所有tag $ git tag # 新建一个tag在当前commit $ git tag [tag] # 新建一个tag在指定commit $ git tag [tag] [commit] # 删除本地tag $ git tag -d [tag] # 删除远程tag $ git push origin :refs/tags/[tagName] # 查看tag信息 $ git show [tag] # 提交指定tag $ git push [remote] [tag] # 提交所有tag $ git push [remote] --tags # 新建一个分支,指向某个tag $ git checkout -b [branch] [tag]
7、查看信息
# 显示有变更的文件 $ git status # 显示当前分支的版本历史 $ git log # 显示commit历史,以及每次commit发生变更的文件 $ git log --stat # 搜索提交历史,根据关键词 $ git log -S [keyword] # 显示某个commit之后的所有变动,每个commit占据一行 $ git log [tag] HEAD --pretty=format:%s # 显示某个commit之后的所有变动,其"提交说明"必须符合搜索条件 $ git log [tag] HEAD --grep feature # 显示某个文件的版本历史,包括文件改名 $ git log --follow [file] $ git whatchanged [file] # 显示指定文件相关的每一次diff $ git log -p [file] # 显示过去5次提交 $ git log -5 --pretty --oneline # 显示所有提交过的用户,按提交次数排序 $ git shortlog -sn # 显示指定文件是什么人在什么时间修改过 $ git blame [file] # 显示暂存区和工作区的差异 $ git diff # 显示暂存区和上一个commit的差异 $ git diff --cached [file] # 显示工作区与当前分支最新commit之间的差异 $ git diff HEAD # 显示两次提交之间的差异 $ git diff [first-branch]...[second-branch] # 显示今天你写了多少行代码 $ git diff --shortstat "@{0 day ago}" # 显示某次提交的元数据和内容变化 $ git show [commit] # 显示某次提交发生变化的文件 $ git show --name-only [commit] # 显示某次提交时,某个文件的内容 $ git show [commit]:[filename] # 显示当前分支的最近几次提交 $ git reflog
8、远程同步
# 下载远程仓库的所有变动 $ git fetch [remote] # 显示所有远程仓库 $ git remote -v # 显示某个远程仓库的信息 $ git remote show [remote] # 增加一个新的远程仓库,并命名 $ git remote add [shortname] [url] # 取回远程仓库的变化,并与本地分支合并 $ git pull [remote] [branch] # 上传本地指定分支到远程仓库 $ git push [remote] [branch] # 强行推送当前分支到远程仓库,即使有冲突 $ git push [remote] --force # 推送所有分支到远程仓库 $ git push [remote] --all
9、撤销
# 恢复暂存区的指定文件到工作区 $ git checkout [file] # 恢复某个commit的指定文件到暂存区和工作区 $ git checkout [commit] [file] # 恢复暂存区的所有文件到工作区 $ git checkout . # 重置暂存区的指定文件,与上一次commit保持一致,但工作区不变 $ git reset [file] # 重置暂存区与工作区,与上一次commit保持一致 $ git reset --hard # 重置当前分支的指针为指定commit,同时重置暂存区,但工作区不变 $ git reset [commit] # 重置当前分支的HEAD为指定commit,同时重置暂存区和工作区,与指定commit一致 $ git reset --hard [commit] # 重置当前HEAD为指定commit,但保持暂存区和工作区不变 $ git reset --keep [commit] # 新建一个commit,用来撤销指定commit # 后者的所有变化都将被前者抵消,并且应用到当前分支 $ git revert [commit] # 暂时将未提交的变化移除,稍后再移入 $ git stash $ git stash pop
10、其他
# 生成一个可供发布的压缩包 $ git archive
本文作者:Gustav
本文链接:
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!