lighttpd (Русский)
lighttpd - веб-сервер, разрабатываемый с расчётом на быстроту и защищённость, а также соответствие стандартам. В lighttpd есть поддержка сжатия отдаваемого содержимого «на лету», HTTP-аутентификации, перезаписи URL, SSL и автоматической балансировки нагрузки (нагрузка может автоматически распределяться по нескольким запущенным серверам lighttpd). Веб-сервер также поддерживает интерфейсы CGI, SCGI, FastCGI.
Установка
Установите пакет lighttpd.
Настройка
Базовая установка
Настройки lighttpd находятся в файле /etc/lighttpd/lighttpd.conf. Настройки по умолчанию позволяют проверить работоспособность сервера.
Проверить правильность настроек и выявить ошибки можно с помощью команды:
$ lighttpd -t -f /etc/lighttpd/lighttpd.conf
Также доступна более тщательная проверка:
$ lighttpd -tt -f /etc/lighttpd/lighttpd.conf
По умолчанию в качестве document-root сервера служит директория /srv/http/.
Для проверки установки создайте в ней файл главной страницы:
/srv/http/index.html
Hello world!
Запустите/включите службу lighttpd.service.
Затем откройте в своём браузере адрес http://localhost и вы должны увидеть тестовую страницу.
Примеры конфигурационных файлов вы можете найти в /usr/share/doc/lighttpd/config/.
Настройка журналов
lighttpd может записывать журналы обращений (accesslog) и ошибок (errorlog). Журнал ошибок включен по умолчанию (настраивается опцией server.errorlog). Для включения журнала обращений отредактируйте файл /etc/lighttpd/lighttpd.conf:
server.modules += ( "mod_accesslog", ) accesslog.filename = "/var/log/lighttpd/access.log"
Включение https
- Mozilla предоставляет генератор настроек, который можно использовать в том числе с lighttpd.
- Для проверки корректности настроек можно использовать сервис SSL Server Check от Qualys SSL Labs.
Самоподписанный сертификат
С помощью openssl можно сгенерировать самоподписанный SSL-сертификат.
Создаем директорию для хранения сертификатов:
# mkdir /etc/lighttpd/certs
Генерируем самоподписанный сертификат (пример команды):
# openssl req -x509 -nodes -days 7300 -newkey rsa:2048 -sha256 -keyout /etc/lighttpd/certs/www.example.com.pem -out /etc/lighttpd/certs/www.example.com.pem
Выставляем владельца и нужные права:
# chown http:http /etc/lighttpd/certs/www.example.com.pem # chmod 600 /etc/lighttpd/certs/www.example.com.pem
Теперь нужно включить SSL в настройках lighttpd (в /etc/lighttpd/lighttpd.conf).
server.modules += ( "mod_openssl" )
$SERVER["socket"] == ":443" {
   ssl.engine                  = "enable" 
   ssl.pemfile                 = "/etc/lighttpd/certs/www.example.com.pem" 
}
Подробнее о настройке можно почитать в документации: lighttpd TLS configuration.
Let's Encrypt
Можно использовать сертификаты, полученные от Let's Encrypt.
В файл /etc/lighttpd/lighttpd.conf добавьте следующие строки:
$SERVER["socket"] == ":443" {
    ssl.engine                  = "enable"
    ssl.privkey                 = "/etc/letsencrypt/live/домен/privkey.pem" 
    ssl.pemfile                 = "/etc/letsencrypt/live/домен/fullchain.pem"  
}
Подробнее о настройке можно почитать в документации: bootstrap Let's Encrypt.
Перенаправление HTTP на HTTPS
mod_redirect должен быть включён:
/etc/lighttpd/lighttpd.conf
server.modules += ( "mod_redirect" )
Перенаправляем трафик для домена example.org:
/etc/lighttpd/lighttpd.conf
$SERVER["socket"] == ":80" {
   $HTTP["host"] == "example.org" {
      url.redirect = ( "^/(.*)" => "https://example.org/$1" )
      server.name                 = "example.org" 
   }
}
Чтобы перенаправить все хосты на их https-эквиваленты, используйте следующую конфигурацию сокета 80 вместо приведённой выше:
$SERVER["socket"] == ":80" {
  $HTTP["host"] =~ ".*" {
    url.redirect = (".*" => "https://%0$0")
  }
}
Перенаправляем запросы на HTTPS для части сайта (в примере ниже - /secure):
/etc/lighttpd/lighttpd.conf
$SERVER["socket"] == ":80" {
   $HTTP["url"] =~ "^/secure" {
      url.redirect = ( "^/(.*)" => "https://example.com/$1" )
   }
}
Защита каталога паролем
Обратите внимание, что этот модуль требует установки mariadb-libs. Для аутентификации пользователей необходим passwd-файл, который является lighttpd-эквивалентом системного /etc/passwd. Настройка требует определённого формата и хеширования пароля md5sum, но пользователи могут быстро и легко создать запись, используя в качестве примера следующее:
$ user=foo $ password=b@R102 $ realm='Password Required' $ hash=`echo -n "$user:$realm:$password" | md5sum | cut -b -32` # echo "$user:$realm:$hash" >> /etc/lighttpd/lighttpd.user
Измените /etc/lighttpd/lighttpd.conf, добавив в него строки, включающие защиту каталога:
server.modules = (
   "mod_auth",
 )
