Как скомпилировать Nginx из исходного кода на Fedora 25

NGINX может использоваться как HTTP / HTTPS-сервер, обратный прокси-сервер, почтовый прокси-сервер, балансировщик нагрузки, терминатор TLS или сервер кэширования. Это довольно модульный дизайн. Он имеет собственные модули и сторонние модули, созданные сообществом. Написанный на языке программирования C, это очень быстрое и легкое программное обеспечение.

ПРИМЕЧАНИЕ : NGINX имеет два потока версий, которые работают параллельно - стабильный и магистральный . Обе версии могут быть использованы на производственном сервере. Рекомендуется использовать основную версию в производстве.

Установка NGINX из исходного кода относительно «проста» - загрузите последнюю версию исходного кода NGINX, настройте, соберите и установите его.

В этом уроке я буду использовать основную версию, которая на момент написания статьи была 1.13.3. Обновите номера версий соответственно, когда появятся новые версии.

Требования к сборке NGINX из исходного кода

Обязательные требования:

  • Версия библиотеки OpenSSL между 1.0.2 - 1.1.0
  • Версия библиотеки zlib между 1.1.3 - 1.2.11
  • Версия библиотеки PCRE между 4.4 - 8.41
  • Компилятор GCC

Необязательные требования:

Прежде чем вы начнете

  1. Создать обычного пользователя с sudoдоступом :

  2. Переключиться на нового пользователя:

    su - <username>
    
  3. Обновление системы:

    sudo dnf check-update || sudo dnf upgrade -y
    

