Chcę użyć nowej struktury katalogów Symfony 3, ale nie widzę pytania?
Pytanie Would you like to use Symfony 3 directory structure?
zostało usunięte podczas tworzenia nowego projektu z powodu zamieszania, jakie spowodowało. Możesz wymusić użycie struktury katalogów, wykonując następujące czynności:
Jeśli wolisz nową strukturę, możesz dodać zmienną środowiskową SENSIOLABS_ENABLE_NEW_DIRECTORY_STRUCTURE
do swojej .bashrc
lub .bash_profile
podobnej:
Niech wszystkie przyszłe projekty wymagają nowej struktury
export SENSIOLABS_ENABLE_NEW_DIRECTORY_STRUCTURE=true
Zrób TYLKO TEN projekt z pytaniem, czy chcemy użyć nowej struktury.
Jeśli chcesz go tylko dla konkretnego projektu (jednorazowego), możesz użyć:
SENSIOLABS_ENABLE_NEW_DIRECTORY_STRUCTURE=true composer create-project symfony/framework-standard-edition path/ "2.5.*"
Jeśli zmienna środowiskowa SENSIOLABS_ENABLE_NEW_DIRECTORY_STRUCTURE
jest ustawiona i ustawiona na true
, composer
zapyta, czy chcesz użyć nowej struktury katalogów.
Kontynuuj czytanie poniżej, aby zapoznać się ze wszystkimi zmianami między strukturą katalogów Symfony2
i Symfony3
.
Jaka jest nowa struktura katalogów w Symfony 3?
(i jak to wpływa na mnie i mój przepływ pracy)
Przyjrzałem się temu, tworząc 2 projekty, jeden ze symfony-2.5.0
strukturą katalogów, drugi z symfony-3
(tylko zmiana struktury katalogów).
Zrób jeden z każdego projektu:
$ composer create-project symfony/framework-standard-edition symfony-2.5.0/ 2.5.0
$ composer create-project symfony/framework-standard-edition symfony-3/ 2.5.0
Więc teraz mamy 2 różne katalogi, które chcemy porównać.
Znajdź diff
różnicą
Możesz diff
między 2 katalogami za pomocą:
$ diff -rq symfony-2.5.0/ symfony-3/
Pokazuje pliki, które różnią się w 2 wersjach.
Podział diff
Oto zestawienie wszystkiego w różnicy.
.gitignore
.travis.yml
composer.json
vendor/autoload.php
vendor/composer/autoload_real.php
web/app.php
web/app_dev.php
app/cache | var/cache
app/logs | var/log
app/bootstrap.php.cache | var/bootstrap.php.cache
app/console | bin/console
app/phpunit.xml.dist | phpunit.xml.dist
bin/symfony_requirements
Korzyści ze struktury katalogów Symfony 3
Nowa struktura katalogów ma wiele zalet, z których wszystkie są niewielkie i mogą wymagać minimalnych zmian w przepływie pracy.
PHPUnit
phpunit
można uruchomić z katalogu głównego projektu bez konieczności jawnego określania ścieżki do pliku konfiguracyjnego.
phpunit -c app/phpunit.xml
phpunit
Binarne pliki wykonywalne
Wszystkie binarne pliki wykonywalne są teraz zlokalizowane w jednym miejscu - bin
katalogu (podobnie jak w systemie operacyjnym typu unix) .
PATH="./bin:$PATH"
console
symfony_requirements
doctrine
bin/console
bin/symfony_requirements
bin/doctrine
Nowy /var
katalog
Nowy /var
katalog zawiera pliki, do których system zapisuje dane w trakcie swojej pracy (podobnie jak w systemie unixopodobnym) .
Ułatwia to także dodawanie uprawnień, /var
serwer WWW powinien mieć możliwość zapisu w całym katalogu. Możesz śledzić przewodnik Symfony2 do ustawiania uprawnień (zastępując app/cache
&& app/logs
z var
), wszelkie inne pliki, które chcesz napisać lokalnie może również znajdować się tutaj.
var/bootstrap.php.cache
var/cache
var/logs
Sprawdzenie wymagań Symfony
Uruchomienie symfony_requirements
spowoduje wyświetlenie obowiązkowych i opcjonalnych konfiguracji środowiska.
na przykład:
********************************
* 'Symfony requirements check' *
********************************
* Configuration file used by PHP: /usr/local/php5/lib/php.ini
** Mandatory requirements **
'
OK PHP version must be at least 5.3.3 (5.5.11 installed)
OK PHP version must not be 5.3.16 as Symfony wont work properly with it
OK Vendor libraries must be installed
OK var/cache/ directory must be writable
OK var/logs/ directory must be writable
OK date.timezone setting must be set
OK Configured default timezone "Europe/London" must be supported by your installation of PHP
OK json_encode() must be available
OK session_start() must be available
OK ctype_alpha() must be available
OK token_get_all() must be available
OK simplexml_import_dom() must be available
OK APC version must be at least 3.1.13 when using PHP 5.4
OK detect_unicode must be disabled in php.ini
OK xdebug.show_exception_trace must be disabled in php.ini
OK xdebug.scream must be disabled in php.ini
OK PCRE extension must be available
'
** Optional recommendations **
'
OK xdebug.max_nesting_level should be above 100 in php.ini
OK Requirements file should be up-to-date
OK You should use at least PHP 5.3.4 due to PHP bug #52083 in earlier versions
OK When using annotations you should have at least PHP 5.3.8 due to PHP bug #55156
OK You should not use PHP 5.4.0 due to the PHP bug #61453
OK When using the logout handler from the Symfony Security Component, you should have at least PHP 5.4.11 due to PHP bug #63379 (as a workaround, you can also set invalidate_session to false in the security logout handler configuration)
OK You should use PHP 5.3.18+ or PHP 5.4.8+ to always get nice error messages for fatal errors in the development environment due to PHP bug #61767/#60909
OK PCRE extension should be at least version 8.0 (8.34 installed)
OK PHP-XML module should be installed
OK mb_strlen() should be available
OK iconv() should be available
OK utf8_decode() should be available
OK posix_isatty() should be available
OK intl extension should be available
OK intl extension should be correctly configured
OK intl ICU version should be at least 4+
OK a PHP accelerator should be installed
OK short_open_tag should be disabled in php.ini
OK magic_quotes_gpc should be disabled in php.ini
OK register_globals should be disabled in php.ini
OK session.auto_start should be disabled in php.ini
OK PDO should be installed
OK PDO should have some drivers installed (currently available: mysql, sqlite, dblib, pgsql)
'
Wniosek
Wygląda na to, że Sensio Labs dobrze posprzątał, wszystkie powyższe zmiany mają sens, powinny być łatwe do wdrożenia podczas aktualizacji z 2.5
do 3.x
, to prawdopodobnie będzie najmniejszy z twoich problemów!
Przeczytaj dokumentację
Symfony 2.x => 3.0 Upgrade docs tutaj
Symfony 3.0 Architektura
Data wydania Symfony 3
Spojrzenie na proces wydania wydaje się dalekie (warte przeczytania) :
http://symfony.com/doc/current/contributing/community/releases.html
(źródło: symfony.com )