测试环境 :虚拟机(VMware Fusion Centos 6.5)

1.安装git环境

[root@localhost ~]# yum -y install git

2.检测git是否安装成功

[root@localhost ~]# git -v
Unknown option: -v
usage: git [--version] [--help] [-c name=value]
[--exec-path[=<path>]] [--html-path] [--man-path] [--info-path]
[-p|--paginate|--no-pager] [--no-replace-objects] [--bare]
[--git-dir=<path>] [--work-tree=<path>] [--namespace=<name>]
<command> [<args>]

本地常用操作


- 创建本地仓库 [git init]

[root@localhost test]# git init
初始化空的 Git 版本库于 /var/tmp/test/.git/
Initialized empty Git repository in /var/tmp/text/.git/
[root@localhost test]#

- 添加文件到待提交仓库 [git add]

[root@localhost test]# echo "木雨流苏" >> README.md //把 "木雨流苏" 追加到 README.md 文件
[root@localhost test]# git add README.md // git add . (表示把当前所有文件都提交) git -f README.md (强制提交 README.md)文件
[root@localhost test]#

- 查看当前仓库待提交的文件 [git status]

[root@localhost test]# git status
# 位于分支 master
#
# 初始提交
#
# 未跟踪的文件:
# (使用 "git add <file>..." 以包含要提交的内容)
#
# README.md
提交为空,但是存在尚未跟踪的文件(使用 "git add" 建立跟踪)

- 提交待提交文件到仓库 [git commit]

[root@localhost test]# git commit -m "First Commit"  // 提交代码推荐携带 -m "此处填写提交的备注" [--amend 重新提交]
// 第一次提交的提示 设置了就好了
[master(根提交) 79114a3] First Commit
Committer: root <root@localhost.localdomain>
您的姓名和邮件地址基于登录名和主机名进行了自动设置。请检查它们正确
与否。您可以通过下面的命令对其进行明确地设置以免再出现本提示信息: git config --global user.name "Your Name"
git config --global user.email you@example.com 设置完毕后,您可以用下面的命令来修正本次提交所使用的用户身份: git commit --amend --reset-author file changed, insertion(+)
create mode README.md

- 创建分支 [git branch]

[root@localhost test]# git branch one // git branch -d one 删除 one 分支
[root@localhost test]# git branch // 查看仓库分支列表
* master
one

- 切换分支 [git checkout]

[root@localhost test]# git checkout one // git chectout -b one 创建并切换到新创建的分支
切换到分支 'one'
// 当切换到不存在的分支后
error: pathspec 'a' did not match any file(s) known to git.

- 合并某个分支到当前分支 [git merge]

[root@localhost test]# git merge one
更新 79114a3..e988dbc
Fast-forward
README.md | +
file changed, insertion(+)

- 查看日志记录 [git log]

[root@localhost test]# git log
commit e988dbc451a1a9e546299be9d05fa2c8e8fd3283 // 提交ID
Author: root <root@localhost.localdomain> // 提交 作者
Date: Sun Apr :: +0800 // 提交时间 One Branch Commit // 提交备注 commit 79114a34ce2f512da42af3c23078ce78a6d29d9d
Author: root <root@localhost.localdomain>
Date: Sun Apr :: + First Commit

- 删除文件 [git rm]

[root@localhost test]# git rm .txt  // 删除并提交到待提交库中等待commit (此命令与 rm -rf 1.txt ; git add . 等同)
rm '1.txt' // 提交之后的返回
[root@localhost test]# git rm .txt // 此时是上一步删除之后重新创建的 1.txt
fatal: 路径 '1.txt' 未匹配任何文件 // 这次由于git库中没有此文件记录所以提示错误
[注]
// git rm --cached 1.txt [删除git对此文件的追踪,并不删除该文件]
// git rm -r --cached . [删除git对当前目录下所有文件的追踪]

远程常用命令


- 创建并关联远程仓库(此处我已经创建好了一个远程仓库)

echo "# git_test" >> README.md // 创建一个README.md文件 并写入 "#git_test"
git init // 创建本地仓库
git add README.md // 提交README.md 到本地待提交仓库
git commit -m "first commit" // 提交add的文件到本地仓库
git remote add origin git@github.com:zhouwei8725/git_test.git // 添加远程主机(此处以github举例)
git push -u origin master // 提交到远程仓库

- 提交到远程仓库 [git push]

git push origin master:master // git push 远程仓库名 本地分支名:远程分支名
Counting objects: , done.
Delta compression using up to threads.
Compressing objects: % (/), done.
Writing objects: % (/), bytes | bytes/s, done.
Total (delta ), reused (delta )

- 拉取远程仓库数据[git pull]

- 克隆远程仓库到本地分支[git clone]

-


一些其他小情况 ,解决办法

1 . 当出现[warning: LF will be replaced by CRLF in XXXXXXXXXXXXXX.] 错误时候 可以使用一下代码解决错误

git config core.autocrlf false

2 . 生成公钥私钥 [ssh-keygen -t rsa -C "your_email@example.com" ]

[root@localhost test]# ssh-keygen -t rsa -C "your_email@example.com"
Generating public/private rsa key pair.
Enter file in which to save the key (/root/.ssh/id_rsa):
Created directory '/root/.ssh'. // 此处是密钥文件位置 有这(id_rsa  id_rsa.pub)两个位置
// 创建密钥的密码 [如果连续敲两次 return/enter/回车 为空密码]
Enter passphrase (empty for no passphrase): //此处输入密码
Enter same passphrase again: // 此处重复密码
Your identification has been saved in /root/.ssh/id_rsa.
Your public key has been saved in /root/.ssh/id_rsa.pub.
The key fingerprint is:
cb:eb:9c:5c:5f:d6:bd::b9:f5:aa::eb::2f:cb your_email@example.com
The key's randomart image is:
+--[ RSA ]----+
| |
| |
| |
| . |
| S o . |
| . . . o.o|
| o . oo +|
| +o+oo o...|
| .E*=+o... |
+-----------------+