auth.backend                = "htdigest"
auth.backend.htdigest.userfile = "/etc/lighttpd/lighttpd.user"
# note this entry is relative to the server.document-root
auth.require = ( "/secret" =>
   (
    "method" => "basic",
    "realm" => "Password Required",
    "require" => "valid-user"
   )
)
/etc/lighttpd/lighttpd.conf, должно совпадать со значением из файла /etc/lighttpd/lighttpd.user, чтобы аутентификация работала.CGI
Скрипты Common Gateway Interface (CGI) работают с lighttpd из коробки, вам просто нужно включить модуль CGI, добавить файл настроек и убедиться, что выбранный вами интерпретатор языка программирования установлен. (например, для python установите пакет python).
Создайте файл /etc/lighttpd/conf.d/cgi.conf и добавьте в него следующее:
/etc/lighttpd/conf.d/cgi.conf
server.modules += ( "mod_cgi" )
 
 cgi.assign                 = ( ".pl"  => "/usr/bin/perl",
                                ".cgi" => "/usr/bin/perl",
                                ".rb"  => "/usr/bin/ruby",
                                ".erb" => "/usr/bin/eruby",
                                ".py"  => "/usr/bin/python",
                                ".php" => "/usr/bin/php-cgi" )
 
 index-file.names           += ( "index.pl",   "default.pl",
                                "index.rb",   "default.rb",
                                "index.erb",  "default.erb",
                                "index.py",   "default.py",
                                "index.php",  "default.php" )
}
Для php-скриптов в /etc/php/php.ini также добавьте:
cgi.fix_pathinfo = 1
Включаем эти настройки в /etc/lighttpd/lighttpd.conf:
/etc/lighttpd/lighttpd.conf
include "conf.d/cgi.conf"
FastCGI
Установите fcgi. Теперь у вас есть lighttpd с поддержкой fcgi. Если это то, что вы хотели, то всё в порядке. Тем, кто хочет использовать Ruby on Rails, PHP или Python, нужно провести дополнительную настройку.
Сперва скопируйте пример настроек /usr/share/doc/lighttpd/config/conf.d/fastcgi.conf в /etc/lighttpd/conf.d
Следующее содержимое нужно добавить в файл конфигурации
/etc/lighttpd/conf.d/fastcgi.conf
server.modules += ( "mod_fastcgi" )
#server.indexfiles += ( "dispatch.fcgi" ) #this is deprecated
index-file.names += ( "dispatch.fcgi" ) #dispatch.fcgi if rails specified
server.error-handler-404   = "/dispatch.fcgi" #too
fastcgi.server = (
    ".fcgi" => (
      "localhost" => ( 
        "socket" => "/run/lighttpd/rails-fastcgi.sock",
        "bin-path" => "/path/to/rails/application/public/dispatch.fcgi"
      )
    )
)
Включаем этот конфиг в /etc/lighttpd/lighttpd.conf строкой
/etc/lighttpd/lighttpd.conf
include "conf.d/fastcgi.conf"
Для PHP и Ruby on Rails смотрите следующие разделы.
PHP
С помощью php-cgi
Установите пакеты php и php-cgi (смотрите также PHP и LAMP).
Проверяем, что php-cgi работает:
$ php-cgi --version
PHP 5.3.8 with Suhosin-Patch (cgi-fcgi) (built: Sep 11 2011 10:04:49) Copyright (c) 1997-2011 The PHP Group Zend Engine v2.3.0, Copyright (c) 1998-2011 Zend Technologies
Если вы увидели похожий вывод, значит всё установлено правильно.
Создайте новый файл настроек:
/etc/lighttpd/conf.d/fastcgi.conf
server.modules += ("mod_fastcgi")
index-file.names += ("index.php")
fastcgi.server = ( 
    # Распределение запросов к этому адресу...
    ".php" => (
        # ... по следующим серверам FastCGI. Строка с именем сервера — это
        # просто метка, которая позволяет идентифицировать сервер в журналах
        "localhost" => ( 
            "bin-path" => "/usr/bin/php-cgi",
            "socket" => "/tmp/php-fastcgi.sock",
            # breaks SCRIPT_FILENAME in a way that PHP can extract PATH_INFO
            # from it 
            "broken-scriptfilename" => "enable",
            # Запуск (max-procs + (max-procs * PHP_FCGI_CHILDREN)) процессов, где
            # max-procs это "watchers", а остальные это "workers". Смотрите:
            # https://redmine.lighttpd.net/projects/1/wiki/frequentlyaskedquestions#How-many-php-CGI-processes-will-lighttpd-spawn
            "max-procs" => "4", # значение по умолчанию
            "bin-environment" => (
                "PHP_FCGI_CHILDREN" => "1" # значение по умолчанию
            )
        )
    )   
)
Включаем этот конфиг в /etc/lighttpd/lighttpd.conf строкой
/etc/lighttpd/lighttpd.conf
include "conf.d/fastcgi.conf"
/usr/share/doc/lighttpd/config/modules.conf.Перезагрузите службу lighttpd.service с новыми настройками (reload).
- Если вы получаете ошибки, подобные этим "No input file found" при попытке получить доступ к вашему php файлу, у этого могут быть разные причины; смотрите этот FAQ.
- Убедитесь, что нет других модулей (например, mod_cgi), которые будут пытаться обрабатывать .php файлы.
С помощью php-fpm
Установите пакет php-fpm и запустите/включите службу php-fpm.service.
/etc/php/php-fpm.conf. Более подробную информацию о php-fpm можно найти на сайте php-fpm. Не забывайте перезапускать php-fpm.service после изменения настроек.В файл /etc/lighttpd/conf.d/fastcgi.conf добавьте:
/etc/lighttpd/conf.d/fastcgi.conf
server.modules += ( "mod_fastcgi" )
index-file.names += ( "index.php" ) 
fastcgi.server = (
    ".php" => (
      "localhost" => ( 
        "socket" => "/run/php-fpm/php-fpm.sock",
        "broken-scriptfilename" => "enable"
      ))
)
)
Аналогично предыдущему описанию включаем этот конфиг в /etc/lighttpd/lighttpd.conf строкой
/etc/lighttpd/lighttpd.conf
include "conf.d/fastcgi.conf"
uWSGI
В файл /etc/lighttpd/lighttpd.conf добавьте
server.modules += ("mod_scgi")
$HTTP["url"] =~ "^/uwsgi/" {
    scgi.protocol = "uwsgi"
    scgi.server   = (
        "/uwsgi/foo" => ((
            "socket"            => "/путь/к/сокету",
            "check-local"       => "disable"
        )),
        "/uwsgi/bar" => ((
            "host"              => "127.0.0.1",
            "port"              => "8080",
            "check-local"       => "disable"
        ))
    )
}
Затем вы можете запустить приложение uwsgi либо как юнит systemd либо напрямую. Здесь руководство от digitalocean о том, как настроить приложение flask с нуля.
Сжатие исходящих данных
Сжатие исходящих данных уменьшает нагрузку на сеть и может улучшить общую пропускную способность веб-сервера.
Скопируйте файл с примером настроек:
# mkdir /etc/lighttpd/conf.d # cp /usr/share/doc/lighttpd/config/conf.d/deflate.conf /etc/lighttpd/conf.d/
Включите настройки, добавив в /etc/lighttpd/lighttpd.conf:
include "conf.d/deflate.conf"
Наконец, перезапустите lighttpd.service с новыми настройками, и он будет динамически сжимать простой текст и html.
/etc/lighttpd/lighttpd.conf.Также можно выбрать тип содержимого, которое должно быть сжато, изменив в файле /etc/lighttpd/conf.d/deflate.conf параметр deflate.mimetypes:
deflate.mimetypes           = ("text/plain", "text/html", "text/javascript", "text/css", "text/xml")
Можно создать каталог для хранения сжатых файлов. Создаём нужную директорию и задаём владельца:
# mkdir /var/cache/lighttpd/compress/ # chown http:http /var/cache/lighttpd/compress/
В файле /etc/lighttpd/conf.d/deflate.conf раскомментируйте и измените параметр deflate.cache-dir:
deflate.cache-dir = "/var/cache/lighttpd/compress"
Смотрите также
- Lighttpd wiki (англ.)