- 浏览: 581933 次
- 性别:
- 来自: 广州
文章分类
最新评论
-
JYY282:
[i][/i]
Ecshop与Shopex的比较 -
qq247890212:
我也遇见这问题了,真诡异。重新下载个猫换了就好了。 太浪费时间 ...
诡异:ClassNotFoundException: org.springframework.web.filter.CharacterEncoding
From: http://www.cppblog.com/kesalin/archive/2011/11/08/git_xcode.html
Mac 下配置 Git 服务器
XCode 默认支持 Git 作为代码仓库,当我们新建一个仓库的时候,可以勾选创建默认仓库,只不过这个仓库是在本地的。本文介绍如何在 mac 机器上创建 Git 服务器,总体思路是:使用 gitosis 来简化创建过程,在用作服务器的机器上创建一个名为 git 的账户来创建 git 服务器,其他客户端通过 ssh 机制访问 git 服务器。
本文文档:点此下载
一,创建 git 账户
1,在用作服务器的机器 Server 上创建 git 账户。我们可以通过 System Preferences->accounts 来添加。在这里我添加一个 git 的 administrator 账户,administrator 不是必须的,在这里仅仅为了方便。
2,设置远程访问
logout 当前账户,使用 git 账户登录;在 System Preferences->Sharing 中,勾选:Web Sharing 和 Remote Logig。
二,下载安装 gitosis
1,Mac Snow默认已经为我们安装了 Git 和 Python,可以使用如下命令查看其版本信息:
yourname:~ git$ git --version
git version 1.7.3.4
yourname:~ git$ python --version
Python 2.6.1
git version 1.7.3.4
yourname:~ git$ python --version
Python 2.6.1
2,通过命令 "git clone git://eagain.net/gitosis.git" 来下载 gitosis
yourname:~ git$ git clone git://eagain.net/gitosis.git
Cloning into gitosis
remote: Counting objects: 614, done.
remote: Compressing objects: 100% (183/183), done.
remote: Total 614 (delta 434), reused 594 (delta 422)
Receiving objects: 100% (614/614), 93.82 KiB | 45 KiB/s, done.
Resolving deltas: 100% (434/434), done.
Cloning into gitosis
remote: Counting objects: 614, done.
remote: Compressing objects: 100% (183/183), done.
remote: Total 614 (delta 434), reused 594 (delta 422)
Receiving objects: 100% (614/614), 93.82 KiB | 45 KiB/s, done.
Resolving deltas: 100% (434/434), done.
3,进入 gitosis 目录,使用命令 "sudo python setup.py install" 来执行 python 脚本来安装 gitosis。
yourname:~ git$ cd gitosis/
yourname:gitosis git$ sudo python setup.py install
running install
running bdist_egg
running egg_info
creating gitosis.egg-info
……
Using /Library/Python/2.6/site-packages/setuptools-0.6c9-py2.6.egg
Finished processing dependencies for gitosis==0.2
yourname:gitosis git$ sudo python setup.py install
running install
running bdist_egg
running egg_info
creating gitosis.egg-info
……
Using /Library/Python/2.6/site-packages/setuptools-0.6c9-py2.6.egg
Finished processing dependencies for gitosis==0.2
三,制作 ssh rsa 公钥
1,回到 client 机器上,制作 ssh 公钥。在这里我的使用同一台机器上的另一个账户作为 client。如果作为 client 的机器与作为 server 的机器不是同一台,也是类型的流程:制作公钥,放置到服务的 /tmp 目录下。只不过在同一台机器上,我们可以通过开启另一个 terminal,使用 su 切换到 local 账户就可以同时操作两个账户。
yourname:~ git$ su local_account
Password:
bash-3.2$ cd ~
bash-3.2$ ssh-keygen -t rsa
Generating public/private rsa key pair.
Enter file in which to save the key (/Users/local_account/.ssh/id_rsa):
Enter passphrase (empty for no passphrase):
Enter same passphrase again:
Your identification has been saved in /Users/local_account/.ssh/id_rsa.
Your public key has been saved in /Users/local_account/.ssh/id_rsa.pub.
bash-3.2$ cd .ssh
bash-3.2$ ls
id_rsa id_rsa.pub
bash-3.2$ cp id_rsa.pub /tmp/yourame.pub
Password:
bash-3.2$ cd ~
bash-3.2$ ssh-keygen -t rsa
Generating public/private rsa key pair.
Enter file in which to save the key (/Users/local_account/.ssh/id_rsa):
Enter passphrase (empty for no passphrase):
Enter same passphrase again:
Your identification has been saved in /Users/local_account/.ssh/id_rsa.
Your public key has been saved in /Users/local_account/.ssh/id_rsa.pub.
bash-3.2$ cd .ssh
bash-3.2$ ls
id_rsa id_rsa.pub
bash-3.2$ cp id_rsa.pub /tmp/yourame.pub
在上面的命令里,首先通过 su 切换到 local 账户(只有在同一台机器上才有效),然后进入到 local 账户的 home 目录,使用 ssh-keygen -t rsa 生成 id_rsa.pub,最后将该文件拷贝放置到 /tmp/yourname.pub,这样 git 账户就可以访问 yourname.pub了,在这里改名是为了便于在 git 中辨识多个 client。
四,使用 ssh 公钥初始化 gitosis
1,不论你是以那种方式(邮件,usb等等)拷贝 yourname.pub 至服务器的 /tmp/yourname.pub。下面的流程都是一样,登入服务器机器的 git 账户,进入先前提到 gitosis 目录,进行如下操作初始化 gitosis,初始化完成后,会在 git 的 home 下创建 repositories 目录。
yourname:gitosis git$ sudo -H -u git gitosis-init < /tmp/yourname.pub
Initialized empty Git repository in /Users/git/repositories/gitosis-admin.git/
Reinitialized existing Git repository in /Users/git/repositories/gitosis-admin.git/
Initialized empty Git repository in /Users/git/repositories/gitosis-admin.git/
Reinitialized existing Git repository in /Users/git/repositories/gitosis-admin.git/
在这里,会将该 client 当做认证受信任的账户,因此在 git 的 home 目录下会有记录,文件 authorized_keys 的内容与 yourname.pub 差不多。
yourname:~ git$ cd ~
yourname:~ git$ cd .ssh
yourname:.ssh git$ ls
authorized_keys
yourname:~ git$ cd .ssh
yourname:.ssh git$ ls
authorized_keys
我们需要将 authorizd_keys 稍做修改,用编辑器打开它,删除里面的"command="gitosis-serve yourname",no-port-forwarding,no-X11-forwarding,no-agent-forwarding,no-pty " 这一行:
yourname:.ssh git$ open -e authorized_keys
然后,我们对 post-update 赋予可写权限,以便 client 端可以提交更改。
yourname:gitosis git$ sudo chmod 755 /Users/git/repositories/gitosis-admin.git/hooks/post-update
Password:
yourname:.ssh git$ cd ~
yourname:~ git$ cd repositories/
yourname:repositories git$ ls
gitosis-admin.git
yourname:repositories git$
Password:
yourname:.ssh git$ cd ~
yourname:~ git$ cd repositories/
yourname:repositories git$ ls
gitosis-admin.git
yourname:repositories git$
在上面的命令中可以看到,gitosis 也是作为仓库的形式给出,我们可以在其他账户下 checkout,然后对 gitosis 进行配置管理等等,而无需使用服务器的 git 账户进行。
最后一步,修改 git 账户的 PATH 路径。
yourname:gitosis git$ touch ~/.bashrc
yourname:gitosis git$ echo PATH=/usr/local/bin:/usr/local/git/bin:\$PATH > .bashrc
yourname:gitosis git$ echo export PATH >> .bashrc
yourname:gitosis git$ cat .bashrc
PATH=/usr/local/bin:/usr/local/git/bin:$PATH
export PATH
yourname:gitosis git$ echo PATH=/usr/local/bin:/usr/local/git/bin:\$PATH > .bashrc
yourname:gitosis git$ echo export PATH >> .bashrc
yourname:gitosis git$ cat .bashrc
PATH=/usr/local/bin:/usr/local/git/bin:$PATH
export PATH
至此,服务器的配置完成。
五,client 配置
1,回到 local 账户,首先在 terminal 输入如下命令修改 local 的 git 配置:
bash-3.2$ git config --global user.name "yourgitname"
bash-3.2$ git config --global user.email "yourmail@yourcom.com"
bash-3.2$ git config --global user.email "yourmail@yourcom.com"
2,测试服务器是否连接正确,将 10.1.4.211 换成你服务的名称或服务器地址即可。
yourname:~ local_account$ ssh git@10.1.4.211
Last login: Mon Nov 7 13:11:38 2011 from 10.1.4.211
Last login: Mon Nov 7 13:11:38 2011 from 10.1.4.211
3,在本地 clone 服务器仓库,下面以 gitosis-admin.git 为例:
bash-3.2$ git clone git@10.1.4.211:repositories/gitosis-admin.git
Cloning into gitosis-admin
remote: Counting objects: 5, done.
remote: Compressing objects: 100% (5/5), done.
remote: Total 5 (delta 0), reused 5 (delta 0)
Receiving objects: 100% (5/5), done.
bash-3.2$ ls
Desktop InstallApp Music Sites
Documents Library Pictures gitosis-admin
Downloads Movies Public
bash-3.2$ git
Cloning into gitosis-admin
remote: Counting objects: 5, done.
remote: Compressing objects: 100% (5/5), done.
remote: Total 5 (delta 0), reused 5 (delta 0)
Receiving objects: 100% (5/5), done.
bash-3.2$ ls
Desktop InstallApp Music Sites
Documents Library Pictures gitosis-admin
Downloads Movies Public
bash-3.2$ git
在上面的输出中可以看到,我们已经成功 clone 服务器的 gitosis-admin 仓库至本地了。
4,在本地管理 gitosis-admin:
进入 gitosis-admin 目录,我们来查看一下其目录结构:gitosis.conf 文件是一个配置文件,里面定义哪些用户可以访问哪些仓库,我们可以修改这个配置;keydir 是存放ssh 公钥的地方。
bash-3.2$ cd gitosis-admin/
bash-3.2$ ls
gitosis.conf keydir
bash-3.2$ cd keydir/
bash-3.2$ ls
yourname.pub
bash-3.2$ ls
gitosis.conf keydir
bash-3.2$ cd keydir/
bash-3.2$ ls
yourname.pub
我们只需要将其他 client 产生的 ssh 公钥添加到 keydir 目录下,并在 gitosis.conf 文件中配置这些用户可以访问的仓库(用户名与放置在 keydir 下sh 公钥名相同,这就是在前面我们要修改ssh 公钥名的原因),然后将改动提交至服务器,这样就可以让其他的 client 端访问服务器的代码仓库了。
整合 XCode 4与 Git
一,服务器配置
1,首先在服务器上使用 git 账户登录,进入服务器的 repositories(请参考前文),创建一个空仓库:
2,在Git 服务器配置中增加用户对这个仓库的写权限。进入 repositories/gitosis-admin.git 目录,在 gitosis.conf 中增加如下内容:
二,客户端配置
1(注1),回到你自己机器的 local 账户,使用 XCode 4 创建一个使用本地 Git 仓库的工程,关闭该工程。
2,进入到该工程的目录下,使用如下命令初始化远程仓库。
3,这样我们就可以在该目录下使用 git 命令来操作了,当然也可以使用可视化工具(OpenInGitGui,使用方法:在 Git 目录双击该工具打开即可)。
4,打开该 XCode 工程,修改代码,然后使用 File -> Source Control -> Commit(提交到本地),然后使用 Push 提交到服务器。在第一次 Push 的时候会提示权限受限,没有关系,try again,就能成功了。
5,我们可以在别的地方新建一个空目录来检验仓库是否有内容,以及刚刚的修改。在 Documents (或别的地方)下新建一个空目录 test,进入该目录:
注1:为已有工程创建 git 仓库,我们只需要进入到该工程目录下使用如下命令即可。
1,首先在服务器上使用 git 账户登录,进入服务器的 repositories(请参考前文),创建一个空仓库:
mkdir hello-world.git
cd hello-world.git
git --bare init
cd hello-world.git
git --bare init
2,在Git 服务器配置中增加用户对这个仓库的写权限。进入 repositories/gitosis-admin.git 目录,在 gitosis.conf 中增加如下内容:
[group mac]
writable = hello-world
memebers = yourname
yourname 为用户名,可以使用空间隔开以添加多个用户。至此服务器配置完成。writable = hello-world
memebers = yourname
二,客户端配置
1(注1),回到你自己机器的 local 账户,使用 XCode 4 创建一个使用本地 Git 仓库的工程,关闭该工程。
2,进入到该工程的目录下,使用如下命令初始化远程仓库。
git remote add origin git@10.1.4.211:repositories/hello-world.git
git push -u origin master
git push -u origin master
3,这样我们就可以在该目录下使用 git 命令来操作了,当然也可以使用可视化工具(OpenInGitGui,使用方法:在 Git 目录双击该工具打开即可)。
4,打开该 XCode 工程,修改代码,然后使用 File -> Source Control -> Commit(提交到本地),然后使用 Push 提交到服务器。在第一次 Push 的时候会提示权限受限,没有关系,try again,就能成功了。
5,我们可以在别的地方新建一个空目录来检验仓库是否有内容,以及刚刚的修改。在 Documents (或别的地方)下新建一个空目录 test,进入该目录:
cd test
git clone git@10.1.4.211:repositories/hello-world.git
这样我们就能得到刚刚修改过的工程了。git clone git@10.1.4.211:repositories/hello-world.git
注1:为已有工程创建 git 仓库,我们只需要进入到该工程目录下使用如下命令即可。
|
发表评论
-
Mac技巧之用终端命令行查看苹果电脑显示器液晶面板型号的方法
2013-04-03 12:11 2857http://www.mac52ipod.cn/post/c ... -
Apple 在中国的维修和保修政策
2013-04-03 11:52 1372致尊敬的中国消费者 ... -
教你如何制作OS X Lion启动U盘与使用U盘安装系统
2013-04-03 10:13 2704From: http://www.weiphone.com/ ... -
Mac版酷狗在线播放器
2012-12-10 22:25 1767(需要安装adobe flash, 下载地址:http://g ... -
Mac和Windows系统中网页字体显示方案对比
2012-11-27 12:19 2554From: http://www.websbook.com/a ... -
Git “Command not found” Error in Mountain Lion [Quickfix]
2012-10-29 09:28 1542From: http://www.tuicool.com/ar ... -
Macbook Pro 升级 SSD 固态硬盘+数据转移完全教程
2012-10-24 09:24 1908From: http://www.guomii.com/po ... -
Photoshop CS6 MAC 中文版
2012-08-28 14:28 1788Photoshop CS6 MAC 中文版破解版 ... -
MacBook Pro拆机换内存
2012-08-15 22:33 2088From: http://geekwall.org/archi ... -
Mac技巧之苹果电脑Mac OS X系统下设置开机自动启动运行软件(开机启动项)的方法
2012-08-15 21:21 2080From: http://www.mac52ipod.cn/p ... -
Mac 下配置 Git 服务器
2012-08-15 10:54 1206From: http://www.cppblog.com/ke ... -
VMware Fusion 4.1.3
2012-08-11 13:27 1152From: http://soft.macx.cn/soft ... -
git使用详细介绍
2012-08-10 16:32 1413From: http://blog.csdn.net/gemm ... -
mac最简单的隐藏文件方法
2012-08-10 15:08 3655From: http://www.startos.com/ma ... -
UML tools for mac
2012-08-08 13:40 1529BOUML:http://www.bouml.fr/ ... -
Mac 技巧——让Mac轻松访问Windows网络共享
2012-07-30 09:15 1030From: http://www.cnblogs.c ... -
Mac OS X安装Git
2012-07-22 19:57 1185From: http://www.linuxidc.com/L ... -
解决office for mac 的word显示字体乱码问题
2012-07-20 10:27 12922From: http://hi.baidu.com/innuy ... -
photoshop cs5 for mac破解
2012-06-26 12:56 1http://zhidao.baidu.com/questio ... -
快速显示、恢复隐藏文件
2012-06-18 11:20 1230在Mac OS X中,文件名前有一个点“.”就可以隐藏文件。你 ...
相关推荐
事实上,这种做法再团队和软件公司中相当常见:每个人负责项目的一部分,最终所有部分被整合到一起形成最终产品。对于个人开发者来说,版本控制系统并不是必需的,但是我们仍然强烈推荐开发者使用它,因为它可以使...
在XCode 4中,苹果引入了统一的界面设计,将项目导航、编辑器、调试器和工具面板整合在一个窗口内,使得开发者可以更集中地进行代码编写和调试。这一改变简化了工作流程,减少了在多个窗口之间切换的需求。 1. **源...
1. **统一的用户界面**:Xcode 4将代码编辑器、调试器、项目管理等功能整合在一个统一的窗口中,大大简化了开发流程。 2. **增强的源代码编辑器**:编辑器支持更丰富的语法高亮显示,自动完成功能也得到了加强,使...
Xcode 14.2进一步整合了App Store Connect的功能,开发者可以直接在Xcode内查看应用状态、管理版本发布和反馈,无需频繁切换到网页版App Store Connect。 ### 8. 真机调试与测试 Xcode 14.2在真机调试方面表现出色...
10. **源代码版本控制**:Xcode 6 Beta对Git的支持也有所增强,包括更方便的分支管理和合并操作,使团队协作更为高效。 总之,Xcode 6 Beta版是一个充满创新和前瞻性的开发工具,它不仅为开发者提供了新的编程语言...
7. **CloudKit集成**:开发者可以利用Xcode 6轻松地将Apple的CloudKit服务整合到应用中,实现数据的云存储和同步。 8. **HealthKit和HomeKit**:Xcode 6支持开发针对HealthKit和HomeKit的第三方应用,分别用于健康...
31.3.4 Gitweb 整合/ 449 31.4 创建新版本库/ 449 31.5 轻量级管理的 Git 服务/ 450 第32章 Gerrit 代码审核服务器/ 452 32.1 Gerrit 的实现原理/ 452 32.2 架设 Gerrit 的服务器/ 456 32.3 Gerrit 的配置文件/ 461 ...
### Xcode 4 Unleashed:深入探索iOS与macOS应用开发 #### 一、引言 《Xcode 4 Unleashed》是一本专为iOS和macOS开发者准备的全面指南,它不仅覆盖了Xcode 4的基础操作,还深入探讨了其高级功能和隐藏技巧,帮助...
Xcode 4.4 DP可能会对源代码控制功能进行升级,更好地支持Git等版本控制系统,简化代码版本管理和协作。 **8. iCloud 整合** 对于开发者来说,将应用与iCloud整合是常见的需求。Xcode 4.4 DP可能会提供更顺畅的...
在调试工具方面,XCODE6引入了Source Control功能,支持Git版本控制,帮助开发者管理代码的不同版本,协同工作更为便捷。此外,强大的Alcatraz插件管理系统让开发者可以自定义并安装各种第三方插件,扩展XCODE的功能...
总之,"Xcode 里快速搜索 Google, StackOverflow 插件"是一个旨在提升Xcode开发体验的实用工具,它通过整合流行的在线开发资源,使开发者能更便捷地解决问题,推动项目的顺利进行。对于任何使用Xcode的iOS或macOS...
4. **分支与合并**:使用`git checkout -b develop`创建并切换到新分支,`git merge (--no-ff)`合并分支,`git diff`比较不同分支,`git rebase -i`交互式地整合多个提交。 5. **回滚历史**:使用`git reset commit...
将Maven与Xcode整合,开发者可以在更熟悉的Maven环境中处理Xcode项目,使得跨平台的持续集成和自动化构建变得更加方便。 【描述】"labeled-tostring.zip" 提及的是一个Scala编程语言中的特性,即覆盖默认的`...
- **版本控制集成**:有的插件可以更好地整合Git等版本控制系统,方便提交、回滚操作。 2. **Xcode插件安装** - **Alcatraz**:过去,Xcode插件的安装主要依赖于Alcatraz,一个Xcode的包管理器,它允许用户通过...
Git的合并功能使得团队成员可以方便地整合各自的改动。此外,Git还提供了强大的版本回溯能力,允许开发者查看和恢复过去的代码状态。 结合CMake和Git,开发者可以构建一个高效且灵活的开发流程:CMake负责跨平台的...
4. **更强大的Siri**:Siri在iOS 12中变得更加智能,可以学习用户习惯,提供更加个性化的建议,并且与更多第三方应用进行了整合。 5. **群组FaceTime**:最多支持32人同时进行视频通话。 6. **照片应用增强**:...
4. **测试与调试**:创建新项目后,通过Xcode进行编译和运行,检查Monolith应用是否按预期工作,同时解决可能出现的构建或运行时错误。 5. **持续更新**:关注Monolith-Xcode-Template的更新,适时拉取最新的代码,...
git clone https://github.com/kattrali/cocoapods-xcode-plugin.git cd cocoapods-xcode-plugin rake install ``` 安装完成后,重启Xcode,插件就会生效。现在,你可以看到Xcode的菜单栏多了CocoaPods相关的选项,...
在移动设备领域,手机与PDA(个人数字助手)程序设计是至关重要的组成部分,尤其对于开发者来说,掌握整合型开发工具能大大提高效率和便捷性。本文将深入探讨手机与PDA程序设计的基础知识,以及如何利用整合型开发...