git的常用指令用法

原文地址:地址

1、git的简介:

git的常用指令用法

  • workspace 工作区
  • index 暂存区
  • repository 本地版本库
  • remote 远程仓库

在你的ubuntu下输入命令sudo apt-get install git 即可安装。

常用的git命令
所有的git命令必须在工作区内能使用,工作区就是你的项目目录:

git --version 查看版本
git config -l 查看配置信息

修改name 和 email:

 git config --global user.name  'yourname'    你的名字
 git config --global user.email  'youremail'	你的email
 git config --l   查看你所设置的名字和email

 创建版本库有两种方法 一种克隆.另一种把本地目录变成版本库
(1)克隆版本库:

git clone 版本库地址     将远端服务上的项目克隆到本地

(2)创建版本库:

git init   初始化一个新的项目 ,必须切换到版本库所在目录 
git remote add origin 远程仓库地址 

(3)将文件添加到暂存区:

git add 文件名     将指定文件添加到暂存区
git add .          将所有文件添加到暂存区
git reset HEAD <file>  撤销暂存区的修改

(4)查看修改:

git diff

(5)提交代码到版本库:

git commit <文件名>    -m "说明信息"
git commit -a -m    提交所有文件

(6)将本地代码推送到远端托管服务器:

 git push [origin master] 默认推送到主分支
 git push origin 分支名     推送到指定分支

(7)从远端服务器拉取内容:

git pull origin 分支名
allow-unrelated-histories  解决本地和远程库不同的问题

(8)删除文件:

git rm <file>  从版本库中删除文件

(9)查看版本库状态:

git status

(10)查看提交记录:

git log					查看提交日志
git log --pretty=oneline		查看日志 一行显示

(11)版本回退:

git reset --hard head~n
	 head~ 上一个版本
	 head~~上两个版本
	 head~n 上n版本
更简介的做法是:git reset --hard +版本号  一般取前七位就可以 能区分就ok

在你push之前有可能别人更改了代码 一定要先pull! 一定要先pull! 一定要先pull! 查看是否是最新的 在git push origin 分支

git的使用流程:

  1. 首先到托管服务器上创建一个空版本库,例如在github、coding、oschina等
  2. 然后克隆到本地(clone)创建一个新项目
  3. 或者可以通过初始化项目创建一个新项目 git init
  4. git remote add origin 远程仓库地址
  5. 添加代码文件(git add)
  6. 提交代码到本地库 git commit -m
  7. 将代码推送到远端服务器 git push
  8. 从远端服务器拉取代码git pull

冲突管理

  • 如果有多个人同时修改同一个文件的相同行,在推送时会有冲突
  • 发生冲突后,首先将服务器端代码拉到本地(pull),手动合并冲突
  • 然后添加修改后的代码文件,重新提交
  • 将代码推送到服务器

分支管理

  • master 主分支,记录发布版本
  • online 线上分支 正在运行的版本
  • develop 开发分支 用于测试
  • local 本地分支
  • 分支管理常用命令
git branch 查看分支
git branch 新分支 [旧分支]    基于旧分支创建新分支
git branch -d 分支名      	 删除分支
git checkout 分支           切换到指定分支
git merge 分支名            将指定分支合并到当前分支

问题
忽略提交,在工作区中编写一个.gitignore文件,在文件中记录不需要提交的目录和文件
如果克隆的时候出现了: unable to access ‘https://git.coding.net/landmark/php1702.git/’: error setting certificate 解决方式:

Git config --global http.sslVerify false 

巴拉巴拉:

==主页传送门==