转自:https://www.cnblogs.com/Juvy/p/3556902.html

git的优势:

1 可以创建分支;

2 版本控制是基于每一次提交的,而不需要考虑每次提交了多少个文件。

下载:

下载网址为:http://git-scm.com/download,根据您的操作系统选择相应的安装宝,下载完后直接按照默认安装即可(本文讲述全部基于Windows操作系统)。

概述:

git源代码管理器的仓库位置可以基于本地服务器远程服务器两种方式:

本地服务器主要用于管理自己的代码,将本机作为源代码管理服务器;

远程服务器则用于将源代码公开,并由多个人来对代码进行编辑,主要用于团队开发中。

git源代码的提交流程,可以用下面这张图片来表示:

你的本地仓库由 git 维护的三棵“树”组成:

1) 工作目录(WorkDir),它持有实际文件;

2) 缓存区(Index),它像个缓存区域,临时保存你的改动;

3) HEAD,指向你最近一次提交后的结果。

经过上面三步以后,你的改动现在已经在本地仓库的 HEAD 中了,但是源代码并未保存(推送)到远程仓库,可以执行如下命令以将这些改动提交到远端仓库:git push origin master,(master表示你要提交的分支,可以把 master 换成你想要推送的任何分支)

使用方法:

1 初始化,创建项目;

1)以本机或者局域网电脑作为源代码管理服务器,

a) 需要在源代码管理服务器上面安装git

b) 然后创建一个目录(如git)作为源代码存储根目录,如"c:\\git"

c)进入git目录,点击鼠标右键菜单中的“Git Init Here"按钮,即可完成初始化操作(或者利用”Git Bash命令行程序通过执行“git init“命令完成初始化);

d)然后在该根目录下以项目为单位分别创建项目目录,或者创建一些文件,如readme(目录必须包含文件才会被提交,否则在提交的时候空目录会被忽略);

e)对于上一部创建的项目目录,需要在仓库根目录点击右键菜单中的”Git Commit Tool“按钮,然后点击弹出界面中的”提交“按钮,或者在仓库根目录点击右键菜单中的”Git Bash“,弹出命令行窗口,依次输入:git add .回车git -commit -m 'some message'回车,才能将初始化目录和文件提交到代码仓库中

2)如果oschina服务器作为源代码管理服务器,则省掉了初始化步骤,需要先在oschina的注册帐号,然后通过oschina提供的功能在线创建项目。访问地址举例:

  a)http方式:http://git.oschina.net/UserName/Test.git

  b)ssh方式:git@git.oschina.net:UserName/Test.git

2 将git仓库中文件克隆到本地

1)本地git仓库:进入要下载代码的目录入:c:\\git-workspace-local,点击右键菜单中的”Git Bash"按钮,弹出命令行窗口,输入命令:git clone '本地git仓库根目录', 本文为"c:\\git'

2)局域网或者oschina仓库:进入要下载代码的目录入:c:\\git-workspace-oschina,点击右键菜单中的”Git Bash"按钮,弹出命令行窗口,输入命令:git clone '远程git仓库地址', 如:http://git.oschina.net/UserName/Test.git或者git@git.oschina.net:UserName/Test.git(本人在采用git协议的进行clone的时候报错,不知是何故,还请阅者告之,谢谢!)

3 创建分支,创建分支操作智能在源代码管理器中创建,而非本地workspace

1)以本机或者局域网电脑作为源代码管理服务器:在源代码管理器服务器仓库根目录,点击右键菜单中的”Git History“,然后在弹出的”gitk:git“窗体左上角区域点击鼠标右键创建分支

2)远程服务器(oschina),直接通过网站”创建分支“功能创建;

4 分支切换: git checkout branchname

5 文件提交

1)在资源管理器中,创建/修改/删除/文件,或者在git bash工具中执行touch filename命令创建文件

2)通过执行:git add filename(用“.”替换文件名表示提交当前目录的所有文件),将修改提交到workspace;