Сборка NGINX из исходного кода

  1. Установите «Инструменты разработки», редактор Vim, wget и gcc-c ++:

    sudo dnf install -y @development-tools && sudo dnf install -y vim wget gcc-c++
    
  2. Загрузите последнюю основную версию исходного кода NGINX и распакуйте его:

    wget https://nginx.org/download/nginx-1.13.3.tar.gz && tar zxvf nginx-1.13.3.tar.gz
    
  3. Загрузите исходный код зависимостей NGINX и распакуйте их:

    NGINX зависит от 3 библиотек: PCRE , zlib и OpenSSL :

    # PCRE version 8.41
    wget https://ftp.pcre.org/pub/pcre/pcre-8.41.tar.gz && tar xzvf pcre-8.41.tar.gz
    
    # zlib version 1.2.11
    wget https://www.zlib.net/zlib-1.2.11.tar.gz && tar xzvf zlib-1.2.11.tar.gz
    
    # OpenSSL version 1.1.0f
    wget https://www.openssl.org/source/openssl-1.1.0f.tar.gz && tar xzvf openssl-1.1.0f.tar.gz
    
  4. Загрузите и установите дополнительные зависимости NGINX:

    # perl
    sudo dnf install -y perl perl-devel perl-ExtUtils-Embed
    
    # libxslt
    sudo dnf install -y libxslt libxslt-devel
    
    # libxml2
    sudo dnf install -y libxml2 libxml2-devel
    
    # libgd
    sudo dnf install -y gd gd-devel
    
    # GeoIP
    sudo dnf install -y GeoIP GeoIP-devel
    
    # Libatomic_Ops
    sudo dnf install -y libatomic_ops libatomic_ops-devel
    
  5. Удалить все .tar.gzфайлы. Они нам больше не нужны:

    rm -rf *.tar.gz
    
  6. Перейдите в исходный каталог NGINX:

    cd ~/nginx-1.13.3
    
  7. Для удобства перечислите файлы исходного кода NGINX и каталоги:

    ls
    # auto  CHANGES  CHANGES.ru  conf  configure  contrib  html  LICENSE  man  README  src
    
  8. Скопируйте справочную страницу NGINX по адресу /usr/share/man/man8/:

    sudo cp ~/nginx-1.13.3/man/nginx.8 /usr/share/man/man8/
    sudo gzip /usr/share/man/man8/nginx.8
    # Check that Man page for NGINX is working
    man nginx
    
  9. Для получения справки вы можете получить список доступных параметров конфигурации, выполнив:

    ./configure --help
    # To see want core modules can be build as dynamic run:
    ./configure --help | grep -F =dynamic
    
  10. Сконфигурируйте, скомпилируйте и установите NGINX:

    ./configure --prefix=/etc/nginx \
                --sbin-path=/usr/sbin/nginx \
                --modules-path=/usr/lib64/nginx/modules \
                --conf-path=/etc/nginx/nginx.conf \
                --error-log-path=/var/log/nginx/error.log \
                --pid-path=/var/run/nginx.pid \
                --lock-path=/var/run/nginx.lock \
                --user=nginx \
                --group=nginx \
                --build=Fedora \
                --builddir=nginx-1.13.3 \
                --with-select_module \
                --with-poll_module \
                --with-threads \
                --with-file-aio \
                --with-http_ssl_module \
                --with-http_v2_module \
                --with-http_realip_module \
                --with-http_addition_module \
                --with-http_xslt_module=dynamic \
                --with-http_image_filter_module=dynamic \
                --with-http_geoip_module=dynamic \
                --with-http_sub_module \
                --with-http_dav_module \
                --with-http_flv_module \
                --with-http_mp4_module \
                --with-http_gunzip_module \
                --with-http_gzip_static_module \
                --with-http_auth_request_module \
                --with-http_random_index_module \
                --with-http_secure_link_module \
                --with-http_degradation_module \
                --with-http_slice_module \
                --with-http_stub_status_module \
                --with-http_perl_module=dynamic \
                --with-perl=/usr/bin/perl \
                --http-log-path=/var/log/nginx/access.log \
                --http-client-body-temp-path=/var/cache/nginx/client_temp \
                --http-proxy-temp-path=/var/cache/nginx/proxy_temp \
                --http-fastcgi-temp-path=/var/cache/nginx/fastcgi_temp \
                --http-uwsgi-temp-path=/var/cache/nginx/uwsgi_temp \
                --http-scgi-temp-path=/var/cache/nginx/scgi_temp \
                --with-mail=dynamic \
                --with-mail_ssl_module \
                --with-stream=dynamic \
                --with-stream_ssl_module \
                --with-stream_realip_module \
                --with-stream_geoip_module=dynamic \
                --with-stream_ssl_preread_module \
                --with-compat \
                --with-pcre=../pcre-8.41 \
                --with-pcre-jit \
                --with-zlib=../zlib-1.2.11 \
                --with-openssl=../openssl-1.1.0f \
                --with-openssl-opt=no-nextprotoneg \
                --with-debug
    
    make
    sudo make install
    
  11. Напечатайте версию NGINX, версию компилятора и настройте параметры скрипта:

    nginx -V
    
    # nginx version: nginx/1.13.3 (Fedora)
    # built by gcc 6.3.1 20161221 (Red Hat 6.3.1-1) (GCC)
    # built with OpenSSL 1.1.0f  25 May 2017
    # TLS SNI support enabled
    # configure arguments: --prefix=/etc/nginx . . .
    # . . .
    
  12. Создайте пользователя и группу системы NGINX:

    sudo useradd --system --home /var/cache/nginx --shell /sbin/nologin --comment "nginx user" --user-group nginx
    
  13. Проверьте синтаксис и возможные ошибки:

    sudo nginx -t
    # Will throw this error: nginx: [emerg] mkdir() "/var/cache/nginx/client_temp" failed (2: No such file or directory)
    # Just create directory
    sudo mkdir -p /var/cache/nginx/ && sudo nginx -t
    
  14. Создайте системный файл модуля для NGINX:

    sudo vim /etc/systemd/system/nginx.service
    
  15. Скопируйте / вставьте следующее содержимое:

    ПРИМЕЧАНИЕ . Расположение PIDфайла и двоичного файла NGINX может отличаться в зависимости от того, как был скомпилирован NGINX.

    [Unit]
    Description=Nginx - A high performance web server and a reverse proxy server
    Documentation=http://nginx.org/en/docs/
    After=network.target
    
    [Service]
    Type=forking
    PIDFile=/var/run/nginx.pid
    ExecStartPre=/usr/sbin/nginx -t -q -g 'daemon on; master_process on;'
    ExecStart=/usr/sbin/nginx -g 'daemon on; master_process on;'
    ExecReload=/usr/sbin/nginx -g 'daemon on; master_process on;' -s reload
    ExecStop=-/sbin/start-stop-daemon --quiet --stop --retry QUIT/5 --pidfile /var/run/nginx.pid
    TimeoutStopSec=5
    KillMode=mixed
    
    [Install]
    WantedBy=multi-user.target
    
  16. Запустите NGINX:

    sudo systemctl start nginx.service
    
  17. Включите NGINX для автоматического запуска при загрузке:

    sudo systemctl enable nginx.service
    
  18. Проверьте, запустится ли NGINX после перезагрузки:

    sudo systemctl is-enabled nginx.service
    # enabled
    
  19. Проверьте, работает ли NGINX:

    sudo systemctl status nginx.service
    ps aux | grep nginx
    curl -I 127.0.0.1
    
  20. Перезагрузите VPS, чтобы убедиться, что NGINX запускается автоматически:

    sudo shutdown -r now
    
  21. Удалите архаичные файлы из /etc/nginx/каталога:

    sudo rm /etc/nginx/koi-utf /etc/nginx/koi-win /etc/nginx/win-utf
    
  22. Поместите файлы подсветки синтаксиса конфигурации NGINX для vimв ~/.vim/. Вам будет предоставлена ​​хорошая подсветка синтаксис�� при редактировании файла конфигурации NGINX:

    mkdir ~/.vim/
    cp -r ~/nginx-1.13.3/contrib/vim/* ~/.vim/
    
  23. Сделать conf.d/каталог в /etc/nginx/каталоге. В этом каталоге вы можете разместить виртуальные серверы и апстримы:

    sudo mkdir /etc/nginx/conf.d/
    
  24. Удалите извлеченные каталоги и файлы из вашего домашнего каталога:

    rm -rf nginx-1.13.3/ openssl-1.1.0f/ pcre-8.41/ zlib-1.2.11/
    

Вывод

Вот и все. Теперь у вас установлена ​​новейшая версия NGINX. Он статически скомпилирован с некоторыми важными библиотеками, такими как OpenSSL. Зачастую системная версия OpenSSL устарела. Используя этот метод установки с более новой версией OpenSSL, вы можете использовать преимущества новых шифров, таких как CHACHA20_POLY1305и протоколы, такие как TLS 1.3, которые будут доступны в OpenSSL 1.1.1(который не был выпущен на момент написания).



Leave a Comment

Как установить Matomo Analytics на Fedora 28

Как установить Matomo Analytics на Fedora 28

Используете другую систему? Matomo (ранее Piwik) - это аналитическая платформа с открытым исходным кодом, открытая альтернатива Google Analytics. Источник Matomo размещен o

Как установить форум NodeBB на Fedora 28

Как установить форум NodeBB на Fedora 28

Используете другую систему? NodeBB - это форум на базе Node.js. Он использует веб-сокеты для мгновенного взаимодействия и уведомления в режиме реального времени. Исходный код NodeBB я

Как установить Dolibarr на Fedora 28

Как установить Dolibarr на Fedora 28

Используете другую систему? Dolibarr - это общедоступное планирование ресурсов предприятия (ERP) и управление взаимоотношениями с клиентами (CRM) для бизнеса. Dolibar

Как установить AWStats на Fedora 28

Как установить AWStats на Fedora 28

AWStats - полезный инструмент для анализа веб-трафика. Его HTML-интерфейс доступен через браузер, что позволяет легко понять, кто вас просматривает.

Как установить RainLoop Webmail на Fedora 28

Как установить RainLoop Webmail на Fedora 28

Используете другую систему? RainLoop - это простой, современный и быстрый сетевой почтовый клиент. Исходный код RainLoop размещен на GitHub. Это руководство покажет вам, как

Как установить BookStack на Fedora 28

Как установить BookStack на Fedora 28

Используете другую систему? BookStack - это простая, самостоятельная платформа для организации и хранения информации. BookStack является полностью бесплатным и открытым исходным кодом,

Как установить Reader Self 3.5 RSS Reader на Fedora 26 LAMP VPS

Как установить Reader Self 3.5 RSS Reader на Fedora 26 LAMP VPS

Используете другую систему? Reader Self 3.5 - это простая и гибкая, бесплатная программа для чтения RSS с открытым исходным кодом и альтернатива Google Reader. Читатель Sel

Как установить Gitea на Fedora 29

Как установить Gitea на Fedora 29

Используете другую систему? Gitea - это альтернативная система управления версиями с открытым исходным кодом, работающая на Git. Гитея написана на Голанге и является

Как развернуть Ghost v0.11 LTS на Fedora 25

Как развернуть Ghost v0.11 LTS на Fedora 25

Используете другую систему? Ghost - это блог-платформа с открытым исходным кодом, которая завоевывает популярность среди разработчиков и обычных пользователей с 201 года.

Как установить Kanboard на Fedora 29

Как установить Kanboard на Fedora 29

Используете другую систему? Введение Kanboard - это бесплатная программа с открытым исходным кодом для управления проектами, предназначенная для упрощения и визуализации.

Как установить Directus 6.4 CMS на Fedora 26 LAMP VPS

Как установить Directus 6.4 CMS на Fedora 26 LAMP VPS

Используете другую систему? Directus 6.4 CMS - это мощная и гибкая, бесплатная система управления контентом (CMS) с открытым исходным кодом, которая предоставляет разработчикам

Как установить MyBB на Fedora 28

Как установить MyBB на Fedora 28

Используете другую систему? MyBB - это бесплатная и открытая, интуитивно понятная и расширяемая форумная программа. Исходный код MyBB размещен на GitHub. Это руководство будет шо

Как установить Backdrop CMS 1.8.0 на Fedora 26 LAMP VPS

Как установить Backdrop CMS 1.8.0 на Fedora 26 LAMP VPS

Используете другую систему? Backdrop CMS 1.8.0 - это простая и гибкая, удобная для мобильных устройств, бесплатная система с открытым исходным кодом (CMS), которая позволяет нам

Как установить Microweber на Fedora 28

Как установить Microweber на Fedora 28

Используете другую систему? Microweber - это CMS с открытым исходным кодом и онлайн-магазин. Исходный код микропровода размещен на GitHub. Это руководство покажет вам

Как установить Osclass на Fedora 28

Как установить Osclass на Fedora 28

Используете другую систему? Osclass - это проект с открытым исходным кодом, который позволяет легко создавать секретные сайты без каких-либо технических знаний. Его источник

Установите HTMLDoc на Fedora 29

Установите HTMLDoc на Fedora 29

Используете другую систему? HTMLDoc будет динамически анализировать документы Postscript (PDF 1.6) из правильно написанного гипертекста (HTML 3.2). Это позволит вам т

Как установить Cachet на Fedora 28

Как установить Cachet на Fedora 28

Используете другую систему? Cachet - это система страниц с открытым исходным кодом, написанная на PHP. Исходный код Cachet размещен в этом репозитории Github. В этом

Как установить программу чтения RSS Selfoss на VPS-лампе Fedora 26

Как установить программу чтения RSS Selfoss на VPS-лампе Fedora 26

Используете другую систему? Selfoss RSS Reader - это бесплатная многоцелевая веб-программа с открытым исходным кодом для самостоятельного размещения, прямой эфир, гибриды, лента новостей (RSS / Atom).

Как установить Paste 2.1 на Fedora 26 LAMP VPS

Как установить Paste 2.1 на Fedora 26 LAMP VPS

Используете другую систему? Paste 2.1 - это простое и гибкое бесплатное приложение с открытым исходным кодом для хранения кода, текста и многого другого. Это было изначально

Как установить PyroCMS на Fedora 28

Как установить PyroCMS на Fedora 28

Используете другую систему? PyroCMS - это CMS с открытым исходным кодом, написанная на PHP. Исходный код PyroCMS размещен на GitHub. В этом руководстве хорошо прогуляться по всему

Изучение 26 методов анализа больших данных: часть 1

Изучение 26 методов анализа больших данных: часть 1

Изучение 26 методов анализа больших данных: часть 1

6 невероятных фактов о Nintendo Switch

6 невероятных фактов о Nintendo Switch

Многие из вас знают Switch, который выйдет в марте 2017 года, и его новые функции. Для тех, кто не знает, мы подготовили список функций, которые делают «Switch» обязательным гаджетом.

Технические обещания, которые все еще не выполнены

Технические обещания, которые все еще не выполнены

Вы ждете, когда технологические гиганты выполнят свои обещания? проверить, что осталось недоставленным.

Функциональные возможности уровней эталонной архитектуры больших данных

Функциональные возможности уровней эталонной архитектуры больших данных

Прочтите блог, чтобы узнать о различных уровнях архитектуры больших данных и их функциях самым простым способом.

Как ИИ может вывести автоматизацию процессов на новый уровень?

Как ИИ может вывести автоматизацию процессов на новый уровень?

Прочтите это, чтобы узнать, как искусственный интеллект становится популярным среди небольших компаний и как он увеличивает вероятность их роста и дает преимущество перед конкурентами.

CAPTCHA: как долго она может оставаться жизнеспособным методом различения между человеком и ИИ?

CAPTCHA: как долго она может оставаться жизнеспособным методом различения между человеком и ИИ?

CAPTCHA стало довольно сложно решать пользователям за последние несколько лет. Сможет ли он оставаться эффективным в обнаружении спама и ботов в ближайшем будущем?

Технологическая сингулярность: далекое будущее человеческой цивилизации?

Технологическая сингулярность: далекое будущее человеческой цивилизации?

По мере того, как наука развивается быстрыми темпами, принимая на себя большую часть наших усилий, также возрастает риск подвергнуться необъяснимой сингулярности. Прочтите, что может значить для нас необычность.

Телемедицина и удаленное здравоохранение: будущее уже здесь

Телемедицина и удаленное здравоохранение: будущее уже здесь

Что такое телемедицина, дистанционное здравоохранение и их влияние на будущее поколение? Это хорошее место или нет в ситуации пандемии? Прочтите блог, чтобы узнать мнение!

Вы когда-нибудь задумывались, как хакеры зарабатывают деньги?

Вы когда-нибудь задумывались, как хакеры зарабатывают деньги?

Возможно, вы слышали, что хакеры зарабатывают много денег, но задумывались ли вы когда-нибудь о том, как они зарабатывают такие деньги? Давайте обсудим.

Обновление дополнения к macOS Catalina 10.15.4 вызывает больше проблем, чем решает

Обновление дополнения к macOS Catalina 10.15.4 вызывает больше проблем, чем решает

Недавно Apple выпустила macOS Catalina 10.15.4, дополнительное обновление для исправления проблем, но похоже, что это обновление вызывает больше проблем, приводящих к поломке компьютеров Mac. Прочтите эту статью, чтобы узнать больше