DevProTalk

DevProTalk (http://www.devprotalk.com/index.php)
-   PHP (http://www.devprotalk.com/forumdisplay.php?f=9)
-   -   Razvoj i deployment PHP aplikacija (http://www.devprotalk.com/showthread.php?t=6111)

zoro 31. 08. 2008. 18:45

Razvoj i deployment PHP aplikacija
 
Ovih dana se dosta bavimo problemom organizacije razvoja i deploymenta nasih PHP aplikacija, i trudimo se da sve sto vise automatizujemo i eliminisemo korake koji generisu greske.
Osnovna postavka koju smo isplanirali je otprilike standardna:
Od razvojne verzije na SVN-u generisemo release branch, koji prvo ide na lokalni test server, a zatim na web.

Bilo bi jako lepo kada bi release verzija sa SVN-a mogla automatski preko FTP-a da se prebaci na web , i jos da se pri tom prenose samo razlike a ne kompletan kod.

Zanima me da li neko ima resenje, iskustva ili savet u vezi sa ovime?

Hvala.

merjadok 31. 08. 2008. 20:06

Pogledajte Phing, mislim da bi moglo da pomogne.

-- Napomena: nisam koristio Phing, ali pošto je baziran na Antu (sa kojim imam dosta iskustva) pretpostavljam da je OK.

nn.nn 31. 08. 2008. 21:19

Citat:

Originalno napisao zoro (Napišite 59715)
Bilo bi jako lepo kada bi release verzija sa SVN-a mogla automatski preko FTP-a da se prebaci na web , i jos da se pri tom prenose samo razlike a ne kompletan kod.

"Skript" jezici su kao izmišljeni za ovo. Ovako, otprilike, bi se to moglo uraditi u Rubiju:

Kôd:

#!/usr/bin/ruby

require 'net/ftp'

razlike = `svn diff -x -w --summarize -r 8750:8759`

ftp = Net::FTP.new('moj.server.tld')
ftp.login('username', 'password')
ftp.chdir('neki/dir/na/serveru')

razlike.each do |linija|
  status, fajl = /(.)\s*(.*)/.match(linija)[1,2]
  begin
    case status
      when 'M'
        ftp.put fajl
      when 'D'
        ftp.delete File.basename fajl
    end
  rescue
    puts "Huston, we have a problem!"
    raise
  end
end

ftp.close

Npr, ne bi bilo loše ako bi se obradili i ostali statusi. Informaciju o postojećim statusima daje komanda:
Kôd:

$ svn help status

f13o 31. 08. 2008. 23:12

rsync
 
Citat:

Originalno napisao zoro (Napišite 59715)
Bilo bi jako lepo kada bi release verzija sa SVN-a mogla automatski preko FTP-a da se prebaci na web , i jos da se pri tom prenose samo razlike a ne kompletan kod.

Jedno od rešenja predstavlja dobri stari rsync:
Kôd:

rsync -Ravz source remoteuser@remotehost:/path
to će da ti prebaci samo razlike između source i remote foldera. Obrati pažnju na završni / (slash) kod source foldera.

Phing je dobar za nešto komplikovanije transformacije na dev-test-live putanji.

Zanimljiva je integracija oba ova alata:
http://phpimpact.wordpress.com/2008/...d-directories/
koja dodaje na phing FileSyncTask pa možeš da u sklopu svoje phing arhitekture da definišeš i rsync task. Stvar je dosta mlada, ali zanimljiva.

Nadam se da sam bio od pomoći :)

zoro 01. 09. 2008. 20:34

Ljudi hvala svima na pomoci, nesto od ovoga cu sigurno napraviti pa cu javiti sta i kako radi.

zoro 05. 09. 2008. 00:44

Vidim da je tema postala 'vazna' pa hajde da je updateujem :)

Definitivno cu probati sa phing-om

Export sa svn-a
http://phing.info/docs/guide/current...#SvnExportTask

Tu je i podrska za ftp upload
http://phing.info/trac/ticket/15

Razlika izmedju prethodnog i aktuelnog release-a se moze naci sa
svn diff --summarize [path1] [path2] ili slicno kao sto je rekao nn.nn
i recimo da se poziva iz nekog phing task-a. (ovo uz pretpostavku da se verzija koja je na web-u takodje nalazi i na svn-u i tako se nalazi changeset)

Kreiranje ili update baze:
http://phing.info/docs/guide/current...l#DbDeployTask

I na kraju testiranje
http://phing.info/docs/guide/current...l#PHPUnit2Task

A kome sve ovo proradi moze u penziju :)

f13o 05. 09. 2008. 12:21

А кад смо већ код тестирања, занимљив систем се може направити и са phpUnderControl и CruiseControl.

Овде је поента на фреквентном тестирању, где у сарадњи са phpCodeSniffer, phpDocumentor може да се направи један леп систем где је "само" потребно научити програмере да пишу тестове, често комитују (хм, српска реч? :)) и да неко гледа у коначне табеле и графиконе :)...