3)通过执行:git commit -m 'some message of this commit', 将修改提交到缓冲区;

4)通过执行:git push origin branchname(本地存储),或者通过执行 git push 回车 用户名 回车 密码 回车(远程服务器)将修改提交到源代码管理仓库中去

注:在提交到本地仓库的时候,在执行上面第四步的时候,源代码管理仓库最好切换到与当前提交的的分支不同的分支(如现在有两个分支:master和MyBranch,当前工作区MyBranch进行checkout,
在执行git push的时候,源代码管理仓库最好切换到master 分支,否则在执行git push的时候会抱错)

6 文件夹提交:不直接支持空文件夹的提交,需要在文件中创建文件,然后提交文件,这样会将文件所在的文件夹一起提交。

 常见错误

1 在使用Git Push代码到数据仓库时,提示如下错误:

[remote rejected] master -> master (branch is currently checked out)

remote: error: refusing to update checked out branch: refs/heads/master

remote: error: By default, updating the current branch in a non-bare repository

remote: error: is denied, because it will make the index and work tree inconsistent

remote: error: with what you pushed, and will require 'git reset --hard' to match

remote: error: the work tree to HEAD.

remote: error:

remote: error: You can set 'receive.denyCurrentBranch' configuration variable to

remote: error: 'ignore' or 'warn' in the remote repository to allow pushing into

remote: error: its current branch; however, this is not recommended unless you

remote: error: arranged to update its work tree to match what you pushed in some

remote: error: other way.

remote: error:

remote: error: To squelch this message and still keep the default behaviour, set

remote: error: 'receive.denyCurrentBranch' configuration variable to 'refuse'.

To git@192.168.1.X:/var/git.server/.../web

! [remote rejected] master -> master (branch is currently checked out)

error: failed to push some refs to 'git@192.168.1.X:/var/git.server/.../web'

解决办法:

这是由于git默认拒绝了push到当前分支操作,需要进行设置,修改.git/config文件后面添加如下代码:

[receive]
denyCurrentBranch = ignore

无法查看push后的git中文件的原因与解决方法:在仓库根目录git bash 命令窗口中执行命令 git reset --hard 才能看到push后的内容.

在初始化远程仓库时最好使用(不知道为什么要这样做,使用该命令执行创建仓库后,创建的三一个空仓库,而且无法看到项目文件)

git --bare init

而不要使用:git init

git init 和git --bare init 的具体区别:http://blog.haohtml.com/archives/12265

推荐git学习的两篇文章:

1)git - 简易指南

2)图解Git[强烈推荐]

