本文主要介绍一下如何将我们的项目托管到Github功能包括:
1.托管项目到Github,用git来进行管理
2.如何修改提交
3.项目阶段性标记tag
详细步骤如下:
1:注册Github的账号,这是必须滴。怎么注册?按照正常的注册流程就好。注册传送门Github
2:先科普一下有关gitHub。
gitHub网站使用Git版本管理工具来对仓库进行管理,注意它们并不等同。gitHub是全球最大的第三方开源库集散地,Git是一款分布式的版本管理控制工具(除了git之外还有一些其他的版本管理控制工具如SVN等)。
如有需要请参考:Git教程。
关于Git使用的相关书籍:Git版本控制管理(第2版),Git权威指南(电子版下载地址)。
3:在github上面建立空的仓库(repositories)
3.1:在第一步中注册成功,登陆github账号。
3.2:点击头像右边的加号+,选择new repositories选项,简单配置后即可创建一个空的仓库。其中repositories name处需要填写的是仓库的名称。Description (optional)处填写对该仓库的简单描述,主要是介绍下仓库的功能等(可以不写)。
3.3:接下来是两个选项(Public|private)表示你创建的仓库是公开的还是私有的。Public和private有什么不同呢?如果仓库是公开的那么意味着任何人都可以无条件的获得你整个仓库的内容,免费。如果仓库是私有的,那么别人无法访问你的私有仓库,条件是需要花钱交保护费,在这里我们选择public仓库即可。
3.4:Initialize this repository with a README 表示在初始化仓库的时候,是否生成一个readMe文件。我们在查看别人框架的时候,在框架主页上会有对该框架版本信息.
Add .gitignore按钮,点击之后会出现一个下拉框,问你是否要设置仓库的忽略文件。这个看你自己的需要,通常如果你的仓库和代码项目有关系,那么最好选择相应的忽略文件(如OC项目可以选择Object-C,swift项目可以选择Swift),至于为什么请参考GIT的基本使用。
Add a license按钮,点击之后会出现一个下拉框,需要你选择一种开源协议,开源协议有很多种用的比较多的有MIT的或者是Apache的,不同的开源协议对项目的使用方式等有不同的规定,详情可以参考Choose an open source license。
3.5:上面的信息都设置好之后,接下来只需要轻轻点击Create respository按钮即可创建一个空的仓库。
4:连接远程仓库
连接远程仓库的方式有很多种,可以使用第三方的GIT管理图形界面工具如sourceTree,也可以使用终端(命令行),或者是XCode。在这里就选择使用XCode来完成该操作。
把MAC 上面的XCode打开,打开之后,左上角菜单选择Xcode->Preference选项
进入到XCode的配置信息窗口。
切换到Accounts菜单,点击左下角的+号,选择Add Respository添加仓库。
Address需要输入要连接的远程仓库地址,其实要连接远程仓库有两种方式可以选择一种是HTTPS请求的,一种是SSH密钥对。在这里,我们先讲解HTTPS请求应该如何处理,如何获得仓库地址呢?选择clone with https后拷贝输出框中地址
Type:表示使用的版本管理方式可以选择GIT和SVN,在这里只能选择Git(因为GIThub只支持git的方式来管理)
Authentication:表示认证的方式即验证身份的,Github提供两种验证方式,HTTPS和SSH,我们当前选择的是HTTPS的方式,所以此处选择User Name and Password.
User Name 和passWord两处填入github网站登录的用户名和密码即可。
配置完成之后,点击add按钮,出现下面的窗口,则说明连接仓库成功。
5:把远程仓库下载到本地
连接上远程仓库之后,接下来我们把远程仓库下载到本地,如图选择菜单栏的source control->check out。
之后会弹出如下界面,找到要下载的仓库(通常在最后),点击Next
点击Next按钮之后,需要你选择仓库下载后的存储位置,然后点击Finsh完成即可。把仓库下载完成之后,可以发现内部有一个.git的隐藏文件,即git的版本库。
补充:可以在终端输入如下命令来显示或者是不显示隐藏文件
- 显示隐藏文件 $ defaults write com.apple.finder AppleShowAllFiles Yes && killall Finder
- 不显示隐藏文件$ defaults write com.apple.finder AppleShowAllFiles No && killall Finder
第七步:添加OC项目到仓库中并推送到远程服务器
1)首先先新建一个项目,假设为ZZDemo,项目创建后保存到仓库路径下(和.git文件同级)
2)打开项目,会发现在项目的导航栏中各个文件会显示不同的状态如?M等等,通过这种方法来初始化项目,项目本身已经被纳入到git版本库的管理范畴。
3)把修改提交到本地并推送到远程服务器。
XCode本身已经对git进行了很好的集成,点击菜单栏上面的source control选项
其中check out 等同于git 命令行中的clone指令,用于把远程仓库下载到本地。
commit 等同于git命令行中的commit指令(无差别),用于把更改提交到本地git版本库。
push等同于git命令行中的push指令(无差别),用于把更改提交到远程的git仓库中。
pull指令等同于git命令行中pull指令(无差别),用于获取得到最新的远程仓库信息。
此处,我们需要先选择commit选项,先把更改提交到本地的版本库。选择commit
命令行操作
上面所有演示都没有涉及到命令行,那如果不使用XCode而是使用命令行,应该如何处理增加、删除、提交等常见操作呢?
1)新创建文件,需要把创建的文件提交到本地的git版本库。
把终端打开,cd进入到仓库路径,然后创建一个NewFile文件,如下图所示:
新创建了NewFile文件之后,该文件默认并不会被git版本库管理(可以使用git status命令查看),需要使用add 命令先把指定的文件添加到git的暂缓区,然后再提交到git的版本库,如下图所示。
命令说明:
$ ls -l 以列表的方式显示当前目录下面的文件(NewFile文件为刚刚创建的)
$ git status 查看git仓库文件状态 (NewFile文件状态为红色,表示未被git管理)
$ git add NewFile 把NewFile文件添加到git的暂缓区中(如果需要一次性提交多个文件,那么可以使用git add .命令)
$ git status 重新查看状态(此时NewFile文件状态为绿色,表示更改已经提交到了暂缓区)
$ git commit -m "创建了NewFile文件" NewFile 表示把暂缓区中NewFile文件对应的更改提交到本地的git版本库(如果要一次性提交所有的更改,那么可以直接把具体的文件省略即可)
2)把文件提交到远程(github)的仓库
说明:使用git push指令把本地的更改推送到远程仓库。
此时重新刷新下github网站上该仓库的主页,可以发现NewFile文件已经提交。
3)修改文件,并把修改操作提交到远程仓库。
假设我们修改了NewFile文件,然后把修改提交到git暂缓区,提交到本地的git版本库之后,再推送到远程的仓库。
第九步:其他操作(tag标记)
如果你的项目已经完成了里程碑开发,那么可以确定为一个新的版本,比如说发布为正式的1.0版本,而后续可能接着发布1.1.0或者是2.0版本等等,那么使用github托管的项目如何确定为一个新的版本呢?或者是如何进行tag标记。
如果仓库没有发布特定的版本,那么release处显示为0.
假设当前的项目已经完成了阶段性的开发,需要正式确定为ZZDemo1.0版本,那么应该如何处理?
上面的命令行~
(1)先使用git tag指令查看当前被打上tag标签的版本,最开始的时候无
(2)然后把当前的仓库打上tag标签,为ZZDemo1.0版本,并添加注释
(3)再使用git tag指令查看,即可以发现有ZZDemo1.0版本
确定了新版本之后,还需要把标签推送到远程服务器,命令行为git push origin 标签名,具体操作如下图所示:
推送到远程仓库之后,刷新github上面该仓库主页,发现release处变为1,点击该按钮就可以看到(提供标记版本的压缩下载)