怎么样在团队中使用github 团队

Github团队开发示例(一)
原文地址:
我们可以在上管理自己的团队项目。团队成员通过进行协同工作,也方便管理,接下来我提供一种Github团队建立仓库的目录格式,并对每个目录进行必要说明,最后根据这个目录结构写了一个简单的例子。
团队仓库目录结构
TestOrgName
下面一一说一下这些目录的作用:
TestOrgName
团队/组织名,可以自定义,最好用英文。
团队要做的项目名称,可以自定义,最好用英文。
在开发的时候,项目是部署在开发环境中的,所以项目中的一些配置文件,比如:数据库连接配置文件,都是用的开发环境的数据库连接配置,项目要部署上线的时候,我们需要把开发环境的数据库连接配置替换成生产环境的数据库连接配置,所以这个目录可以用来存生产环境的相关配置文件。
之所以将测试环境/开发环境/生产环境分开是因为开发过程中,需要对数据库中的一些数据进行测试或者修改,如果不和生产环境分开,会“污染”生产环境的数据。
在开发过程中,每次开发过程中涉及到要执行一些脚本,比如:开发过程中,要新建一个表,建表语句就要保存在这个目录里面,待开发完毕上线的时候,就需要在生产环境中执行这个建表语句。
这里存放项目的相关文档,比如:需求说明书,会议纪要,上线手册等。
这里存放项目源码。
我们通过这个简单的例子来说明如何配置相关目录中的信息。
团队基本信息
团队名称:PhoenixGoGo
团队要做的项目名称:helloworld
在Github中新建团队
新建organization
输入Organization Name等相关信息,并点击Create organization
邀请成员,这步我们先略过,点击Finish
此时,我们就把团队仓库新建完毕。
在团队仓库中新建项目
点击Create a new repository
输入项目相关信息, 并点击Create repository
此时,我们就把项目建好了。
初始化相关目录
先将项目clone至本地:
git clone https://github.com/PhoenixGoGo/helloworld.git
进入项目目录,并新建以下文件夹:
我们要将控制台输入的文本写入到C盘根目录中的file_product文件夹中的ds.txt文件中。
配置和初始化
为了不影响生产环境file_product文件夹中的ds.txt文件, 我们考虑在C盘根目录中新建一个file_develop的文件夹,并在这个文件夹里面ds.txt文件,我们平时在开发的时候,就读取file_develop中的ds.txt文件,等我们开发完毕测试通过以后,我们可以把相关的目录改为file_product。
为了说明问题,我通过脚本来新建相关目录,以Windows为例,
新建一个名为init_ds.bat文件,
用记事本打开这个文件写入以下内容并保存:
md &C:\file_develop&
cd &C:\file_develop&
cd.&ds.txt
双击这个bat文件,可以在C盘下生成了相关目录和文件。同时,我们把init_ds.bat文件放到helloworld/dbscripts文件夹下面。
因为以后发布项目的时候要切换目录,所以,我们不能把要读取的目录写死在代码里面,我们可以将目录路径写在配置文件里面,通过读取配置文件来获得目录的路径,这样我们在部署的时候只需要用生产环境的配置文件覆盖开发环境的配置文件即可。
我们可以新建两个配置文件,一个用于开发环境,一个用于生产环境。
我们先新建一个开发环境中需要的配置文件:
新建一个名为config.properties的配置文件,
用记事本打开这个文件写入以下内容并保存:
# test environment
file.name=C:/file_develop/ds.txt
再新建一个生产环境中需要的配置文件:
新建一个名为config.properties的配置文件,
用记事本打开这个文件写入以下内容并保存:
# product environment
file.name=C:/file_product/ds.txt
我们把这个用于生产的配置文件放在helloworld/configs下面。
项目源码(部分)
为了方便,这里对代码没有做优化和检查。
import java.io.BufferedW
import java.io.F
import java.io.FileInputS
import java.io.FileW
import java.io.IOE
import java.util.P
import java.util.S
public class App {
private static S
public static void main(String[] args) {
Properties prop = new Properties();
prop.load(new FileInputStream(&config/config.properties&));
scanner = new Scanner(System.in);
String line = null;
System.out.print(&please input:&);
while (!&exit&.equals(line = scanner.nextLine())) {
System.out.println(&input context = & + line);
System.out.print(&please input: &);
File writename = new File(prop.getProperty(&file.name&));
writename.createNewFile();
BufferedWriter out = new BufferedWriter(new FileWriter(writename));
out.write(line);
out.flush();
out.close();
System.out.println(&The program will exit&);
} catch (IOException e) {
e.printStackTrace();
我们将源码放入helloworld/src目录下。
我们将helloworldpush到远程仓库:
控制台下分别执行以下命令:
cd helloworld
git commit -m &if applied, this commit will init project&
git push -u origin master
此时,项目的结构是这样的:
项目组经常会有新来的成员 ,他们如何在没有老成员带的情况下,通过文档就可以在一台全新的机器上部署项目呢?
这时候我们就需要一个文档,来说明项目如何部署运行,下面是这个helloword项目的部署文档,仅供参考:
打开Eclipse,设置编码格式UTF-8:
Window-&Preferences-&General-&Workspace-&Text file encoding-&UTF-8
在Eclipse中打开:
Window-&Show View-&Other...-&找到Git Repositories并双击
Window-&Show View-&Other...-&找到Git Staging并双击
配置Maven到Eclipse中:
Window-&Preferences-&Maven-&Installations-&Add...-&选择前面安装的Maven的目录
点击Finish。
在Git Repositories下点击clone git repository
输入URI以及Github用户名和密码
在控制台下,我们进入源码的目录执行:
mvn eclipse:eclipse
在src目录下右键,选择Import Projects:
选择import existing Eclipse Projects:
项目导入完成
选择App.java
右键-& Run As-&Java Application
以上为helloworld这个项目的开发部署文档, 我们可以将其保存为:develop_guide.md 文件,
并且放到hellworld/docs目录下
最后,把docs目录也提交到团队仓库中去。
增加团队成员
团队仓库初始化好以后,我们可以增加团队成员进行协作开发:
点击Invite member
输入你的团队成员的Github账户即可对相应的成员发出邀请,接收到邀请的成员要进Github注册邮箱进行确认方可加入:
这里包含两类人:Member/Owner :
他们拥有的权限可以自定义,管理员可根据需要配置不同团队成员的权限:
阅读(...) 评论()> 博客详情
摘要: 多用户基于同一个Github上得项目并行开发,当前用户的开发流程
多用户基于同一个Github上得项目并行开发,当前用户的开发流程:
origin:默认的远程主机名
master:默认的远程主分支名
1:首先要将Github上的项目克隆到本地(第一次克隆,说明你的本地上还没有项目源码,所以先克隆)。
git clone “URL”
2:然后建立一个属于自己的分支:
git checkout -b mybranch_1.0 origin/master & (从远程服务器上克隆的项目默认分支均为master,现在你本地只有两个分支,一个是主分支master,还有一个是你的分支mybranch_1.0)
3:将自己的分支提交到远程服务器上
git& push origin& mybranch_1.0& (这一步一定要紧跟上一步,防止其他人建立跟你同名的分子)
4:经过2和3两个步骤,我们建立了属于自己的分支,并且我们已经在当前的分支下了,我们可以进行编码工作。
5:编码结束之后,我们要进行三步操作:
首先将自己的改动提交到缓冲区:
git add &filename&
然后提交实际改动到HEAD(只是本地改动,还没有提交到远程库):
git commit -m “代码修改信息”
最后 git push origin mybranch_1.0,将自己的分支提交到远程对应的自己的分子
6:现在我们就可以切回到主分支继续进行工作:git checkout master
7:现在你的编码工作基本完成,接下来就是将本地代码上传的远程库。由于其他开发者可能对远程库,所以需要将别人的改动同步到本地:
这样,你本地的master已经是最近的版本了。
8:接下来我们需要将自己刚刚的mybranch_1.0和本地的master合并
git checkout mybranch_1.0
git merge master
git push origin mybranch-1.0
现在是将最新代码提交到你的远程分支上了。
然后上线,确认无错误后才能,我们需要将没有branch_1.0分支合并到master上。
git checkout master
git merge mybranch_1.0
9:现在我们就可以将我们的master提交到远程了
git push origin master
以上就是你同别人协同开发项目的过程了。
当然,git还有很多有用的命令:fetch
git fetch origin 分支名(取自己想要的分支)
分支映射出错,没有映射到同名的分支:git branch - -set-upstream-to = origin/mc_1.2.7
我们也可以在项目库里建立自己的分支,可以不和主分支master合并。
支付宝支付
微信扫码支付
打赏金额: ¥
已支付成功
打赏金额: ¥你必须收藏的Github技巧
腾讯前端团队分享的
Github 使用技巧,还是非常好用的。&
作者:AlloyTeam&
原文:http://www.alloyteam.com/2016/12/you-must-collect-the-github-tips/
GitHub Pages 大家可能都知道,常用的做法,是建立一个 gh - pages 的分支,通过 setting 里的设置的
GitHub Pages 模块可以自动创建该项目的网站。
这里经常遇到的痛点是, master 遇到变更,经常需要去 sync 到 gh - pages ,特别是纯 web
前端项目,这样的痛点是非常地痛。
Github 官方可能嗅觉到了该痛点,出了个 master 当作网站是选项,太有用了。
选择完 master branch 之后, master 自动变成了网站。 master 所有的提交会自动更新到网站。
精准分享关键代码
比如你有一个文件里的某一行代码写得非常酷炫或者关键,想分享一下。 可以在 url
后面加上&*
比如,点击下面这个 url :
https://github.com/AlloyTeam/AlloyTouch/blob/master/alloy_touch.js#L240
你便会跳到 alloy_touch.js 的第240行。
那么问题来了?如果我是一段代码,即多行代码想分享呢?也很简单: url
后面加上&*
#L开始行号——L结束行号*
比如,AlloyTouch的运动缓动和逆向缓动函数如下面代码段所示:
https://github.com/AlloyTeam/AlloyTouch/blob/master/alloy_touch.js#L39-L45
其实也不用记忆你直接在网址后面操作, github 自动会帮你生成 url 。比如你点击39行, url 变成了
https://github.com/AlloyTeam/AlloyTouch/blob/master/alloy_touch.js#L39
再按住 shift 点击45行, url 变成了
https://github.com/AlloyTeam/AlloyTouch/blob/master/alloy_touch.js#L39-L45
然后你这个 url 就可以复制分享出去了,点击这个 url 的人自动会跳到39行,并且39-45行高亮。
通过提交的 msg 自动关闭 issues
比如有人提交了个issues&https://github.com/AlloyTeam/AlloyTouch/issues/6&然后你去主干上改代码,改完之后提交填
msg 的时候,填入:
https://github.com/AlloyTeam/AlloyTouch/issues/6
这个 issues 会自动被关闭。当然不仅仅是 fix 这个关键字。下面这些关键字也可以:
通过 HTML 方式嵌入 Github
如下面所示, user 和 repo 改成你想要展示的便可以
src="//ghbtns.com/github-btn.html?user=alloyteam&repo=alloytouch&type=watch&count=true"
allowtransparency="true"
frameborder="0"
scrolling="0"
width="110"
height="20"&
插入之后你便可以看到这样的展示:
gitattributes 设置项目语言
如上图所示, github 会根据相关文件代码的数量来自动识别你这个项目是 HTML 项目还是 Javascript 项目。
这就带来了一个问题,比如AlloyTouch最开始被识别成HTML项目。
因为 HTML 例子比 JS 文件多。怎么办呢? gitattributes 来帮助你搞定。在项目的根目录下添加如下。
gitattributes 文件便可,https://github.com/AlloyTeam/AlloyTouch/blob/master/.gitattributes&里面的:
*. html linguist
- language = JavaScript
主要意思是把所有 html 文件后缀的代码识别成 js 文件。
查看自己项目的访问数据
在自己的项目下,点击 Graphs ,然后再点击 Traffic 如下所示:
里面有 Referring sites 和 Popular content 的详细数据和排名。如: Referring
其中 Referring sites 代表大家都是从什么网站来到你的项目的, Popular content
代表大家经常看你项目的哪些文件。
trending 排行榜
上面教大家设置语言了,下面可以看看怎么查看某类型语言的每日排行榜。比如 js 每日排行榜:
https://github.com/trending/javascript?since=daily
https://github.com/trending/html?since=daily
https://github.com/trending/css?since=daily
Github推荐:https://github.com/explore
issue 中输入冒号 : 添加表情
任意界面, shift + ?显示快捷键
issue 中选中文字, R 键快速引用
好了,我就会这么多,也是我经常使用的技巧。欢迎补充实用的技巧~~我会持续更新上去…
我们团队的Github:&http://alloyteam.github.io/
题图:pexels.com,CC0授权。
点击阅读原文,查看更多 Python
教程和资源。
阅读原文:http://mp.weixin.qq.com/s?__biz=MzAwNDc0MTUxMw==&mid=&idx=1&sn=86f5c231cb9326b3af73&chksm=833dab96b44a0ed75ef6ee1bfcd2cb088b634de5c99ee8995ffc25#rd
已投稿到:
以上网友发言只代表其个人观点,不代表新浪网的观点或立场。如何使用github和git进行团队合作开发_百度知道
如何使用github和git进行团队合作开发
我有更好的答案
使用Git进行Eclipse团队合作,并且将代码托管到GitHub
为您推荐:
其他类似问题
换一换
回答问题,赢新手礼包
个人、企业类
违法有害信息,请在下方选择后提交
色情、暴力
我们会通过消息、邮箱等方式尽快将举报结果通知您。他的最新文章
他的热门文章
您举报文章:
举报原因:
原文地址:
原因补充:
(最多只允许输入30个字)

我要回帖

更多关于 团队使用github 的文章

 

随机推荐