夺命雷公狗----Git---4---多人协作实现
基本流程:
1..创建一个git裸服务器(git init --bare)
2..从裸服务器将版本库克隆到本地(git clone)
3..本地常规操作(git remote + git push origin master)
4..从远程服务器拉取版本(git pull)
在正常情况下都是搭建在linux服务器上的,不过这次我可以在windows上模拟一个环境来实现给大家看看
先抽奖一个test2的文件夹,一般的情况下这个都是放在公司的服务器上的。。。

然后进入git 创建一个裸服务器
git init --bare

上面的 Repository 的中文意思是仓库的意思噢,嘻嘻。。
然后我们即可发现 test2 目录下多了很多的东西:

其实所谓的裸服务器就是指版本库的内容,没有工作区。
如果非要操作的话就会出先如下类型的错误,所以在这个目录下没有操作的权限

所以对于git服务器而言,所要做的就是创建好版本库,没有其他的。。。。
第二步就是要服务器版本库克隆到本地
首先就要将服务器上的版本库克隆到自己的电脑上
git clone 地址
如: git clone 192.168.0.1 这里一般都是公司的一个版本库服务器的ip或者一个域名,看实际情况来定
在本地里创建了一个test3的文件夹,然后在git下输入git clone 地址,因为在本地测试的,所以直接输入盘符即可
git clone D:\git\test2

很明显在test3 文件夹里面多了一个文件夹。。。
然后我们进去看下里面有什么东西:

很明显发现里面多了一个.git的隐藏目录文件,所以我们在自己的电脑上省去了git init 的操作了。。。。
比如程序员在里面写好了一个index.html 文件,如下所示:

有了这个文件后,他即可通过git add index.html 将文件添加到文件 暂存区 然后在git commit -m XXXXX 这样即可添加到文件仓库里面了。。。。

发现会报一个和上面这样的错误,其实原因也很简单,因为我们没设置用户名和邮箱,之需要创建好这两个问题即可解决。。。。
在这和时候BBBB程序员也来了,他也需要干同样的事情,比如创建一个test4的文件将来模拟BBBB程序员的电脑,那么他也是需要首先从服务器的仓库中克隆到自己的电脑上。。。

然后还需要进入文件夹的位置才可以。。。

这样我们即可进入该文件夹了,然后在这里面即可做他的常规开发即可。。。


经过团们的一同开发后我们需要将文件push到服务器上。。。。。。。
那么我们首先要知道服务器在那才可以,对不对?
所以我们需要用到一条命令:
git remote来进行查看下,如下所示:
git remote

因为我们已知文件地址在那了那里了,所以直接用路径的方式来push即可:
git push origin master

然后AAA用户想同步下即可用到pull来进行同步

但有可能有些朋友是第一次拉取,所以需要加 --allow-unrelated-historeies 即可
git pull origin master --allow-unrelated-histories
他会进入一个vi编辑器,然后用 :q退出即可。。

效果如下所示:

夺命雷公狗----Git---4---多人协作实现的更多相关文章
- 夺命雷公狗-----React---12--添加类和样式
<!DOCTYPE> <html> <head> <meta charset="utf-8"> <title></ ...
- 夺命雷公狗-----React---11--添加css样式的方法
<!DOCTYPE> <html> <head> <meta charset="utf-8"> <title></ ...
- 夺命雷公狗-----React---10--组建嵌套进行数据遍历
先写一个组建... 然后进行嵌套.. <!DOCTYPE html> <html lang="en"> <head> <meta char ...
- 夺命雷公狗-----React---9--map数据的遍历
比如我们要实现的是这种效果: 用这种方法来写,她只能写死在哪,没啥意思,所以我们定义一个数据,然后来测试下map方法对她遍历出来的数据 <!DOCTYPE html> <html l ...
- 夺命雷公狗-----React---8--react官方提供的组建实现双向绑定
首先要引入她.. <!DOCTYPE html> <html lang="en"> <head> <meta charset=" ...
- 夺命雷公狗-----React---7--组建的状态props和state
props:组建初始要渲染的数据,他是不可以改变的 state:组建状态发生改变,调用render重新渲染数据 我们来写一个例子: <!DOCTYPE html> <html lan ...
- 夺命雷公狗-----React---6--props多属性的传递
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 夺命雷公狗-----React---5--props对象的传递
提示:props的值是不可以改变的... <!DOCTYPE html> <html lang="en"> <head> <meta ch ...
- 夺命雷公狗-----React---4--props变量的传递
提示:props的值是不可以改变的... <!DOCTYPE html> <html lang="en"> <head> <meta ch ...
- 夺命雷公狗-----React---3--标签的规则
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
随机推荐
- JAVA_Android APK反编译就这么简单 详解(附图)
在学习Android开发的过程你,你往往会去借鉴别人的应用是怎么开发的,那些漂亮的动画和精致的布局可能会让你爱不释手,作为一个开发者,你可能会很想知道这些效果界面是怎么去实现的,这时,你便可以对改应用 ...
- linux 添加 service 服务并自动添加 chkconfig 启动级别
下面以添加一个叫做watchcat的服务为例进行说明: 1.写一个提供给service命令使用的脚本 service 命令的使用方法一般如下 启动: $ service watchcat start ...
- c#实现简单金山打字小游戏(源码)
using GameDemo.Utils;using System;using System.Collections.Generic;using System.Linq;using System.Te ...
- [转载]C++堆栈的入门学习
申明: 转自 http://www.cnblogs.com/pengshao/archive/2011/12/26/2301461.html 头文件stackDemo.h #pragma o ...
- UIPickerView理解
- CI框架3
1.CI不能像smarty那样直接{}访问, <?php echo $ci;?> application\config\ config.php 日志查看 $config['lo ...
- 《实时控制软件设计》第一周作业 欧梓峰 U201317662 (更新)
CNC 插补计算程序分析 前言:插补(Interpolation),即机床数控系统依照一定方法确定刀具运动轨迹的过程.一般是已知起点坐标.终点坐标和轨迹,由数控插补计算程序实时的算出各个中间的坐标来拟 ...
- OMXplayer播放视频的参数说明
1.OMXplayer支持硬解码,因此是一个非常不错的选择.2.支持格式目前知道的有:MKV.AVI.FLV.MP43.如果想用全屏播放,参数是:-r4.如果想用HDMI输出声音,参数是:-o hdm ...
- CSS方法论完全总结
软件开发领域所有的工程问题,归根结底衍生自一个问题:代码量大了怎么办? 对于CSS而言,因代码量增大导致的核心问题是命名冲突. 解决命名冲突的方法论是模块化,围绕此方法论,演化出种种模块化方案. 一. ...
- C# fun
C#中Func<T,TResult>的用法和Lambda表达式 代码片段: Func<int,string,string> t=(int x, string b) => ...