====== Пример установки каркасного приложения Limb3 ====== Установка (подготовка кода к работе) Limb3 несложна. Здесь и далее речь пойдет о создании проектов на базе пакета [[limb3:ru:packages:web_app|WEB_APP]], т.к. самый частый случай использования Limb3, в роли веб-приложения. ===== 1. Исходный код скелета ===== Итак, чтобы подготовить ваш новый проект к работе, создайте где-нибудь на диске директорию с названием вашего проекта, например **/var/www/limbapp**. Скопируйте содержимое папки **limb/web_app/skel** в выбранную директорию проекта. Скопируйте исходный код limb в папку **/var/www/limbapp/lib/limb**. ===== 2. Права ===== Задайте права на запись директории /var/www/limbapp/var для вебсервера, проще всего это сделать так: $ chmod 777 /var/www/limbapp/var Если этой папки нет, то создайте ее. ===== 3. Настройка веб-сервера ===== ==== 3.1 Apache ==== Осталось настроить виртуальный хост, например так: * Создайте виртуальный хост limbapp в настройках Apache(например, в httpd.conf) примерно такого содержания: DocumentRoot /var/www/limbapp/www/ ServerName limbapp ErrorLog logs/limbapp-error_log CustomLog logs/limbapp-access_log common * Пропишите ip адрес хоста "limbapp" в файле /etc/hosts(или %WINDOWS%/system32/drivers/etc/hosts в Windows): 127.0.0.1 limbapp * Перезапустите Apache ==== 3.2 Nginx + php-fpm ==== Инструкция по установке php-fpm доступна в официальной wiki - http://php-fpm.org/wiki/RU:Documentation . Настройки nginx: server { listen 80; server_name limbapp; index index.php; root /var/www/limbapp/www; location / { if (!-e $request_filename) { rewrite ^(.*)$ /index.php last; } } location ~ \.php$ { fastcgi_pass 127.0.0.1:9000; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; fastcgi_param QUERY_STRING $query_string; fastcgi_param REQUEST_METHOD $request_method; fastcgi_param CONTENT_TYPE $content_type; fastcgi_param CONTENT_LENGTH $content_length; fastcgi_param SCRIPT_NAME $fastcgi_script_name; fastcgi_param REQUEST_URI $request_uri; fastcgi_param DOCUMENT_URI $document_uri; fastcgi_param DOCUMENT_ROOT $document_root; fastcgi_param SERVER_PROTOCOL $server_protocol; fastcgi_param GATEWAY_INTERFACE CGI/1.1; fastcgi_param SERVER_SOFTWARE nginx/$nginx_version; fastcgi_param REMOTE_ADDR $remote_addr; fastcgi_param REMOTE_PORT $remote_port; fastcgi_param SERVER_ADDR $server_addr; fastcgi_param SERVER_PORT $server_port; fastcgi_param SERVER_NAME $server_name; fastcgi_param REDIRECT_STATUS 200; } } ===== 4. Shared-файлы ===== В некоторые пакеты (CMS, WYSIWYG, JS, CALENDAR) входят файлы, которые должны быть доступны из веба. Эти файлы лежат в папках **shared**, соответствующих пакетов. Например, файл **limb/cms/shared/js/app.js** должен быть доступен по адресу http://limbapp/shared/cms/js/app.js. Поддержку shared-папок можно реализовать, как минимум тремя способами: * простым копированием содержимого * символическими ссылками * настройками веб-сервера ===== 5. Часто используемые классы ===== Модифицируем немного файл setup.php: [...] //Подключим наиболее популярные файлы lmb_require('limb/web_app/src/controller/lmbController.class.php'); lmb_require('limb/active_record/src/lmbActiveRecord.class.php'); lmbController и lmbActiveRecord самые часто используемые классы в нашем приложении. lmb_require() использует отложенную загрузку классов, так что сильного влияния на производительность эти две строки не будут иметь.