2

我正在使用 FuelPHP 框架与另外两个团队成员一起开发一个网站。我想使用 git 来维护项目,但是我在处理配置时遇到了一些麻烦。当我使用oil安装 FuelPHP 时,它会安装主框架以及来自 github 的几个子模块。文档根目录中的.git/config文件如下所示:

[core]
        repositoryformatversion = 0
        filemode = true
        bare = false
        logallrefupdates = true
        ignorecase = true
[remote "origin"]
        fetch = +refs/heads/*:refs/remotes/origin/*
        url = git://github.com/fuel/fuel.git
[branch "1.4/master"]
        remote = origin
        merge = refs/heads/1.4/master
[submodule "docs"]
        url = git://github.com/fuel/docs.git
[submodule "fuel/core"]
        url = git://github.com/fuel/core.git
[submodule "fuel/packages/auth"]
        url = git://github.com/fuel/auth.git
[submodule "fuel/packages/email"]
        url = git://github.com/fuel/email.git
[submodule "fuel/packages/oil"]
        url = git://github.com/fuel/oil.git
[submodule "fuel/packages/orm"]
        url = git://github.com/fuel/orm.git
[submodule "fuel/packages/parser"]
        url = git://github.com/fuel/parser.git

我在远程服务器上有一个裸存储库设置,我想在其中维护这个项目。我希望能够从 github 为 FuelPHP 及其子模块提取更新,同时还能够将任何更改推送到裸存储库,以便我的团队成员和生产服务器可以从中提取。到目前为止,我遇到了一堵砖墙。

这是我到目前为止所做的:

在服务器上:

$ mkdir websitename.git
$ cd websitename.git
$ git init --bare

在我的本地机器上:

$ curl get.fuelphp.com/oil | sh
$ oil create websitename
$ cd websitename/
$ git remote add reponame ssh://git@example.com:2222/httpd/www/websitename.git
$ git push reponame 1.4/master

我得到这个回应:

Counting objects: 14422, done.
Delta compression using up to 2 threads.
Compressing objects: 100% (4375/4375), done.
Writing objects: 100% (14422/14422), 2.20 MiB | 3.82 MiB/s, done.
Total 14422 (delta 9816), reused 14410 (delta 9810)
To ssh://haroldbr@haroldinc.com:2222/home/haroldbr/public_html/crude.git
 * [new branch]      1.4/master -> 1.4/master

然后,再次在服务器上:

$ git clone -l --no-hardlinks /httpd/www/websitename.git /httpd/www/websitename

这给了我这个错误:

Cloning into 'websitename'...
done.
warning: remote HEAD refers to nonexistent ref, unable to checkout.

显然我有一个配置问题,但我不知道它是什么。我希望能够使用git. 我设想它的工作方式如下:

在我的本地机器上:

$ git pull origin 1.4/master
$ git push reponame --all

在服务器上:

$ cd websitename/
$ git pull

在一个完美的世界中,这将从 github 拉取 FuelPHP 的所有更新及其包,并推送所有这些更新,以及对裸存储库中app/public/裸存储库中文件的任何更改。我想要做的甚至可能吗?我是否需要在其中设置存储库app/public/单独维护它们?我无法从裸仓库克隆的配置有什么问题?

4

2 回答 2

2

这里有一个关于如何使用 git 维护 FuelPHP 网站项目的截屏视频:http://blip.tv/fuelphp/creating-a-fuelphp-application-repository-5688973 但它不包括推送到裸存储库.

假设您已经在 ssh://example.com/path/to/project.git 设置了一个新的裸存储库,您可以按照以下步骤设置您的项目。从您的本地机器:

git clone -b 1.4/master --recursive git://github.com/fuel/fuel.git /path/to/project
cd /path/to/project
rm -R .git
rm .gitmodules
rm -R docs
git init
git submodule add git://github.com/fuel/core.git fuel/core
git submodule add git://github.com/fuel/auth.git fuel/packages/auth
git submodule add git://github.com/fuel/email.git fuel/packages/email
git submodule add git://github.com/fuel/oil.git fuel/packages/oil
git submodule add git://github.com/fuel/orm.git fuel/packages/orm
git submodule add git://github.com/fuel/parser.git fuel/packages/parser
git add .
git commit -m "Initial commit"
git remote add origin master ssh://example.com/path/to/project.git
git push origin master

然后,您可以转到生产服务器并从远程存储库中递归克隆以获取整个项目:

git clone --recursive ssh://example.com/path/to/project.git /path/to/production

然后,您将能够跟踪项目的更改,同时保持以下能力:

git submodule update --recursive

这将使您了解最新的 FuelPHP 软件包。

于 2012-12-19T20:09:42.830 回答
0

您已成功克隆,但您只需要检查您想要的分支。由于您没有在裸仓库中定义 head,因此它会向您发出警告。

此外,git clone --recursive应该完成一次,这也将获得您的子模块。从那时起,您可以执行 agit pull后跟 agit submodule update

于 2012-12-14T20:28:06.347 回答