git@oschina.net源代码管理使用日记【转】的更多相关文章

  1. git@oschina.net源代码管理使用日记

    git的优势: 1 可以创建分支: 2 版本控制是基于每一次提交的,而不需要考虑每次提交了多少个文件. 下载: 下载网址为:http://git-scm.com/download,根据您的操作系统选择 ...

  2. git与svn, tfs等源代码管理器的协同

    简单地说,这三个都是业界知名的源代码管理器.他们是有区别的,根本的区别在于git是分布式源代码管理器(每个本地都有完整的代码,及历史),而svn和tfs是集中式源代码管理器(只有服务器才有完整的历史, ...

  3. iOS开发——源代码管理——git(分布式版本控制和集中式版本控制对比,git和SVN对比,git常用指令,搭建GitHub远程仓库,搭建oschina远程仓库 )

    一.git简介 什么是git? git是一款开源的分布式版本控制工具 在世界上所有的分布式版本控制工具中,git是最快.最简单.最流行的   git的起源 作者是Linux之父:Linus Bened ...

  4. Git学习总结(13)——使用git.oschina作为自己的源代码在线管理库

    工作有几年了,期间积累了很多的代码片段,一直想找个存放的地方,方便随时的取用.以前可能是放在自己电脑的硬盘中,但毕竟这样使用起来还是有很多不便. 下面通过码云来说明 一下设置过程.其实,码云和GitH ...

  5. 源代码管理工具-GIT

    源代码管理工具-GIT ---- 一. 掌握 - git 概述 1. git 简介? 什么是git? git是一款开源的分布式版本控制工具在世界上所有的分布式版本控制工具中,git是最快.最简单.最流 ...

  6. iOS核心笔记—源代码管理工具-GIT

    源代码管理工具-GIT 一. git 概述 1. git 简介? 什么是git? > git是一款开源的分布式版本控制工具 > 在世界上所有的分布式版本控制工具中,git是最快.最简单.最 ...

  7. 源代码管理之Git命令的使用

    目录 02.源代码管理之Git命令的使用 2.Git命令行演练-个人开发 2.1 如何学习git指令 2.2 初始化创建本地仓库 2.3 个人开发基本演练 2.4 Git的基本常识 3.Git命令行演 ...

  8. 使用git进行源代码管理

    git是一款非常流行的分布式版本控制系统,使用Local Repository追踪代码的修改,通过Push和Pull操作,将代码changes提交到Remote Repository,或从Remote ...

  9. Git 源代码管理工具

    Git 源代码管理工具 Git基本信息 Git :Git是一个“分布式”的版本控制工具 Git的作者是Linux之父 Linus Benedict Torvolds,当初开发Git仅仅是为了辅助Lin ...

随机推荐

  1. 'phantomjs.exe' executable needs to be in PATH. (selenium PhantomJS python)

    今天selenium PhantomJS python用了下,发现报错,提示我:'phantomjs.exe' executable needs to be in PATH. from seleniu ...

  2. js中关于array的常用方法

    最近总结了一些关于array中的常用方法, 其中大部分的方法来自于<JavaScript框架设计>这本书, 如果有更好的方法,或者有关于string的别的常用的方法,希望大家不吝赐教. 第 ...

  3. UVALive - 4975_Casting Spells

    题意很简单,给你一个字符串,要求你求出一个最长的形似于w(wr)w(wr)的最长连续子串的长度.wr表示w的逆序串. 在这里大家很容易就能想到Manacher算法求回文串.没有错,就是这个. 算法的详 ...

  4. C++解析(3):布尔类型与三目运算符

    0.目录 1.布尔类型 2.三目运算符 3.小结 1.布尔类型 C++中的布尔类型: C++在C语言的基本类型系统之上增加了bool C++中的bool可取的值只有true和false 理论上bool ...

  5. Notepad++查找和替换空行/空格/换行

    Notepad++查找和替换支持正则表达式,功能很强大,但比较复杂因此暂不研究 Notepad++使用正则表达式查找,首先需要勾选查找/替换窗口左下部的“正则表达式(E)”\r\n表示换行,其中\r表 ...

  6. 【BZOJ4709】柠檬(动态规划,单调栈)

    [BZOJ4709]柠檬(动态规划,单调栈) 题面 BZOJ 题解 从左取和从右取没有区别,本质上就是要分段. 设\(f[i]\)表示前\(i\)个位置的最大值. 那么相当于我们枚举一个前面的位置\( ...

  7. php安装gd库

    安装gd需要以下库: gd-2.0.33.tar.gz http://www.boutell.com/gd/ jpegsrc.v6b.tar.gz http://www.ijg.org/ libpng ...

  8. 【CF375C】Circling Round Treasures

    Portal --> CF375C Solution 一个有趣的事情:题目中有很大的篇幅在介绍如何判断一个位置在不在所围的多边形中 那么..给了方法当然就是要用啊 ​ 首先是不能包含\('B'\ ...

  9. day5-python基础

  10. MySQL自定义函数、触发器、存储过程

    存储过程 概念 存储过程,是一个数据库对象,类似一个函数. 在存储过程中可以使用SQL中的绝大部分内容,并且可以加入编程语言的特性(循环判断分支). 编写好存储过程之后,可以在客户端调用存储过程,存储 ...