3. 定义默认的用户名/邮箱

git config --global user.email "you@example.com" // 设置默认的邮箱
git config --global user.name "Your Name" // 设置默认的用户名

图形化软件推荐


    一款免费好用的 windows and mac 的 git 图形化客户端 地址:https://www.sourcetreeapp.com/

git 分支管理记录的更多相关文章

  1. Git 分支管理是一门艺术

    转载: Git 分支管理是一门艺术 1 要确保:团队成员从主分支(master)获得的都是处于可发布状态的代码,而从开发分支(develop)应该总能够获得最新开发进展的代码. 2 "辅助分 ...

  2. Git 分支管理详解

    大纲: 1.前言 2.创建分支 3.切换分支 4.合并分支(快速合并) 5.删除分支 6.分支合并冲突 7.合并分支(普通合并) 8.分支管理策略 9.团队多人开发协作 10.总结 注,测试机 Cen ...

  3. Git学习总结(12)——多人开发 Git 分支管理详解

    1.前言 在上一篇博客中我们主要讲解了Git 远程仓库,相信大家对远程的Git仓库有一定的了解,嘿嘿.在这一篇博客中我们来在大家讲解一下Git 分支管理,这可以说是Git的又一大特点.下面我们就来学习 ...

  4. Git-Runoob:Git 分支管理

    ylbtech-Git-Runoob:Git 分支管理 1.返回顶部 1. Git 分支管理 几乎每一种版本控制系统都以某种形式支持分支.使用分支意味着你可以从开发主线上分离开来,然后在不影响主线的同 ...

  5. 【第七篇】- Git 分支管理之Spring Cloud直播商城 b2b2c电子商务技术总结

    ​ Git 分支管理 几乎每一种版本控制系统都以某种形式支持分支.使用分支意味着你可以从开发主线上分离开来,然后在不影响主线的同时继续工作. 有人把 Git 的分支模型称为必杀技特性,而正是因为它,将 ...

  6. GIT分支管理模型

    GIT分支管理模型 link: git-branching-model 主分支(Main branches) 项目两个常驻分支: master 主干分支(锁定),仅用于发布新版本,平时不能在上面干活, ...

  7. Git分支管理[三]

    标签(linux): git 笔者Q:972581034 交流群:605799367.有任何疑问可与笔者或加群交流 git分支管理命令 git branch #创建分支 git branch -v # ...

  8. Git—分支管理

    Git—分支管理 分支学习:branch称为分支,默认仅有一个名为master的分支.一般开发新功能流程为:开发新功能时会在分支dev上进行,开发完毕后再合并到master分支. branch相关常用 ...

  9. [转载]理解 Git 分支管理最佳实践

    原文 理解 Git 分支管理最佳实践 Git 分支有哪些 在进行分支管理讲解之前,我们先来对分支进行一个简单的分类,并明确每一类分支的用途. 分支分类 根据生命周期区分 主分支:master,deve ...

随机推荐

  1. 数据库数据迁移 SqlServer复制到mysql

    经过一番搜索,有朋友推荐用datax的,后来发现比较麻烦,需要循环每个表去复制:有推荐用Navicat的,但是方式有点行不通,会报文件打不开:无法打开Provider=SQLNCLI10.1;Pers ...

  2. iis7 设置http 自动跳转到https

    https://www.cnblogs.com/wxbug/p/7054972.html

  3. bean shell 中parameter传递参数的方法

    1.在csv set data config中添加用到的数据文件,并进行配置 2.在这一栏中,可以引入数据文件中的数据,用法如下${变量名},多个变量用空格隔开.在脚本中进行引用时,采用bsh.arg ...

  4. Linux系统的磁盘管理

    Linux系统的磁盘管理有三个命令:df.du.fdisk. df:列出Linux中所有文件系统的整体磁盘使用量: du:对文件和目录所占用磁盘空间的查看: fdisk:用于磁盘分区时列出所有的磁盘. ...

  5. dom编程艺术笔记1--第二章

    第二章语法部分: 1.js注释:<!-- XXXXX 而“-->”这部分js会认为是注释内容的一部分 2.var 声明变量 不用声明变量类型 3.声明使用一个数组语法:var object ...

  6. DB9接口定义

    注意公头和母头的引脚序号是不一样的.

  7. Python01(linux基础)

    聊一聊计算机 CPU,电源相关,时钟部分(主频),存储器,输入输出系统 计算机记忆装置:存储器分两大类:1.内存Ram(速度快,容量小(相对),断电后内容丢失) 非持久性记忆存储器2.如:硬盘,(速度 ...

  8. MySQL存储过程中实现执行动态SQL语句

    sql语句中的任何部分都可以作为参数. DROP PROCEDURE if exists insertdata; delimiter //CREATE PROCEDURE insertdata(IN ...

  9. 认识enum

    今天在看别人代码的时候发现他的使用enum的方法,我是不会用的,因此记录一下. 这个是一个语音合成,今天改为使用百度的语音,可以免费支持离线.在线. 在语音合成的使用,会使用许多的词句让其合成语音,用 ...

  10. dubbo could not get local host ip address will use 127.0.0.1 instead 异常处理

    dubbo could not get local host ip address will use 127.0.0.1 instead 查看hostname localhost:spring wls ...