Можда мало ван теме, али има тема у наслову "развој" :)

Успут, phing може да се корисити и за трансформације фајлова пре постављања на продукциону верзију апликације - пример - рецимо компресија JavaScript библиотека, преписке конфигурационих фајлова у односу на тест окружење и слично...

cvele 05. 09. 2008. 13:57

ja za to koristim rsync...

Dev -> SVN -> Latest Stable -> rsync na web server

zoro 06. 09. 2008. 01:00

Citat:

Originalno napisao cvele (Napišite 60098)
ja za to koristim rsync...

Dev -> SVN -> Latest Stable -> rsync na web server

Da, kratko jasno i zavrsava posao.

Meni se mnogo svidja ideja o automatizaciji konfiguracije, updatea baze, testiranja, a mozda i lokalni test deployment. Sve u jednom build procesu, ne moze nista da se zaboravi/promakne. Cini mi se da phing sve ovo resava bez problema.
Mislim da je za razvoj vecih sajtova, koji se cesto upgrade-uju, ili odrzavanje veceg broja sajtova zasnovanih na istom engine-u ovo spas i da stedi mnogo vremena. Pocinjem da eksperimentisem sa phing-om pa mozda skockamo neki DevProBuild.xml :)

Ilija Studen 06. 09. 2008. 03:10

activeCollab projekat je sastavljen iz 6 blokova - app, framework, instanca, installer, upgrader, docs itd. Svaki ima svoj svoj folder sa tagovima, branchevima i trunkom u repositoriju. Da bi se od svih tih blokova napravio instalacioni paket (blokovi složili na svoje mesto, sredila DB konstrukcija na osnovu includeovanih modula, složili inicijalni podaci itd) koristimo jednostavnu build skriptu. Da je nema svaki build bi bio mučenje podložno greškama.

U pitanju je jednostavan PHP skript koji izvršava niz shell komandi. Sve to lepo radi bez potrebe za punokrvnim build alatom. Kao što nn.nn reče, za ove stvari skript jezici dobro dođu, a PHP CLI nije za baciti...


Vreme je GMT +2. Trenutno vreme je 17:47.

Powered by vBulletin® Verzija 3.6.8
Copyright ©2000 - 2017, Jelsoft Enterprises Ltd.
Copyright © DevProTalk. All Rights Reserved.

Mišljenja, saveti, izjave, ponude ili druge informacije ili sadržaji nastali na Sajtu su vlasništvo onoga ko ih je kreirao, a ne DevProTalk.com, tako da ne morate da se oslanjate na njih.
Autori poruka su jedini odgovorni za ovakve sadržaje. DevProTalk.com ne garantuje tačnost, kompletnost ili upotrebnu vrednost informacija, stavova, saveta ili datih izjava. Ne postoje uslovi pod kojima bi mi bili odgovorni za štetu ili gubitak koji je posledica bilo čijeg oslanjanja na nepouzdane informacije, ili bilo kakve informacije nastale kroz komunikaciju između registrovanih članova.
Web sajt može sadržavati linkove na druge web sajtove na Internetu ili neke druge sadržaje. Ne kontrolišemo niti podržavamo te druge web sajtove, niti smo pregledali bilo kakve sadržaje na takvim sajtovima. Mi nećemo biti odgovorni za legalnost, tačnost ili prikladnost bilo kog sadržaja, oglasa, proizvoda, usluga ili informacije lociranim na ili distribuiranih kroz druge web sajtove, niti za bilo kakvu štetu nastalu kao posledica takvih informacija. DevProTalk.com drži i čuva druga prava vlasništva na web sajtu. Web sajt sadrže materijale zaštićene copyright-om, zaštitne znakove i druge informacije o pravu vlasništva ili softver. Članovi mogu poslatu informacije zaštićene pravima vlasništva njihovih nosilaca i ona ostaju zaštićena bez obzira da li su oni koji prenose te informacije to naveli ili ne. Osim informacija koje su u javnom vlasništvu ili za koje dobijete dozvolu, nemate pravo da kopirate, modifikujete ili na bilo koji način menjate, objavljujete, prenosite, distribuirate, izvršavate, prikazujete ili prodajte bilo koju informaciju zaštićenu pravima vlasništva. Slanjem informacija ili sadržaja na bilo koji deo DevProTalk.com, Vi automatski dozvoljavate i predstavljate garanciju da imate pravo da dozvolite DevProTalk.com ili članovima DevProTalk.com bespovratnu, kontinualnu, neograničenu, globalnu dozvolu da koriste, kopiraju, izvršavaju, prikazuju i distribuiraju takve informacije i sadržaje i da iz takvih sadžaja koriste bilo koji deo u bilo koje svrhe, kao i pravo i dozvolu da koriste gore navedene sadržaje. Svi zaštitni znakovi (trademarks), logotipi, oznake usluga, firme ili imena proizvoda koji se pominju na ovom web sajtu su vlasništvo kojim raspolažu njihovi vlasnici.