我们的小公司有 3 个人,每个人都有一个本地主机网络服务器,大多数项目(以前的和当前的)都在一个 PC 网络共享磁盘上。我们有虚拟服务器,我们的一些客户站点和我们的站点都在其中。
我们的标准工作流程是:
Coder PC → Programmer localhost → dev domain (client.company.com)
↓
live version (client.com)
经常发生的情况是,有两三个人同时从事同一个项目 - 一个在开发版本上,两个在本地主机上。
完成后,我们会尝试在开发版本上同步文件,最好不要弄乱(感谢 ILMV:])任何文件,这 **knock knock* * 并不经常发生。
然后我们中的一个人在实时网络服务器上部署开发版本。
我们正在寻找一种在更新网站时简化此工作流程的方法 - 理想情况下可能是某种差异 uploader 或 VCS(Git/SVN/VCS/...),但我们不完全确定从哪里开始或以何种方式开始将是理想的,因此我问你,stackoverflowers 的同胞,了解你在网站/应用程序部署和推荐工作流程方面的经验。
我们可能还需要在过程中使用 Mac,所以如果这不会成为问题,那就更好了。
谢谢
编辑:其中一个关键部分是在任何工作更新后将网站从开发状态转移到实时状态。 编辑:如果没有其他人出现,我将检查 MaxVt 的答案 :)
最佳答案
这是一个复杂的问题,但一般而言,您需要进行三项重大改进才能改进您的流程。
使用版本控制
如果项目在共享磁盘上,我假设只有一个文件夹包含每个项目的当前状态。开发人员很容易覆盖彼此的更改,没有历史记录,并且您无法确定项目是否处于一致状态或当前是否存在问题。
选择一个版本系统并开始使用它。哪一个(免费的 - SVN 可以并且更“集中”,git 或 mercurial 很棒并且允许更大的灵 active )并不重要,但更重要的是任何更改,无论多么小,总是通过版本控制。
简化升级、部署和回滚
现在可能需要一系列步骤才能从本地主机转移到开发,从开发转移到生产 - 同步文件,将数据库恢复到已知状态,配置特定于服务器的设置......可能有一个文档描述需要做什么,或者可能是部落知识。您的目标应该是开始简化和自动化,实现单个命令或脚本来完成将服务器(本地、开发或生产)同步到源代码管理中的项目修订所需的所有工作。
通过自动化部署,您可以确保所有必要的操作都按正确的顺序完成,即使所有文件都正确但某些配置或命令未运行,您也不会在部署中出现错误,从而破坏站点。
引入测试
您如何知道您刚刚部署的修订版不仅可以正确编译,而且可以按预期工作?对于每个重要的项目,您应该进行测试以验证最重要的功能(登录、添加内容、生成报告等),以确保开发人员所做的更改使网站正常运行。
有专门用于测试网络应用程序的测试框架(想到 Selenium)。研究并应用它们。理想情况下,此测试套件将作为单行部署脚本的一部分运行。
完成这些后,您就已经在拥有有序、可预测且有弹性的开发流程方面取得了长足的进步。您的客户和开发人员会为此感谢您 :)
关于php - 本地/开发/实时部署 - 最佳工作流程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2728316/
很好奇,就使用rubyonrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提
我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-
我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t
我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i
我正在编写一个包含C扩展的gem。通常当我写一个gem时,我会遵循TDD的过程,我会写一个失败的规范,然后处理代码直到它通过,等等......在“ext/mygem/mygem.c”中我的C扩展和在gemspec的“扩展”中配置的有效extconf.rb,如何运行我的规范并仍然加载我的C扩展?当我更改C代码时,我需要采取哪些步骤来重新编译代码?这可能是个愚蠢的问题,但是从我的gem的开发源代码树中输入“bundleinstall”不会构建任何native扩展。当我手动运行rubyext/mygem/extconf.rb时,我确实得到了一个Makefile(在整个项目的根目录中),然后当
我花了三天的时间用头撞墙,试图弄清楚为什么简单的“rake”不能通过我的规范文件。如果您遇到这种情况:任何文件夹路径中都不要有空格!。严重地。事实上,从现在开始,您命名的任何内容都没有空格。这是我的控制台输出:(在/Users/*****/Desktop/LearningRuby/learn_ruby)$rake/Users/*******/Desktop/LearningRuby/learn_ruby/00_hello/hello_spec.rb:116:in`require':cannotloadsuchfile--hello(LoadError) 最佳
关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭8年前。Improvethisquestion在首页我有:汽车:VolvoSaabMercedesAudistatic_pages_spec.rb中的测试代码:it"shouldhavetherightselect"dovisithome_pathit{shouldhave_select('cars',:options=>['volvo','saab','mercedes','audi'])}end响应是rspec./spec/request
在Rails4.0.2中,我使用s3_direct_upload和aws-sdkgems直接为s3存储桶上传文件。在开发环境中它工作正常,但在生产环境中它会抛出如下错误,ActionView::Template::Error(noimplicitconversionofnilintoString)在View中,create_cv_url,:id=>"s3_uploader",:key=>"cv_uploads/{unique_id}/${filename}",:key_starts_with=>"cv_uploads/",:callback_param=>"cv[direct_uplo
我已经在Sinatra上创建了应用程序,它代表了一个简单的API。我想在生产和开发上进行部署。我想在部署时选择,是开发还是生产,一些方法的逻辑应该改变,这取决于部署类型。是否有任何想法,如何完成以及解决此问题的一些示例。例子:我有代码get'/api/test'doreturn"Itisdev"end但是在部署到生产环境之后我想在运行/api/test之后看到ItisPROD如何实现? 最佳答案 根据SinatraDocumentation:EnvironmentscanbesetthroughtheRACK_ENVenvironm
我是Google云的新手,我正在尝试对其进行首次部署。我的第一个部署是RubyonRails项目。我基本上是在关注thisguideinthegoogleclouddocumentation.唯一的区别是我使用的是我自己的项目,而不是他们提供的“helloworld”项目。这是我的app.yaml文件runtime:customvm:trueentrypoint:bundleexecrackup-p8080-Eproductionconfig.ruresources:cpu:0.5memory_gb:1.3disk_size_gb:10当我转到我的项目目录并运行gcloudprevie