АвтоматизиранС Π½Π° инсталиранСто Π½Π° WordPress с NGINX Unit ΠΈ Ubuntu

АвтоматизиранС Π½Π° инсталиранСто Π½Π° WordPress с NGINX Unit ΠΈ Ubuntu

Има ΠΌΠ½ΠΎΠ³ΠΎ ΡƒΡ€ΠΎΡ†ΠΈ Π·Π° Ρ‚ΠΎΠ²Π° ΠΊΠ°ΠΊ Π΄Π° инсталиратС WordPress, Ρ‚ΡŠΡ€ΡΠ΅Π½Π΅ Π² Google Π½Π° β€žWordPress installβ€œ Ρ‰Π΅ ΠΏΠΎΠΊΠ°ΠΆΠ΅ ΠΎΠΊΠΎΠ»ΠΎ ΠΏΠΎΠ»ΠΎΠ²ΠΈΠ½ ΠΌΠΈΠ»ΠΈΠΎΠ½ Ρ€Π΅Π·ΡƒΠ»Ρ‚Π°Ρ‚ΠΈ. Π’ΡΡŠΡ‰Π½ΠΎΡΡ‚ ΠΎΠ±Π°Ρ‡Π΅ срСд тях ΠΈΠΌΠ° ΠΌΠ½ΠΎΠ³ΠΎ ΠΌΠ°Π»ΠΊΠΎ Π΄ΠΎΠ±Ρ€ΠΈ Ρ€ΡŠΠΊΠΎΠ²ΠΎΠ΄ΡΡ‚Π²Π°, спорСд ΠΊΠΎΠΈΡ‚ΠΎ ΠΌΠΎΠΆΠ΅Ρ‚Π΅ Π΄Π° инсталиратС ΠΈ ΠΊΠΎΠ½Ρ„ΠΈΠ³ΡƒΡ€ΠΈΡ€Π°Ρ‚Π΅ WordPress ΠΈ основната ΠΎΠΏΠ΅Ρ€Π°Ρ†ΠΈΠΎΠ½Π½Π° систСма, Ρ‚Π°ΠΊΠ° Ρ‡Π΅ Π΄Π° ΠΌΠΎΠ³Π°Ρ‚ Π΄Π° сС ΠΏΠΎΠ΄Π΄ΡŠΡ€ΠΆΠ°Ρ‚ Π·Π° дълъг ΠΏΠ΅Ρ€ΠΈΠΎΠ΄ ΠΎΡ‚ Π²Ρ€Π΅ΠΌΠ΅. МоТС Π±ΠΈ ΠΏΡ€Π°Π²ΠΈΠ»Π½ΠΈΡ‚Π΅ настройки са силно зависими ΠΎΡ‚ спСцифични Π½ΡƒΠΆΠ΄ΠΈ ΠΈΠ»ΠΈ Ρ‚ΠΎΠ²Π° сС дълТи Π½Π° Ρ„Π°ΠΊΡ‚Π°, Ρ‡Π΅ ΠΏΠΎΠ΄Ρ€ΠΎΠ±Π½ΠΎΡ‚ΠΎ обяснСниС ΠΏΡ€Π°Π²ΠΈ статията Ρ‚Ρ€ΡƒΠ΄Π½Π° Π·Π° Ρ‡Π΅Ρ‚Π΅Π½Π΅.

Π’ Ρ‚Π°Π·ΠΈ статия Ρ‰Π΅ сС ΠΎΠΏΠΈΡ‚Π°ΠΌΠ΅ Π΄Π° ΠΊΠΎΠΌΠ±ΠΈΠ½ΠΈΡ€Π°ΠΌΠ΅ Π½Π°ΠΉ-Π΄ΠΎΠ±Ρ€ΠΎΡ‚ΠΎ ΠΎΡ‚ Π΄Π²Π°Ρ‚Π° свята, ΠΊΠ°Ρ‚ΠΎ прСдоставим bash скрипт Π·Π° Π°Π²Ρ‚ΠΎΠΌΠ°Ρ‚ΠΈΡ‡Π½ΠΎ инсталиранС Π½Π° WordPress Π² Ubuntu, ΠΊΠ°ΠΊΡ‚ΠΎ ΠΈ Ρ‰Π΅ ΠΏΡ€Π΅ΠΌΠΈΠ½Π΅ΠΌ ΠΏΡ€Π΅Π· Π½Π΅Π³ΠΎ, обяснявайки ΠΊΠ°ΠΊΠ²ΠΎ ΠΏΡ€Π°Π²ΠΈ всяко ΠΏΠ°Ρ€Ρ‡Π΅, ΠΊΠ°ΠΊΡ‚ΠΎ ΠΈ компромиситС, ΠΊΠΎΠΈΡ‚ΠΎ Π½Π°ΠΏΡ€Π°Π²ΠΈΡ…ΠΌΠ΅ ΠΏΡ€ΠΈ Ρ€Π°Π·Ρ€Π°Π±ΠΎΡ‚Π²Π°Π½Π΅Ρ‚ΠΎ ΠΌΡƒ . Ако стС Π½Π°ΠΏΡ€Π΅Π΄Π½Π°Π» ΠΏΠΎΡ‚Ρ€Π΅Π±ΠΈΡ‚Π΅Π», ΠΌΠΎΠΆΠ΅Ρ‚Π΅ Π΄Π° пропуснСтС тСкста Π½Π° статията ΠΈ просто Π²Π·Π΅ΠΌΠ΅Ρ‚Π΅ сцСнария Π·Π° модификация ΠΈ ΠΈΠ·ΠΏΠΎΠ»Π·Π²Π°Π½Π΅ във Π²Π°ΡˆΠ°Ρ‚Π° срСда. Π Π΅Π·ΡƒΠ»Ρ‚Π°Ρ‚ΡŠΡ‚ ΠΎΡ‚ скрипта Π΅ пСрсонализирана инсталация Π½Π° WordPress с ΠΏΠΎΠ΄Π΄Ρ€ΡŠΠΆΠΊΠ° Π½Π° Lets Encrypt, Ρ€Π°Π±ΠΎΡ‚Π΅Ρ‰Π° Π½Π° NGINX Unit ΠΈ подходяща Π·Π° производствСна ΡƒΠΏΠΎΡ‚Ρ€Π΅Π±Π°.

Π Π°Π·Ρ€Π°Π±ΠΎΡ‚Π΅Π½Π°Ρ‚Π° Π°Ρ€Ρ…ΠΈΡ‚Π΅ΠΊΡ‚ΡƒΡ€Π° Π·Π° внСдряванС Π½Π° WordPress с ΠΏΠΎΠΌΠΎΡ‰Ρ‚Π° Π½Π° ΠΌΠΎΠ΄ΡƒΠ»Π° NGINX Π΅ описана Π² ΠΏΠΎ-стара статия, сСга ΡΡŠΡ‰ΠΎ Ρ‰Π΅ ΠΊΠΎΠ½Ρ„ΠΈΠ³ΡƒΡ€ΠΈΡ€Π°ΠΌΠ΅ Π΄ΠΎΠΏΡŠΠ»Π½ΠΈΡ‚Π΅Π»Π½ΠΎ Π½Π΅Ρ‰Π°, ΠΊΠΎΠΈΡ‚ΠΎ Π½Π΅ са Ρ€Π°Π·Π³Π»Π΅Π΄Π°Π½ΠΈ Ρ‚Π°ΠΌ (ΠΊΠ°ΠΊΡ‚ΠΎ Π² ΠΌΠ½ΠΎΠ³ΠΎ Π΄Ρ€ΡƒΠ³ΠΈ ΡƒΡ€ΠΎΡ†ΠΈ):

  • WordPress CLI
  • Let's Encrypt ΠΈ TLSSSL сСртификати
  • Автоматично подновяванС Π½Π° сСртификати
  • NGINX ΠΊΠ΅ΡˆΠΈΡ€Π°Π½Π΅
  • NGINX компрСсия
  • ΠŸΠΎΠ΄Π΄Ρ€ΡŠΠΆΠΊΠ° Π½Π° HTTPS ΠΈ HTTP/2
  • Автоматизация Π½Π° процСситС

Бтатията Ρ‰Π΅ опишС инсталиранСто Π½Π° Π΅Π΄ΠΈΠ½ ΡΡŠΡ€Π²ΡŠΡ€, ΠΊΠΎΠΉΡ‚ΠΎ Π΅Π΄Π½ΠΎΠ²Ρ€Π΅ΠΌΠ΅Π½Π½ΠΎ Ρ‰Π΅ хоства ΡΡŠΡ€Π²ΡŠΡ€ Π·Π° статична ΠΎΠ±Ρ€Π°Π±ΠΎΡ‚ΠΊΠ°, ΡΡŠΡ€Π²ΡŠΡ€ Π·Π° ΠΎΠ±Ρ€Π°Π±ΠΎΡ‚ΠΊΠ° Π½Π° PHP ΠΈ Π±Π°Π·Π° Π΄Π°Π½Π½ΠΈ. Π˜Π½ΡΡ‚Π°Π»Π°Ρ†ΠΈΡ, която ΠΏΠΎΠ΄Π΄ΡŠΡ€ΠΆΠ° мноТСство Π²ΠΈΡ€Ρ‚ΡƒΠ°Π»Π½ΠΈ хостовС ΠΈ услуги, Π΅ ΠΏΠΎΡ‚Π΅Π½Ρ†ΠΈΠ°Π»Π½Π° Ρ‚Π΅ΠΌΠ° Π·Π° Π±ΡŠΠ΄Π΅Ρ‰Π΅Ρ‚ΠΎ. Ако искатС Π΄Π° пишСм Π·Π° Π½Π΅Ρ‰ΠΎ, ΠΊΠΎΠ΅Ρ‚ΠΎ Π½Π΅ Π΅ Π² Ρ‚Π΅Π·ΠΈ статии, ΠΏΠΈΡˆΠ΅Ρ‚Π΅ Π² ΠΊΠΎΠΌΠ΅Π½Ρ‚Π°Ρ€ΠΈΡ‚Π΅.

Изисквания

  • Π‘ΡŠΡ€Π²ΡŠΡ€ Π·Π° ΠΊΠΎΠ½Ρ‚Π΅ΠΉΠ½Π΅Ρ€ΠΈ (LXC ΠΈΠ»ΠΈ LXD), Π²ΠΈΡ€Ρ‚ΡƒΠ°Π»Π½Π° машина ΠΈΠ»ΠΈ ΠΎΠ±ΠΈΠΊΠ½ΠΎΠ²Π΅Π½ ΠΆΠ΅Π»Π΅Π·Π΅Π½ ΡΡŠΡ€Π²ΡŠΡ€ с ΠΏΠΎΠ½Π΅ 512 MB RAM ΠΈ инсталиран Ubuntu 18.04 ΠΈΠ»ΠΈ ΠΏΠΎ-Π½ΠΎΠ²Π° вСрсия.
  • Π˜Π½Ρ‚Π΅Ρ€Π½Π΅Ρ‚ Π΄ΠΎΡΡ‚ΡŠΠΏΠ½ΠΈ ΠΏΠΎΡ€Ρ‚ΠΎΠ²Π΅ 80 ΠΈ 443
  • ИмС Π½Π° Π΄ΠΎΠΌΠ΅ΠΉΠ½, ΡΠ²ΡŠΡ€Π·Π°Π½ΠΎ с публичния IP адрСс Π½Π° Ρ‚ΠΎΠ·ΠΈ ΡΡŠΡ€Π²ΡŠΡ€
  • Π”ΠΎΡΡ‚ΡŠΠΏ Π΄ΠΎ root (sudo).

ΠŸΡ€Π΅Π³Π»Π΅Π΄ Π½Π° Π°Ρ€Ρ…ΠΈΡ‚Π΅ΠΊΡ‚ΡƒΡ€Π°Ρ‚Π°

АрхитСктурата Π΅ ΡΡŠΡ‰Π°Ρ‚Π° ΠΊΠ°Ρ‚ΠΎ описаната ΠΏΠΎ-Ρ€Π°Π½ΠΎ, тристСпСнно ΡƒΠ΅Π± ΠΏΡ€ΠΈΠ»ΠΎΠΆΠ΅Π½ΠΈΠ΅. Π‘ΡŠΡΡ‚ΠΎΠΈ сС ΠΎΡ‚ PHP скриптовС, ΠΊΠΎΠΈΡ‚ΠΎ сС ΠΈΠ·ΠΏΡŠΠ»Π½ΡΠ²Π°Ρ‚ Π½Π° PHP двигатСля ΠΈ статични Ρ„Π°ΠΉΠ»ΠΎΠ²Π΅, ΠΊΠΎΠΈΡ‚ΠΎ сС ΠΎΠ±Ρ€Π°Π±ΠΎΡ‚Π²Π°Ρ‚ ΠΎΡ‚ ΡƒΠ΅Π± ΡΡŠΡ€Π²ΡŠΡ€Π°.

АвтоматизиранС Π½Π° инсталиранСто Π½Π° WordPress с NGINX Unit ΠΈ Ubuntu

ΠžΠ±Ρ‰ΠΈ ΠΏΡ€ΠΈΠ½Ρ†ΠΈΠΏΠΈ

  • Много ΠΊΠΎΠΌΠ°Π½Π΄ΠΈ Π·Π° ΠΊΠΎΠ½Ρ„ΠΈΠ³ΡƒΡ€ΠΈΡ€Π°Π½Π΅ Π² скрипт са ΠΎΠ±Π²ΠΈΡ‚ΠΈ Π² условия Π½Π° if Π·Π° идСмпотСнтност: ΡΠΊΡ€ΠΈΠΏΡ‚ΡŠΡ‚ ΠΌΠΎΠΆΠ΅ Π΄Π° сС изпълнява ΠΌΠ½ΠΎΠ³ΠΎΠΊΡ€Π°Ρ‚Π½ΠΎ Π±Π΅Π· риск ΠΎΡ‚ промяна Π½Π° настройкитС, ΠΊΠΎΠΈΡ‚ΠΎ Π²Π΅Ρ‡Π΅ са Π½Π°Π»ΠΈΡ†Π΅.
  • Π‘ΠΊΡ€ΠΈΠΏΡ‚ΡŠΡ‚ сС ΠΎΠΏΠΈΡ‚Π²Π° Π΄Π° инсталира софтуСр ΠΎΡ‚ Ρ…Ρ€Π°Π½ΠΈΠ»ΠΈΡ‰Π°, Ρ‚Π°ΠΊΠ° Ρ‡Π΅ ΠΌΠΎΠΆΠ΅Ρ‚Π΅ Π΄Π° ΠΏΡ€ΠΈΠ»ΠΎΠΆΠΈΡ‚Π΅ систСмни Π°ΠΊΡ‚ΡƒΠ°Π»ΠΈΠ·Π°Ρ†ΠΈΠΈ с Π΅Π΄Π½Π° ΠΊΠΎΠΌΠ°Π½Π΄Π° (apt upgrade Π·Π° Ubuntu).
  • ΠšΠΎΠΌΠ°Π½Π΄ΠΈΡ‚Π΅ сС ΠΎΠΏΠΈΡ‚Π²Π°Ρ‚ Π΄Π° открият, Ρ‡Π΅ сС ΠΈΠ·ΠΏΡŠΠ»Π½ΡΠ²Π°Ρ‚ Π² ΠΊΠΎΠ½Ρ‚Π΅ΠΉΠ½Π΅Ρ€, Π·Π° Π΄Π° ΠΌΠΎΠ³Π°Ρ‚ ΡΡŠΠΎΡ‚Π²Π΅Ρ‚Π½ΠΎ Π΄Π° промСнят настройкитС си.
  • Π—Π° Π΄Π° Π·Π°Π΄Π°Π΄Π΅ броя процСси Π½Π° нишки, ΠΊΠΎΠΈΡ‚ΠΎ Π΄Π° стартират Π² настройкитС, ΡΠΊΡ€ΠΈΠΏΡ‚ΡŠΡ‚ сС ΠΎΠΏΠΈΡ‚Π²Π° Π΄Π° ΠΎΡ‚Π³Π°Ρ‚Π½Π΅ Π°Π²Ρ‚ΠΎΠΌΠ°Ρ‚ΠΈΡ‡Π½ΠΈΡ‚Π΅ настройки Π·Π° Ρ€Π°Π±ΠΎΡ‚Π° Π² ΠΊΠΎΠ½Ρ‚Π΅ΠΉΠ½Π΅Ρ€ΠΈ, Π²ΠΈΡ€Ρ‚ΡƒΠ°Π»Π½ΠΈ машини ΠΈ Ρ…Π°Ρ€Π΄ΡƒΠ΅Ρ€Π½ΠΈ ΡΡŠΡ€Π²ΡŠΡ€ΠΈ.
  • ΠšΠΎΠ³Π°Ρ‚ΠΎ описвамС настройкитС, Π²ΠΈΠ½Π°Π³ΠΈ мислим ΠΏΡ€Π΅Π΄ΠΈ всичко Π·Π° автоматизацията, която, надявамС сС, Ρ‰Π΅ станС основа Π·Π° създаванС Π½Π° ваша собствСна инфраструктура ΠΊΠ°Ρ‚ΠΎ ΠΊΠΎΠ΄.
  • Всички ΠΊΠΎΠΌΠ°Π½Π΄ΠΈ сС ΠΈΠ·ΠΏΡŠΠ»Π½ΡΠ²Π°Ρ‚ ΠΊΠ°Ρ‚ΠΎ ΠΏΠΎΡ‚Ρ€Π΅Π±ΠΈΡ‚Π΅Π» ΠΊΠΎΡ€Π΅Π½, Π·Π°Ρ‰ΠΎΡ‚ΠΎ промСнят основнитС систСмни настройки, Π½ΠΎ Π΄ΠΈΡ€Π΅ΠΊΡ‚Π½ΠΎ WordPress Ρ€Π°Π±ΠΎΡ‚ΠΈ ΠΊΠ°Ρ‚ΠΎ ΠΎΠ±ΠΈΠΊΠ½ΠΎΠ²Π΅Π½ ΠΏΠΎΡ‚Ρ€Π΅Π±ΠΈΡ‚Π΅Π».

Π—Π°Π΄Π°Π²Π°Π½Π΅ Π½Π° ΠΏΡ€ΠΎΠΌΠ΅Π½Π»ΠΈΠ²ΠΈ Π½Π° срСдата

Π—Π°Π΄Π°ΠΉΡ‚Π΅ слСднитС ΠΏΡ€ΠΎΠΌΠ΅Π½Π»ΠΈΠ²ΠΈ Π½Π° срСдата, ΠΏΡ€Π΅Π΄ΠΈ Π΄Π° стартиратС скрипта:

  • WORDPRESS_DB_PASSWORD - ΠŸΠ°Ρ€ΠΎΠ»Π° Π·Π° Π±Π°Π·Π° Π΄Π°Π½Π½ΠΈ Π½Π° WordPress
  • WORDPRESS_ADMIN_USER - ИмС Π½Π° администратор Π½Π° WordPress
  • WORDPRESS_ADMIN_PASSWORD - Административна ΠΏΠ°Ρ€ΠΎΠ»Π° Π½Π° WordPress
  • WORDPRESS_ADMIN_EMAIL - Администраторски ΠΈΠΌΠ΅ΠΉΠ» Π½Π° WordPress
  • WORDPRESS_URL Π΅ ΠΏΡŠΠ»Π½ΠΈΡΡ‚ URL адрСс Π½Π° сайта WordPress, Π·Π°ΠΏΠΎΡ‡Π²Π°Ρ‰ ΠΎΡ‚ https://.
  • LETS_ENCRYPT_STAGING - ΠΏΡ€Π°Π·Π΅Π½ ΠΏΠΎ ΠΏΠΎΠ΄Ρ€Π°Π·Π±ΠΈΡ€Π°Π½Π΅, Π½ΠΎ ΠΊΠ°Ρ‚ΠΎ Π·Π°Π΄Π°Π΄Π΅Ρ‚Π΅ стойността Π½Π° 1, Π²ΠΈΠ΅ Ρ‰Π΅ ΠΈΠ·ΠΏΠΎΠ»Π·Π²Π°Ρ‚Π΅ Π΅Ρ‚Π°ΠΏΠ½ΠΈΡ‚Π΅ ΡΡŠΡ€Π²ΡŠΡ€ΠΈ Π½Π° Let's Encrypt, ΠΊΠΎΠΈΡ‚ΠΎ са Π½Π΅ΠΎΠ±Ρ…ΠΎΠ΄ΠΈΠΌΠΈ Π·Π° чСсто изискванС Π½Π° сСртификати ΠΏΡ€ΠΈ тСстванС Π½Π° Π²Π°ΡˆΠΈΡ‚Π΅ настройки, Π² ΠΏΡ€ΠΎΡ‚ΠΈΠ²Π΅Π½ случай Let's Encrypt ΠΌΠΎΠΆΠ΅ Π²Ρ€Π΅ΠΌΠ΅Π½Π½ΠΎ Π΄Π° Π±Π»ΠΎΠΊΠΈΡ€Π° вашия ip адрСс ΠΏΠΎΡ€Π°Π΄ΠΈ голям Π±Ρ€ΠΎΠΉ заявки .

Π‘ΠΊΡ€ΠΈΠΏΡ‚ΡŠΡ‚ провСрява Π΄Π°Π»ΠΈ Ρ‚Π΅Π·ΠΈ ΡΠ²ΡŠΡ€Π·Π°Π½ΠΈ с WordPress ΠΏΡ€ΠΎΠΌΠ΅Π½Π»ΠΈΠ²ΠΈ са Π·Π°Π΄Π°Π΄Π΅Π½ΠΈ ΠΈ ΠΈΠ·Π»ΠΈΠ·Π°, Π°ΠΊΠΎ Π½Π΅ са.
Π‘ΠΊΡ€ΠΈΠΏΡ‚ Ρ€Π΅Π΄ΠΎΠ²Π΅ 572-576 провСряват стойността LETS_ENCRYPT_STAGING.

Π—Π°Π΄Π°Π²Π°Π½Π΅ Π½Π° ΠΏΡ€ΠΎΠΈΠ·Π²ΠΎΠ΄Π½ΠΈ ΠΏΡ€ΠΎΠΌΠ΅Π½Π»ΠΈΠ²ΠΈ Π½Π° срСдата

Π‘ΠΊΡ€ΠΈΠΏΡ‚ΡŠΡ‚ Π½Π° Ρ€Π΅Π΄ΠΎΠ²Π΅ 55-61 Π·Π°Π΄Π°Π²Π° слСднитС ΠΏΡ€ΠΎΠΌΠ΅Π½Π»ΠΈΠ²ΠΈ Π½Π° срСдата, ΠΈΠ»ΠΈ Π½Π° някаква Ρ‚Π²ΡŠΡ€Π΄ΠΎ ΠΊΠΎΠ΄ΠΈΡ€Π°Π½Π° стойност, ΠΈΠ»ΠΈ ΠΈΠ·ΠΏΠΎΠ»Π·Π²Π°ΠΉΠΊΠΈ стойност, ΠΏΠΎΠ»ΡƒΡ‡Π΅Π½Π° ΠΎΡ‚ ΠΏΡ€ΠΎΠΌΠ΅Π½Π»ΠΈΠ²ΠΈΡ‚Π΅, Π·Π°Π΄Π°Π΄Π΅Π½ΠΈ Π² ΠΏΡ€Π΅Π΄ΠΈΡˆΠ½ΠΈΡ Ρ€Π°Π·Π΄Π΅Π»:

  • DEBIAN_FRONTEND="noninteractive" - Казва Π½Π° прилоТСнията, Ρ‡Π΅ работят Π² скрипт ΠΈ Ρ‡Π΅ няма Π²ΡŠΠ·ΠΌΠΎΠΆΠ½ΠΎΡΡ‚ Π·Π° взаимодСйствиС с потрСбитСля.
  • WORDPRESS_CLI_VERSION="2.4.0" Π΅ вСрсията Π½Π° ΠΏΡ€ΠΈΠ»ΠΎΠΆΠ΅Π½ΠΈΠ΅Ρ‚ΠΎ WordPress CLI.
  • WORDPRESS_CLI_MD5= "dedd5a662b80cda66e9e25d44c23b25c" β€” ΠΊΠΎΠ½Ρ‚Ρ€ΠΎΠ»Π½Π° сума Π½Π° изпълнимия Ρ„Π°ΠΉΠ» Π½Π° WordPress CLI 2.4.0 (вСрсията Π΅ посочСна Π² ΠΏΡ€ΠΎΠΌΠ΅Π½Π»ΠΈΠ²Π°Ρ‚Π° WORDPRESS_CLI_VERSION). Π‘ΠΊΡ€ΠΈΠΏΡ‚ΡŠΡ‚ Π½Π° Ρ€Π΅Π΄ 162 ΠΈΠ·ΠΏΠΎΠ»Π·Π²Π° Ρ‚Π°Π·ΠΈ стойност, Π·Π° Π΄Π° ΠΏΡ€ΠΎΠ²Π΅Ρ€ΠΈ Π΄Π°Π»ΠΈ Π΅ ΠΈΠ·Ρ‚Π΅Π³Π»Π΅Π½ правилният WordPress CLI Ρ„Π°ΠΉΠ».
  • UPLOAD_MAX_FILESIZE="16M" - максималният Ρ€Π°Π·ΠΌΠ΅Ρ€ Π½Π° Ρ„Π°ΠΉΠ»Π°, ΠΊΠΎΠΉΡ‚ΠΎ ΠΌΠΎΠΆΠ΅ Π΄Π° бъдС ΠΊΠ°Ρ‡Π΅Π½ Π² WordPress. Π’Π°Π·ΠΈ настройка сС ΠΈΠ·ΠΏΠΎΠ»Π·Π²Π° Π½Π° няколко мСста, Ρ‚Π°ΠΊΠ° Ρ‡Π΅ Π΅ ΠΏΠΎ-лСсно Π΄Π° я Π·Π°Π΄Π°Π΄Π΅Ρ‚Π΅ Π½Π° Π΅Π΄Π½ΠΎ място.
  • TLS_HOSTNAME= "$(echo ${WORDPRESS_URL} | cut -d'/' -f3)" - ΠΈΠΌΠ΅ Π½Π° хост Π½Π° систСмата, ΠΈΠ·Π²Π»Π΅Ρ‡Π΅Π½ΠΎ ΠΎΡ‚ ΠΏΡ€ΠΎΠΌΠ΅Π½Π»ΠΈΠ²Π°Ρ‚Π° WORDPRESS_URL. Използва сС Π·Π° ΠΏΠΎΠ»ΡƒΡ‡Π°Π²Π°Π½Π΅ Π½Π° подходящи TLS/SSL сСртификати ΠΎΡ‚ Let's Encrypt, ΠΊΠ°ΠΊΡ‚ΠΎ ΠΈ Π·Π° Π²ΡŠΡ‚Ρ€Π΅ΡˆΠ½Π° ΠΏΡ€ΠΎΠ²Π΅Ρ€ΠΊΠ° Π½Π° WordPress.
  • NGINX_CONF_DIR="/etc/nginx" - ΠΏΡŠΡ‚ Π΄ΠΎ дирСкторията с настройкитС Π½Π° NGINX, Π²ΠΊΠ»ΡŽΡ‡ΠΈΡ‚Π΅Π»Π½ΠΎ основния Ρ„Π°ΠΉΠ» nginx.conf.
  • CERT_DIR="/etc/letsencrypt/live/${TLS_HOSTNAME}" β€” ΠΏΡŠΡ‚ΡΡ‚ Π΄ΠΎ Let's Encrypt сСртификатитС Π·Π° WordPress сайта, ΠΏΠΎΠ»ΡƒΡ‡Π΅Π½ ΠΎΡ‚ ΠΏΡ€ΠΎΠΌΠ΅Π½Π»ΠΈΠ²Π°Ρ‚Π° TLS_HOSTNAME.

ΠŸΡ€ΠΈΡΠ²ΠΎΡΠ²Π°Π½Π΅ Π½Π° ΠΈΠΌΠ΅ Π½Π° хост към WordPress ΡΡŠΡ€Π²ΡŠΡ€

Π‘ΠΊΡ€ΠΈΠΏΡ‚ΡŠΡ‚ настройва ΠΈΠΌΠ΅Ρ‚ΠΎ Π½Π° хоста Π½Π° ΡΡŠΡ€Π²ΡŠΡ€Π° Π΄Π° ΡΡŠΠΎΡ‚Π²Π΅Ρ‚ΡΡ‚Π²Π° Π½Π° ΠΈΠΌΠ΅Ρ‚ΠΎ Π½Π° Π΄ΠΎΠΌΠ΅ΠΉΠ½Π° Π½Π° сайта. Π’ΠΎΠ²Π° Π½Π΅ Π΅ Π·Π°Π΄ΡŠΠ»ΠΆΠΈΡ‚Π΅Π»Π½ΠΎ, Π½ΠΎ Π΅ ΠΏΠΎ-ΡƒΠ΄ΠΎΠ±Π½ΠΎ Π΄Π° ΠΈΠ·ΠΏΡ€Π°Ρ‰Π°Ρ‚Π΅ изходяща ΠΏΠΎΡ‰Π° ΠΏΡ€Π΅Π· SMTP, ΠΊΠΎΠ³Π°Ρ‚ΠΎ настройватС Π΅Π΄ΠΈΠ½ ΡΡŠΡ€Π²ΡŠΡ€, ΠΊΠ°ΠΊΡ‚ΠΎ Π΅ ΠΊΠΎΠ½Ρ„ΠΈΠ³ΡƒΡ€ΠΈΡ€Π°Π½ΠΎ ΠΎΡ‚ скрипта.

ΠΊΠΎΠ΄ Π½Π° скрипта

# Change the hostname to be the same as the WordPress hostname
if [ ! "$(hostname)" == "${TLS_HOSTNAME}" ]; then
  echo " Changing hostname to ${TLS_HOSTNAME}"
  hostnamectl set-hostname "${TLS_HOSTNAME}"
fi

ДобавянС Π½Π° ΠΈΠΌΠ΅ Π½Π° хост към /etc/hosts

Π”ΠΎΠΏΡŠΠ»Π½Π΅Π½ΠΈΠ΅ WP-Cron ΠΈΠ·ΠΏΠΎΠ»Π·Π²Π°Π½ Π·Π° изпълнСниС Π½Π° ΠΏΠ΅Ρ€ΠΈΠΎΠ΄ΠΈΡ‡Π½ΠΈ Π·Π°Π΄Π°Ρ‡ΠΈ, изисква WordPress Π΄Π° ΠΈΠΌΠ° Π΄ΠΎΡΡ‚ΡŠΠΏ Π΄ΠΎ сСбС си Ρ‡Ρ€Π΅Π· HTTP. Π—Π° Π΄Π° сС ΡƒΠ²Π΅Ρ€ΠΈΡ‚Π΅, Ρ‡Π΅ WP-Cron Ρ€Π°Π±ΠΎΡ‚ΠΈ ΠΏΡ€Π°Π²ΠΈΠ»Π½ΠΎ във всички срСди, ΡΠΊΡ€ΠΈΠΏΡ‚ΡŠΡ‚ добавя Ρ€Π΅Π΄ към Ρ„Π°ΠΉΠ»Π° / Etc / hostsΡ‚Π°ΠΊΠ° Ρ‡Π΅ WordPress Π΄Π° ΠΈΠΌΠ° Π΄ΠΎΡΡ‚ΡŠΠΏ Π΄ΠΎ сСбС си Ρ‡Ρ€Π΅Π· интСрфСйса Π·Π° ΠΎΠ±Ρ€Π°Ρ‚Π½Π° Π²Ρ€ΡŠΠ·ΠΊΠ°:

ΠΊΠΎΠ΄ Π½Π° скрипта

# Add the hostname to /etc/hosts
if [ "$(grep -m1 "${TLS_HOSTNAME}" /etc/hosts)" = "" ]; then
  echo " Adding hostname ${TLS_HOSTNAME} to /etc/hosts so that WordPress can ping itself"
  printf "::1 %sn127.0.0.1 %sn" "${TLS_HOSTNAME}" "${TLS_HOSTNAME}" >> /etc/hosts
fi

Π˜Π½ΡΡ‚Π°Π»ΠΈΡ€Π°Π½Π΅ Π½Π° инструмСнтитС, Π½Π΅ΠΎΠ±Ρ…ΠΎΠ΄ΠΈΠΌΠΈ Π·Π° слСдващитС ΡΡ‚ΡŠΠΏΠΊΠΈ

ΠžΡΡ‚Π°Π½Π°Π»Π°Ρ‚Π° част ΠΎΡ‚ скрипта сС Π½ΡƒΠΆΠ΄Π°Π΅ ΠΎΡ‚ някои ΠΏΡ€ΠΎΠ³Ρ€Π°ΠΌΠΈ ΠΈ ΠΏΡ€Π΅Π΄ΠΏΠΎΠ»Π°Π³Π°, Ρ‡Π΅ Ρ…Ρ€Π°Π½ΠΈΠ»ΠΈΡ‰Π°Ρ‚Π° са Π°ΠΊΡ‚ΡƒΠ°Π»Π½ΠΈ. АктуализирамС списъка с Ρ…Ρ€Π°Π½ΠΈΠ»ΠΈΡ‰Π°, слСд ΠΊΠΎΠ΅Ρ‚ΠΎ инсталирамС Π½Π΅ΠΎΠ±Ρ…ΠΎΠ΄ΠΈΠΌΠΈΡ‚Π΅ инструмСнти:

ΠΊΠΎΠ΄ Π½Π° скрипта

# Make sure tools needed for install are present
echo " Installing prerequisite tools"
apt-get -qq update
apt-get -qq install -y 
  bc 
  ca-certificates 
  coreutils 
  curl 
  gnupg2 
  lsb-release

ДобавянС Π½Π° NGINX ΠΌΠΎΠ΄ΡƒΠ» ΠΈ NGINX Ρ…Ρ€Π°Π½ΠΈΠ»ΠΈΡ‰Π°

Π‘ΠΊΡ€ΠΈΠΏΡ‚ΡŠΡ‚ инсталира NGINX Unit ΠΈ NGINX с ΠΎΡ‚Π²ΠΎΡ€Π΅Π½ ΠΊΠΎΠ΄ ΠΎΡ‚ ΠΎΡ„ΠΈΡ†ΠΈΠ°Π»Π½ΠΈΡ‚Π΅ Ρ…Ρ€Π°Π½ΠΈΠ»ΠΈΡ‰Π° Π½Π° NGINX, Π·Π° Π΄Π° сС ΡƒΠ²Π΅Ρ€ΠΈ, Ρ‡Π΅ сС ΠΈΠ·ΠΏΠΎΠ»Π·Π²Π°Ρ‚ вСрсиитС с Π½Π°ΠΉ-Π½ΠΎΠ²ΠΈΡ‚Π΅ ΠΊΡ€ΡŠΠΏΠΊΠΈ Π·Π° сигурност ΠΈ ΠΊΠΎΡ€Π΅ΠΊΡ†ΠΈΠΈ Π½Π° Π³Ρ€Π΅ΡˆΠΊΠΈ.

Π‘ΠΊΡ€ΠΈΠΏΡ‚ΡŠΡ‚ добавя Ρ…Ρ€Π°Π½ΠΈΠ»ΠΈΡ‰Π΅Ρ‚ΠΎ Π½Π° NGINX Unit ΠΈ слСд Ρ‚ΠΎΠ²Π° Ρ…Ρ€Π°Π½ΠΈΠ»ΠΈΡ‰Π΅Ρ‚ΠΎ Π½Π° NGINX, ΠΊΠ°Ρ‚ΠΎ добавя ΠΊΠ»ΡŽΡ‡Π° Π½Π° Ρ…Ρ€Π°Π½ΠΈΠ»ΠΈΡ‰Π°Ρ‚Π° ΠΈ ΠΊΠΎΠ½Ρ„ΠΈΠ³ΡƒΡ€Π°Ρ†ΠΈΠΎΠ½Π½ΠΈΡ‚Π΅ Ρ„Π°ΠΉΠ»ΠΎΠ²Π΅ apt, Π΄Π΅Ρ„ΠΈΠ½ΠΈΡ€Π°Π½Π΅ Π½Π° Π΄ΠΎΡΡ‚ΡŠΠΏ Π΄ΠΎ Ρ…Ρ€Π°Π½ΠΈΠ»ΠΈΡ‰Π° ΠΏΡ€Π΅Π· Π˜Π½Ρ‚Π΅Ρ€Π½Π΅Ρ‚.

ДСйствитСлното инсталиранС Π½Π° NGINX Unit ΠΈ NGINX сС случва Π² слСдващия Ρ€Π°Π·Π΄Π΅Π». ΠŸΡ€Π΅Π΄Π²Π°Ρ€ΠΈΡ‚Π΅Π»Π½ΠΎ добавямС Ρ…Ρ€Π°Π½ΠΈΠ»ΠΈΡ‰Π°Ρ‚Π°, Ρ‚Π°ΠΊΠ° Ρ‡Π΅ Π½Π΅ сС Π½Π°Π»Π°Π³Π° Π΄Π° Π°ΠΊΡ‚ΡƒΠ°Π»ΠΈΠ·ΠΈΡ€Π°ΠΌΠ΅ ΠΌΠ΅Ρ‚Π°Π΄Π°Π½Π½ΠΈΡ‚Π΅ ΠΌΠ½ΠΎΠ³ΠΎΠΊΡ€Π°Ρ‚Π½ΠΎ, ΠΊΠΎΠ΅Ρ‚ΠΎ ΠΏΡ€Π°Π²ΠΈ инсталиранСто ΠΏΠΎ-Π±ΡŠΡ€Π·ΠΎ.

ΠΊΠΎΠ΄ Π½Π° скрипта

# Install the NGINX Unit repository
if [ ! -f /etc/apt/sources.list.d/unit.list ]; then
  echo " Installing NGINX Unit repository"
  curl -fsSL https://nginx.org/keys/nginx_signing.key | apt-key add -
  echo "deb https://packages.nginx.org/unit/ubuntu/ $(lsb_release -cs) unit" > /etc/apt/sources.list.d/unit.list
fi

# Install the NGINX repository
if [ ! -f /etc/apt/sources.list.d/nginx.list ]; then
  echo " Installing NGINX repository"
  curl -fsSL https://nginx.org/keys/nginx_signing.key | apt-key add -
  echo "deb https://nginx.org/packages/mainline/ubuntu $(lsb_release -cs) nginx" > /etc/apt/sources.list.d/nginx.list
fi

Π˜Π½ΡΡ‚Π°Π»ΠΈΡ€Π°Π½Π΅ Π½Π° NGINX, NGINX Unit, PHP MariaDB, Certbot (Let's Encrypt) ΠΈ Ρ‚Π΅Ρ…Π½ΠΈΡ‚Π΅ зависимости

Π‘Π»Π΅Π΄ ΠΊΠ°Ρ‚ΠΎ всички Ρ…Ρ€Π°Π½ΠΈΠ»ΠΈΡ‰Π° Π±ΡŠΠ΄Π°Ρ‚ Π΄ΠΎΠ±Π°Π²Π΅Π½ΠΈ, Π°ΠΊΡ‚ΡƒΠ°Π»ΠΈΠ·ΠΈΡ€Π°ΠΉΡ‚Π΅ ΠΌΠ΅Ρ‚Π°Π΄Π°Π½Π½ΠΈΡ‚Π΅ ΠΈ инсталирайтС прилоТСнията. ΠŸΠ°ΠΊΠ΅Ρ‚ΠΈΡ‚Π΅, инсталирани ΠΎΡ‚ скрипта, ΡΡŠΡ‰ΠΎ Π²ΠΊΠ»ΡŽΡ‡Π²Π°Ρ‚ PHP Ρ€Π°Π·ΡˆΠΈΡ€Π΅Π½ΠΈΡΡ‚Π°, ΠΏΡ€Π΅ΠΏΠΎΡ€ΡŠΡ‡Π°Π½ΠΈ ΠΏΡ€ΠΈ стартиранС Π½Π° WordPress.org

ΠΊΠΎΠ΄ Π½Π° скрипта

echo " Updating repository metadata"
apt-get -qq update

# Install PHP with dependencies and NGINX Unit
echo " Installing PHP, NGINX Unit, NGINX, Certbot, and MariaDB"
apt-get -qq install -y --no-install-recommends 
  certbot 
  python3-certbot-nginx 
  php-cli 
  php-common 
  php-bcmath 
  php-curl 
  php-gd 
  php-imagick 
  php-mbstring 
  php-mysql 
  php-opcache 
  php-xml 
  php-zip 
  ghostscript 
  nginx 
  unit 
  unit-php 
  mariadb-server

НастройванС Π½Π° PHP Π·Π° ΠΈΠ·ΠΏΠΎΠ»Π·Π²Π°Π½Π΅ с NGINX Unit ΠΈ WordPress

Π‘ΠΊΡ€ΠΈΠΏΡ‚ΡŠΡ‚ създава Ρ„Π°ΠΉΠ» с настройки Π² дирСкторията conf.d. Π’ΠΎΠ²Π° Π·Π°Π΄Π°Π²Π° максималния Ρ€Π°Π·ΠΌΠ΅Ρ€ Π·Π° PHP качвания, Π²ΠΊΠ»ΡŽΡ‡Π²Π° ΠΈΠ·Ρ…ΠΎΠ΄Π° Π·Π° Π³Ρ€Π΅ΡˆΠΊΠ° Π½Π° PHP към STDERR, Ρ‚Π°ΠΊΠ° Ρ‡Π΅ Ρ‚Π΅ Π΄Π° Π±ΡŠΠ΄Π°Ρ‚ записани Π² рСгистрационния Ρ„Π°ΠΉΠ» Π½Π° NGINX Unit, ΠΈ рСстартира NGINX Unit.

ΠΊΠΎΠ΄ Π½Π° скрипта

# Find the major and minor PHP version so that we can write to its conf.d directory
PHP_MAJOR_MINOR_VERSION="$(php -v | head -n1 | cut -d' ' -f2 | cut -d'.' -f1,2)"

if [ ! -f "/etc/php/${PHP_MAJOR_MINOR_VERSION}/embed/conf.d/30-wordpress-overrides.ini" ]; then
  echo " Configuring PHP for use with NGINX Unit and WordPress"
  # Add PHP configuration overrides
  cat > "/etc/php/${PHP_MAJOR_MINOR_VERSION}/embed/conf.d/30-wordpress-overrides.ini" << EOM
; Set a larger maximum upload size so that WordPress can handle
; bigger media files.
upload_max_filesize=${UPLOAD_MAX_FILESIZE}
post_max_size=${UPLOAD_MAX_FILESIZE}
; Write error log to STDERR so that error messages show up in the NGINX Unit log
error_log=/dev/stderr
EOM
fi

# Restart NGINX Unit because we have reconfigured PHP
echo " Restarting NGINX Unit"
service unit restart

Π£ΠΊΠ°Π·Π²Π°Π½Π΅ Π½Π° настройкитС Π½Π° Π±Π°Π·Π°Ρ‚Π° Π΄Π°Π½Π½ΠΈ MariaDB Π·Π° WordPress

Π˜Π·Π±Ρ€Π°Ρ…ΠΌΠ΅ MariaDB ΠΏΡ€Π΅Π΄ MySQL, Ρ‚ΡŠΠΉ ΠΊΠ°Ρ‚ΠΎ ΠΈΠΌΠ° ΠΏΠΎΠ²Π΅Ρ‡Π΅ активност Π½Π° общността ΠΈ ΡΡŠΡ‰ΠΎ Π΅ вСроятно Π΄Π° ΠΈΠΌΠ° осигурява ΠΏΠΎ-Π΄ΠΎΠ±Ρ€Π° производитСлност ΠΏΠΎ ΠΏΠΎΠ΄Ρ€Π°Π·Π±ΠΈΡ€Π°Π½Π΅ (вСроятно Ρ‚ΡƒΠΊ всичко Π΅ ΠΏΠΎ-просто: Π·Π° Π΄Π° инсталиратС MySQL, трябва Π΄Π° Π΄ΠΎΠ±Π°Π²ΠΈΡ‚Π΅ Π΄Ρ€ΡƒΠ³ΠΎ Ρ…Ρ€Π°Π½ΠΈΠ»ΠΈΡ‰Π΅, ΠΏΡ€ΠΈΠ±Π». ΠΏΡ€Π΅Π²ΠΎΠ΄Π°Ρ‡).

Π‘ΠΊΡ€ΠΈΠΏΡ‚ΡŠΡ‚ създава Π½ΠΎΠ²Π° Π±Π°Π·Π° Π΄Π°Π½Π½ΠΈ ΠΈ създава ΠΈΠ΄Π΅Π½Ρ‚ΠΈΡ„ΠΈΠΊΠ°Ρ†ΠΈΠΎΠ½Π½ΠΈ Π΄Π°Π½Π½ΠΈ Π·Π° Π΄ΠΎΡΡ‚ΡŠΠΏ Π΄ΠΎ WordPress Ρ‡Ρ€Π΅Π· интСрфСйса Π·Π° ΠΎΠ±Ρ€Π°Ρ‚Π½Π° Π²Ρ€ΡŠΠ·ΠΊΠ°:

ΠΊΠΎΠ΄ Π½Π° скрипта

# Set up the WordPress database
echo " Configuring MariaDB for WordPress"
mysqladmin create wordpress || echo "Ignoring above error because database may already exist"
mysql -e "GRANT ALL PRIVILEGES ON wordpress.* TO "wordpress"@"localhost" IDENTIFIED BY "$WORDPRESS_DB_PASSWORD"; FLUSH PRIVILEGES;"

Π˜Π½ΡΡ‚Π°Π»ΠΈΡ€Π°Π½Π΅ Π½Π° ΠΏΡ€ΠΎΠ³Ρ€Π°ΠΌΠ°Ρ‚Π° WordPress CLI

На Ρ‚Π°Π·ΠΈ ΡΡ‚ΡŠΠΏΠΊΠ° ΡΠΊΡ€ΠΈΠΏΡ‚ΡŠΡ‚ инсталира ΠΏΡ€ΠΎΠ³Ρ€Π°ΠΌΠ°Ρ‚Π° WP-CLI. Π‘ Π½Π΅Π³ΠΎ ΠΌΠΎΠΆΠ΅Ρ‚Π΅ Π΄Π° инсталиратС ΠΈ управляватС настройкитС Π½Π° WordPress, Π±Π΅Π· Π΄Π° сС Π½Π°Π»Π°Π³Π° Ρ€ΡŠΡ‡Π½ΠΎ Π΄Π° Ρ€Π΅Π΄Π°ΠΊΡ‚ΠΈΡ€Π°Ρ‚Π΅ Ρ„Π°ΠΉΠ»ΠΎΠ²Π΅, Π΄Π° Π°ΠΊΡ‚ΡƒΠ°Π»ΠΈΠ·ΠΈΡ€Π°Ρ‚Π΅ Π±Π°Π·Π°Ρ‚Π° Π΄Π°Π½Π½ΠΈ ΠΈΠ»ΠΈ Π΄Π° Π²Π»ΠΈΠ·Π°Ρ‚Π΅ Π² контролния ΠΏΠ°Π½Π΅Π». МоТС ΡΡŠΡ‰ΠΎ Π΄Π° сС ΠΈΠ·ΠΏΠΎΠ»Π·Π²Π° Π·Π° инсталиранС Π½Π° Ρ‚Π΅ΠΌΠΈ ΠΈ Π΄ΠΎΠ±Π°Π²ΠΊΠΈ ΠΈ Π°ΠΊΡ‚ΡƒΠ°Π»ΠΈΠ·ΠΈΡ€Π°Π½Π΅ Π½Π° WordPress.

ΠΊΠΎΠ΄ Π½Π° скрипта

if [ ! -f /usr/local/bin/wp ]; then
  # Install the WordPress CLI
  echo " Installing the WordPress CLI tool"
  curl --retry 6 -Ls "https://github.com/wp-cli/wp-cli/releases/download/v${WORDPRESS_CLI_VERSION}/wp-cli-${WORDPRESS_CLI_VERSION}.phar" > /usr/local/bin/wp
  echo "$WORDPRESS_CLI_MD5 /usr/local/bin/wp" | md5sum -c -
  chmod +x /usr/local/bin/wp
fi

Π˜Π½ΡΡ‚Π°Π»ΠΈΡ€Π°Π½Π΅ ΠΈ ΠΊΠΎΠ½Ρ„ΠΈΠ³ΡƒΡ€ΠΈΡ€Π°Π½Π΅ Π½Π° WordPress

Π‘ΠΊΡ€ΠΈΠΏΡ‚ΡŠΡ‚ инсталира Π½Π°ΠΉ-Π½ΠΎΠ²Π°Ρ‚Π° вСрсия Π½Π° WordPress Π² дирСктория /var/www/wordpressΠΈ ΡΡŠΡ‰ΠΎ Ρ‚Π°ΠΊΠ° промСня настройкитС:

  • Π’Ρ€ΡŠΠ·ΠΊΠ°Ρ‚Π° с Π±Π°Π·Π°Ρ‚Π° Π΄Π°Π½Π½ΠΈ Ρ€Π°Π±ΠΎΡ‚ΠΈ ΠΏΡ€Π΅Π· unix Π΄ΠΎΠΌΠ΅ΠΉΠ½ сокСт вмСсто TCP ΠΏΡ€ΠΈ ΠΎΠ±Ρ€Π°Ρ‚Π½Π° Π²Ρ€ΡŠΠ·ΠΊΠ°, Π·Π° Π΄Π° Π½Π°ΠΌΠ°Π»ΠΈ TCP Ρ‚Ρ€Π°Ρ„ΠΈΠΊΠ°.
  • WordPress добавя прСфикс https:// към URL адрСса, Π°ΠΊΠΎ ΠΊΠ»ΠΈΠ΅Π½Ρ‚ΠΈΡ‚Π΅ сС ΡΠ²ΡŠΡ€Π·Π²Π°Ρ‚ с NGINX ΠΏΡ€Π΅Π· HTTPS, ΠΈ ΡΡŠΡ‰ΠΎ ΠΈΠ·ΠΏΡ€Π°Ρ‰Π° ΠΈΠΌΠ΅Ρ‚ΠΎ Π½Π° отдалСчСния хост (ΠΊΠ°ΠΊΡ‚ΠΎ Π΅ прСдоставСно ΠΎΡ‚ NGINX) към PHP. ИзползвамС част ΠΎΡ‚ ΠΊΠΎΠ΄Π°, Π·Π° Π΄Π° настроим Ρ‚ΠΎΠ²Π°.
  • WordPress сС Π½ΡƒΠΆΠ΄Π°Π΅ ΠΎΡ‚ HTTPS Π·Π° Π²Π»ΠΈΠ·Π°Π½Π΅
  • URL структурата ΠΏΠΎ ΠΏΠΎΠ΄Ρ€Π°Π·Π±ΠΈΡ€Π°Π½Π΅ сС основава Π½Π° рСсурси
  • Π—Π°Π΄Π°Π²Π° ΠΏΡ€Π°Π²ΠΈΠ»Π½ΠΈΡ‚Π΅ Ρ€Π°Π·Ρ€Π΅ΡˆΠ΅Π½ΠΈΡ Π·Π° Ρ„Π°ΠΉΠ»ΠΎΠ²Π°Ρ‚Π° систСма Π·Π° дирСкторията Π½Π° WordPress.

ΠΊΠΎΠ΄ Π½Π° скрипта

if [ ! -d /var/www/wordpress ]; then
  # Create WordPress directories
  mkdir -p /var/www/wordpress
  chown -R www-data:www-data /var/www

  # Download WordPress using the WordPress CLI
  echo " Installing WordPress"
  su -s /bin/sh -c 'wp --path=/var/www/wordpress core download' www-data

  WP_CONFIG_CREATE_CMD="wp --path=/var/www/wordpress config create --extra-php --dbname=wordpress --dbuser=wordpress --dbhost="localhost:/var/run/mysqld/mysqld.sock" --dbpass="${WORDPRESS_DB_PASSWORD}""

  # This snippet is injected into the wp-config.php file when it is created;
  # it informs WordPress that we are behind a reverse proxy and as such
  # allows it to generate links using HTTPS
  cat > /tmp/wp_forwarded_for.php << 'EOM'
/* Turn HTTPS 'on' if HTTP_X_FORWARDED_PROTO matches 'https' */
if (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && strpos($_SERVER['HTTP_X_FORWARDED_PROTO'], 'https') !== false) {
    $_SERVER['HTTPS'] = 'on';
}
if (isset($_SERVER['HTTP_X_FORWARDED_HOST'])) {
    $_SERVER['HTTP_HOST'] = $_SERVER['HTTP_X_FORWARDED_HOST'];
}
EOM

  # Create WordPress configuration
  su -s /bin/sh -p -c "cat /tmp/wp_forwarded_for.php | ${WP_CONFIG_CREATE_CMD}" www-data
  rm /tmp/wp_forwarded_for.php
  su -s /bin/sh -p -c "wp --path=/var/www/wordpress config set 'FORCE_SSL_ADMIN' 'true'" www-data

  # Install WordPress
  WP_SITE_INSTALL_CMD="wp --path=/var/www/wordpress core install --url="${WORDPRESS_URL}" --title="${WORDPRESS_SITE_TITLE}" --admin_user="${WORDPRESS_ADMIN_USER}" --admin_password="${WORDPRESS_ADMIN_PASSWORD}" --admin_email="${WORDPRESS_ADMIN_EMAIL}" --skip-email"
  su -s /bin/sh -p -c "${WP_SITE_INSTALL_CMD}" www-data

  # Set permalink structure to a sensible default that isn't in the UI
  su -s /bin/sh -p -c "wp --path=/var/www/wordpress option update permalink_structure '/%year%/%monthnum%/%postname%/'" www-data

  # Remove sample file because it is cruft and could be a security problem
  rm /var/www/wordpress/wp-config-sample.php

  # Ensure that WordPress permissions are correct
  find /var/www/wordpress -type d -exec chmod g+s {} ;
  chmod g+w /var/www/wordpress/wp-content
  chmod -R g+w /var/www/wordpress/wp-content/themes
  chmod -R g+w /var/www/wordpress/wp-content/plugins
fi

НастройванС Π½Π° ΠΌΠΎΠ΄ΡƒΠ» NGINX

Π‘ΠΊΡ€ΠΈΠΏΡ‚ΡŠΡ‚ ΠΊΠΎΠ½Ρ„ΠΈΠ³ΡƒΡ€ΠΈΡ€Π° ΠΌΠΎΠ΄ΡƒΠ»Π° NGINX Π΄Π° изпълнява PHP ΠΈ Π΄Π° ΠΎΠ±Ρ€Π°Π±ΠΎΡ‚Π²Π° WordPress ΠΏΡŠΡ‚ΠΈΡ‰Π°, ΠΊΠ°Ρ‚ΠΎ ΠΈΠ·ΠΎΠ»ΠΈΡ€Π° пространството ΠΎΡ‚ ΠΈΠΌΠ΅Π½Π° Π½Π° процСса Π½Π° PHP ΠΈ ΠΎΠΏΡ‚ΠΈΠΌΠΈΠ·ΠΈΡ€Π° настройкитС Π·Π° производитСлност. Π’ΡƒΠΊ ΠΈΠΌΠ° Ρ‚Ρ€ΠΈ Ρ„ΡƒΠ½ΠΊΡ†ΠΈΠΈ, Π½Π° ΠΊΠΎΠΈΡ‚ΠΎ трябва Π΄Π° ΠΎΠ±ΡŠΡ€Π½Π΅Ρ‚Π΅ Π²Π½ΠΈΠΌΠ°Π½ΠΈΠ΅:

  • ΠŸΠΎΠ΄Π΄Ρ€ΡŠΠΆΠΊΠ°Ρ‚Π° Π·Π° пространства ΠΎΡ‚ ΠΈΠΌΠ΅Π½Π° сС опрСдСля ΠΎΡ‚ условиС, Π±Π°Π·ΠΈΡ€Π°Π½ΠΎ Π½Π° ΠΏΡ€ΠΎΠ²Π΅Ρ€ΠΊΠ° Π΄Π°Π»ΠΈ ΡΠΊΡ€ΠΈΠΏΡ‚ΡŠΡ‚ сС изпълнява Π² ΠΊΠΎΠ½Ρ‚Π΅ΠΉΠ½Π΅Ρ€. Π’ΠΎΠ²Π° Π΅ Π½Π΅ΠΎΠ±Ρ…ΠΎΠ΄ΠΈΠΌΠΎ, Ρ‚ΡŠΠΉ ΠΊΠ°Ρ‚ΠΎ ΠΏΠΎΠ²Π΅Ρ‡Π΅Ρ‚ΠΎ настройки Π½Π° ΠΊΠΎΠ½Ρ‚Π΅ΠΉΠ½Π΅Ρ€ΠΈ Π½Π΅ ΠΏΠΎΠ΄Π΄ΡŠΡ€ΠΆΠ°Ρ‚ Π²Π»ΠΎΠΆΠ΅Π½ΠΎ стартиранС Π½Π° ΠΊΠΎΠ½Ρ‚Π΅ΠΉΠ½Π΅Ρ€ΠΈ.
  • Ако ΠΈΠΌΠ° ΠΏΠΎΠ΄Π΄Ρ€ΡŠΠΆΠΊΠ° Π·Π° пространства ΠΎΡ‚ ΠΈΠΌΠ΅Π½Π°, Π΄Π΅Π°ΠΊΡ‚ΠΈΠ²ΠΈΡ€Π°ΠΉΡ‚Π΅ пространството ΠΎΡ‚ ΠΈΠΌΠ΅Π½Π° ΠΌΡ€Π΅ΠΆΠ°. Π’ΠΎΠ²Π° позволява Π½Π° WordPress Π΄Π° сС ΡΠ²ΡŠΡ€Π·Π²Π° с Π΄Π²Π΅Ρ‚Π΅ ΠΊΡ€Π°ΠΉΠ½ΠΈ Ρ‚ΠΎΡ‡ΠΊΠΈ ΠΈ Π΄Π° бъдС Π΄ΠΎΡΡ‚ΡŠΠΏΠ΅Π½ Π² ΠΌΡ€Π΅ΠΆΠ°Ρ‚Π° Π΅Π΄Π½ΠΎΠ²Ρ€Π΅ΠΌΠ΅Π½Π½ΠΎ.
  • ΠœΠ°ΠΊΡΠΈΠΌΠ°Π»Π½ΠΈΡΡ‚ Π±Ρ€ΠΎΠΉ процСси сС опрСдСля, ΠΊΠ°ΠΊΡ‚ΠΎ слСдва: (Налична ΠΏΠ°ΠΌΠ΅Ρ‚ Π·Π° изпълнСниС Π½Π° MariaDB ΠΈ NGINX Uniy)/(ΠžΠ³Ρ€Π°Π½ΠΈΡ‡Π΅Π½ΠΈΠ΅ Π½Π° RAM Π² PHP + 5)
    Π’Π°Π·ΠΈ стойност Π΅ Π·Π°Π΄Π°Π΄Π΅Π½Π° Π² настройкитС Π½Π° NGINX Unit.

Π’Π°Π·ΠΈ стойност ΡΡŠΡ‰ΠΎ Ρ‚Π°ΠΊΠ° ΠΏΡ€Π΅Π΄ΠΏΠΎΠ»Π°Π³Π°, Ρ‡Π΅ Π²ΠΈΠ½Π°Π³ΠΈ ΠΈΠΌΠ° ΠΏΠΎΠ½Π΅ Π΄Π²Π° изпълнявани PHP процСса, ΠΊΠΎΠ΅Ρ‚ΠΎ Π΅ Π²Π°ΠΆΠ½ΠΎ, Π·Π°Ρ‰ΠΎΡ‚ΠΎ WordPress ΠΏΡ€Π°Π²ΠΈ ΠΌΠ½ΠΎΠ³ΠΎ асинхронни заявки към сСбС си ΠΈ Π±Π΅Π· Π΄ΠΎΠΏΡŠΠ»Π½ΠΈΡ‚Π΅Π»Π½ΠΈ процСси, стартиранСто, Π½Π°ΠΏΡ€ΠΈΠΌΠ΅Ρ€ Π½Π° WP-Cron, Ρ‰Π΅ сС ΠΏΠΎΠ²Ρ€Π΅Π΄ΠΈ. МоТС Π΄Π° искатС Π΄Π° ΡƒΠ²Π΅Π»ΠΈΡ‡ΠΈΡ‚Π΅ ΠΈΠ»ΠΈ Π½Π°ΠΌΠ°Π»ΠΈΡ‚Π΅ Ρ‚Π΅Π·ΠΈ ограничСния въз основа Π½Π° Π²Π°ΡˆΠΈΡ‚Π΅ Π»ΠΎΠΊΠ°Π»Π½ΠΈ настройки, Ρ‚ΡŠΠΉ ΠΊΠ°Ρ‚ΠΎ ΡΡŠΠ·Π΄Π°Π΄Π΅Π½ΠΈΡ‚Π΅ Ρ‚ΡƒΠΊ настройки са консСрвативни. ΠŸΡ€ΠΈ ΠΏΠΎΠ²Π΅Ρ‡Π΅Ρ‚ΠΎ производствСни систСми настройкитС са ΠΌΠ΅ΠΆΠ΄Ρƒ 10 ΠΈ 100.

ΠΊΠΎΠ΄ Π½Π° скрипта

if [ "${container:-unknown}" != "lxc" ] && [ "$(grep -m1 -a container=lxc /proc/1/environ | tr -d '')" == "" ]; then
  NAMESPACES='"namespaces": {
        "cgroup": true,
        "credential": true,
        "mount": true,
        "network": false,
        "pid": true,
        "uname": true
    }'
else
  NAMESPACES='"namespaces": {}'
fi

PHP_MEM_LIMIT="$(grep 'memory_limit' /etc/php/7.4/embed/php.ini | tr -d ' ' | cut -f2 -d= | numfmt --from=iec)"
AVAIL_MEM="$(grep MemAvailable /proc/meminfo | tr -d ' kB' | cut -f2 -d: | numfmt --from-unit=K)"
MAX_PHP_PROCESSES="$(echo "${AVAIL_MEM}/${PHP_MEM_LIMIT}+5" | bc)"
echo " Calculated the maximum number of PHP processes as ${MAX_PHP_PROCESSES}. You may want to tune this value due to variations in your configuration. It is not unusual to see values between 10-100 in production configurations."

echo " Configuring NGINX Unit to use PHP and WordPress"
cat > /tmp/wordpress.json << EOM
{
  "settings": {
    "http": {
      "header_read_timeout": 30,
      "body_read_timeout": 30,
      "send_timeout": 30,
      "idle_timeout": 180,
      "max_body_size": $(numfmt --from=iec ${UPLOAD_MAX_FILESIZE})
    }
  },
  "listeners": {
    "127.0.0.1:8080": {
      "pass": "routes/wordpress"
    }
  },
  "routes": {
    "wordpress": [
      {
        "match": {
          "uri": [
            "*.php",
            "*.php/*",
            "/wp-admin/"
          ]
        },
        "action": {
          "pass": "applications/wordpress/direct"
        }
      },
      {
        "action": {
          "share": "/var/www/wordpress",
          "fallback": {
            "pass": "applications/wordpress/index"
          }
        }
      }
    ]
  },
  "applications": {
    "wordpress": {
      "type": "php",
      "user": "www-data",
      "group": "www-data",
      "processes": {
        "max": ${MAX_PHP_PROCESSES},
        "spare": 1
      },
      "isolation": {
        ${NAMESPACES}
      },
      "targets": {
        "direct": {
          "root": "/var/www/wordpress/"
        },
        "index": {
          "root": "/var/www/wordpress/",
          "script": "index.php"
        }
      }
    }
  }
}
EOM

curl -X PUT --data-binary @/tmp/wordpress.json --unix-socket /run/control.unit.sock http://localhost/config

НастройванС Π½Π° NGINX

ΠšΠΎΠ½Ρ„ΠΈΠ³ΡƒΡ€ΠΈΡ€Π°Π½Π΅ Π½Π° основни настройки Π½Π° NGINX

Π‘ΠΊΡ€ΠΈΠΏΡ‚ΡŠΡ‚ създава дирСктория Π·Π° кСша Π½Π° NGINX ΠΈ слСд Ρ‚ΠΎΠ²Π° създава основния ΠΊΠΎΠ½Ρ„ΠΈΠ³ΡƒΡ€Π°Ρ†ΠΈΠΎΠ½Π΅Π½ Ρ„Π°ΠΉΠ» nginx.conf. ΠžΠ±ΡŠΡ€Π½Π΅Ρ‚Π΅ Π²Π½ΠΈΠΌΠ°Π½ΠΈΠ΅ Π½Π° броя процСси Π½Π° ΠΎΠ±Ρ€Π°Π±ΠΎΡ‚ΠΊΠ° ΠΈ настройката Π½Π° максималния Ρ€Π°Π·ΠΌΠ΅Ρ€ Π½Π° Ρ„Π°ΠΉΠ»Π° Π·Π° ΠΊΠ°Ρ‡Π²Π°Π½Π΅. Има ΡΡŠΡ‰ΠΎ Ρ€Π΅Π΄, ΠΊΠΎΠΉΡ‚ΠΎ Π²ΠΊΠ»ΡŽΡ‡Π²Π° Ρ„Π°ΠΉΠ»Π° с настройки Π·Π° компрСсиранС, Π΄Π΅Ρ„ΠΈΠ½ΠΈΡ€Π°Π½ Π² слСдващия Ρ€Π°Π·Π΄Π΅Π», послСдван ΠΎΡ‚ настройкитС Π·Π° ΠΊΠ΅ΡˆΠΈΡ€Π°Π½Π΅.

ΠΊΠΎΠ΄ Π½Π° скрипта

# Make directory for NGINX cache
mkdir -p /var/cache/nginx/proxy

echo " Configuring NGINX"
cat > ${NGINX_CONF_DIR}/nginx.conf << EOM
user nginx;
worker_processes auto;
error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;
events {
    worker_connections  1024;
}
http {
    include       ${NGINX_CONF_DIR}/mime.types;
    default_type  application/octet-stream;
    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';
    access_log  /var/log/nginx/access.log  main;
    sendfile        on;
    client_max_body_size ${UPLOAD_MAX_FILESIZE};
    keepalive_timeout  65;
    # gzip settings
    include ${NGINX_CONF_DIR}/gzip_compression.conf;
    # Cache settings
    proxy_cache_path /var/cache/nginx/proxy
        levels=1:2
        keys_zone=wp_cache:10m
        max_size=10g
        inactive=60m
        use_temp_path=off;
    include ${NGINX_CONF_DIR}/conf.d/*.conf;
}
EOM

НастройванС Π½Π° NGINX компрСсия

ΠšΠΎΠΌΠΏΡ€Π΅ΡΠΈΡ€Π°Π½Π΅Ρ‚ΠΎ Π½Π° ΡΡŠΠ΄ΡŠΡ€ΠΆΠ°Π½ΠΈΠ΅ Π² Π΄Π²ΠΈΠΆΠ΅Π½ΠΈΠ΅, ΠΏΡ€Π΅Π΄ΠΈ Π΄Π° Π³ΠΎ ΠΈΠ·ΠΏΡ€Π°Ρ‚ΠΈΡ‚Π΅ Π½Π° ΠΊΠ»ΠΈΠ΅Π½Ρ‚ΠΈ, Π΅ чудСсСн Π½Π°Ρ‡ΠΈΠ½ Π·Π° подобряванС Π½Π° СфСктивността Π½Π° сайта, Π½ΠΎ само Π°ΠΊΠΎ компрСсията Π΅ ΠΊΠΎΠ½Ρ„ΠΈΠ³ΡƒΡ€ΠΈΡ€Π°Π½Π° ΠΏΡ€Π°Π²ΠΈΠ»Π½ΠΎ. Π’ΠΎΠ·ΠΈ Ρ€Π°Π·Π΄Π΅Π» ΠΎΡ‚ скрипта сС основава Π½Π° настройкитС слСдоватСлно.

ΠΊΠΎΠ΄ Π½Π° скрипта

cat > ${NGINX_CONF_DIR}/gzip_compression.conf << 'EOM'
# Credit: https://github.com/h5bp/server-configs-nginx/
# ----------------------------------------------------------------------
# | Compression                                                        |
# ----------------------------------------------------------------------
# https://nginx.org/en/docs/http/ngx_http_gzip_module.html
# Enable gzip compression.
# Default: off
gzip on;
# Compression level (1-9).
# 5 is a perfect compromise between size and CPU usage, offering about 75%
# reduction for most ASCII files (almost identical to level 9).
# Default: 1
gzip_comp_level 6;
# Don't compress anything that's already small and unlikely to shrink much if at
# all (the default is 20 bytes, which is bad as that usually leads to larger
# files after gzipping).
# Default: 20
gzip_min_length 256;
# Compress data even for clients that are connecting to us via proxies,
# identified by the "Via" header (required for CloudFront).
# Default: off
gzip_proxied any;
# Tell proxies to cache both the gzipped and regular version of a resource
# whenever the client's Accept-Encoding capabilities header varies;
# Avoids the issue where a non-gzip capable client (which is extremely rare
# today) would display gibberish if their proxy gave them the gzipped version.
# Default: off
gzip_vary on;
# Compress all output labeled with one of the following MIME-types.
# `text/html` is always compressed by gzip module.
# Default: text/html
gzip_types
  application/atom+xml
  application/geo+json
  application/javascript
  application/x-javascript
  application/json
  application/ld+json
  application/manifest+json
  application/rdf+xml
  application/rss+xml
  application/vnd.ms-fontobject
  application/wasm
  application/x-web-app-manifest+json
  application/xhtml+xml
  application/xml
  font/eot
  font/otf
  font/ttf
  image/bmp
  image/svg+xml
  text/cache-manifest
  text/calendar
  text/css
  text/javascript
  text/markdown
  text/plain
  text/xml
  text/vcard
  text/vnd.rim.location.xloc
  text/vtt
  text/x-component
  text/x-cross-domain-policy;
EOM

НастройванС Π½Π° NGINX Π·Π° WordPress

Π‘Π»Π΅Π΄ Ρ‚ΠΎΠ²Π° ΡΠΊΡ€ΠΈΠΏΡ‚ΡŠΡ‚ създава ΠΊΠΎΠ½Ρ„ΠΈΠ³ΡƒΡ€Π°Ρ†ΠΈΠΎΠ½Π΅Π½ Ρ„Π°ΠΉΠ» Π·Π° WordPress default.conf Π² ΠΊΠ°Ρ‚Π°Π»ΠΎΠ³Π° conf.d. Π’ΠΎΠΉ Π΅ ΠΊΠΎΠ½Ρ„ΠΈΠ³ΡƒΡ€ΠΈΡ€Π°Π½ Ρ‚ΡƒΠΊ:

  • АктивиранС Π½Π° TLS сСртификати, ΠΏΠΎΠ»ΡƒΡ‡Π΅Π½ΠΈ ΠΎΡ‚ Let's Encrypt Ρ‡Ρ€Π΅Π· Certbot (настройванСто ΠΌΡƒ Ρ‰Π΅ бъдС Π² слСдващия Ρ€Π°Π·Π΄Π΅Π»)
  • ΠšΠΎΠ½Ρ„ΠΈΠ³ΡƒΡ€ΠΈΡ€Π°Π½Π΅ Π½Π° настройки Π·Π° сигурност Π½Π° TLS въз основа Π½Π° ΠΏΡ€Π΅ΠΏΠΎΡ€ΡŠΠΊΠΈ ΠΎΡ‚ Let's Encrypt
  • АктивиранС Π½Π° ΠΊΠ΅ΡˆΠΈΡ€Π°Π½Π΅ Π½Π° заявки Π·Π° пропусканС Π·Π° 1 час ΠΏΠΎ ΠΏΠΎΠ΄Ρ€Π°Π·Π±ΠΈΡ€Π°Π½Π΅
  • Π”Π΅Π°ΠΊΡ‚ΠΈΠ²ΠΈΡ€Π°ΠΉΡ‚Π΅ рСгистриранСто Π½Π° Π΄ΠΎΡΡ‚ΡŠΠΏΠ°, ΠΊΠ°ΠΊΡ‚ΠΎ ΠΈ рСгистриранСто Π½Π° Π³Ρ€Π΅ΡˆΠΊΠΈ, Π°ΠΊΠΎ Ρ„Π°ΠΉΠ»ΡŠΡ‚ Π½Π΅ Π΅ Π½Π°ΠΌΠ΅Ρ€Π΅Π½, Π·Π° Π΄Π²Π° чСсто искани Ρ„Π°ΠΉΠ»Π°: favicon.ico ΠΈ robots.txt
  • ΠŸΡ€Π΅Π΄ΠΎΡ‚Π²Ρ€Π°Ρ‚Π΅Ρ‚Π΅ Π΄ΠΎΡΡ‚ΡŠΠΏΠ° Π΄ΠΎ скрити Ρ„Π°ΠΉΠ»ΠΎΠ²Π΅ ΠΈ някои Ρ„Π°ΠΉΠ»ΠΎΠ²Π΅ . PhpΠ·Π° прСдотвратяванС Π½Π° Π½Π΅Π·Π°ΠΊΠΎΠ½Π΅Π½ Π΄ΠΎΡΡ‚ΡŠΠΏ ΠΈΠ»ΠΈ Π½Π΅Π²ΠΎΠ»Π½ΠΎ стартиранС
  • Π”Π΅Π°ΠΊΡ‚ΠΈΠ²ΠΈΡ€Π°ΠΉΡ‚Π΅ рСгистриранСто Π½Π° Π΄ΠΎΡΡ‚ΡŠΠΏ Π·Π° статични Ρ„Π°ΠΉΠ»ΠΎΠ²Π΅ ΠΈ Ρ„Π°ΠΉΠ»ΠΎΠ²Π΅ с ΡˆΡ€ΠΈΡ„Ρ‚ΠΎΠ²Π΅
  • Настройка Π½Π° Π·Π°Π³Π»Π°Π²ΠΊΠ°Ρ‚Π° Access-Control-Allow-Origin Π·Π° Ρ„Π°ΠΉΠ»ΠΎΠ²Π΅ с ΡˆΡ€ΠΈΡ„Ρ‚ΠΎΠ²Π΅
  • ДобавянС Π½Π° ΠΌΠ°Ρ€ΡˆΡ€ΡƒΡ‚ΠΈΠ·ΠΈΡ€Π°Π½Π΅ Π·Π° index.php ΠΈ Π΄Ρ€ΡƒΠ³ΠΈ статики.

ΠΊΠΎΠ΄ Π½Π° скрипта

cat > ${NGINX_CONF_DIR}/conf.d/default.conf << EOM
upstream unit_php_upstream {
    server 127.0.0.1:8080;
    keepalive 32;
}
server {
    listen 80;
    listen [::]:80;
    # ACME-challenge used by Certbot for Let's Encrypt
    location ^~ /.well-known/acme-challenge/ {
      root /var/www/certbot;
    }
    location / {
      return 301 https://${TLS_HOSTNAME}$request_uri;
    }
}
server {
    listen      443 ssl http2;
    listen [::]:443 ssl http2;
    server_name ${TLS_HOSTNAME};
    root        /var/www/wordpress/;
    # Let's Encrypt configuration
    ssl_certificate         ${CERT_DIR}/fullchain.pem;
    ssl_certificate_key     ${CERT_DIR}/privkey.pem;
    ssl_trusted_certificate ${CERT_DIR}/chain.pem;
    include ${NGINX_CONF_DIR}/options-ssl-nginx.conf;
    ssl_dhparam ${NGINX_CONF_DIR}/ssl-dhparams.pem;
    # OCSP stapling
    ssl_stapling on;
    ssl_stapling_verify on;
    # Proxy caching
    proxy_cache wp_cache;
    proxy_cache_valid 200 302 1h;
    proxy_cache_valid 404 1m;
    proxy_cache_revalidate on;
    proxy_cache_background_update on;
    proxy_cache_lock on;
    proxy_cache_use_stale error timeout http_500 http_502 http_503 http_504;
    location = /favicon.ico {
        log_not_found off;
        access_log off;
    }
    location = /robots.txt {
        allow all;
        log_not_found off;
        access_log off;
    }

    # Deny all attempts to access hidden files such as .htaccess, .htpasswd,
    # .DS_Store (Mac)
    # Keep logging the requests to parse later (or to pass to firewall utilities
    # such as fail2ban)
    location ~ /. {
        deny all;
    }
    # Deny access to any files with a .php extension in the uploads directory;
    # works in subdirectory installs and also in multi-site network.
    # Keep logging the requests to parse later (or to pass to firewall utilities
    # such as fail2ban).
    location ~* /(?:uploads|files)/.*.php$ {
        deny all;
    }
    # WordPress: deny access to wp-content, wp-includes PHP files
    location ~* ^/(?:wp-content|wp-includes)/.*.php$ {
        deny all;
    }
    # Deny public access to wp-config.php
    location ~* wp-config.php {
        deny all;
    }
    # Do not log access for static assets, media
    location ~* .(?:css(.map)?|js(.map)?|jpe?g|png|gif|ico|cur|heic|webp|tiff?|mp3|m4a|aac|ogg|midi?|wav|mp4|mov|webm|mpe?g|avi|ogv|flv|wmv)$ {
        access_log off;
    }
    location ~* .(?:svgz?|ttf|ttc|otf|eot|woff2?)$ {
        add_header Access-Control-Allow-Origin "*";
        access_log off;
    }
    location / {
        try_files $uri @index_php;
    }
    location @index_php {
        proxy_socket_keepalive on;
        proxy_http_version 1.1;
        proxy_set_header Connection "";
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
        proxy_set_header Host $host;
        proxy_pass       http://unit_php_upstream;
    }
    location ~* .php$ {
        proxy_socket_keepalive on;
        proxy_http_version 1.1;
        proxy_set_header Connection "";
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
        proxy_set_header Host $host;
        try_files        $uri =404;
        proxy_pass       http://unit_php_upstream;
    }
}
EOM

НастройванС Π½Π° Certbot Π·Π° сСртификати ΠΎΡ‚ Let's Encrypt ΠΈ Π°Π²Ρ‚ΠΎΠΌΠ°Ρ‚ΠΈΡ‡Π½ΠΎΡ‚ΠΎ ΠΈΠΌ подновяванС

Certbot Π΅ Π±Π΅Π·ΠΏΠ»Π°Ρ‚Π΅Π½ инструмСнт ΠΎΡ‚ Electronic Frontier Foundation (EFF), ΠΊΠΎΠΉΡ‚ΠΎ Π²ΠΈ позволява Π΄Π° ΠΏΠΎΠ»ΡƒΡ‡Π°Π²Π°Ρ‚Π΅ ΠΈ Π°Π²Ρ‚ΠΎΠΌΠ°Ρ‚ΠΈΡ‡Π½ΠΎ Π΄Π° подновяватС TLS сСртификати ΠΎΡ‚ Let's Encrypt. Π‘ΠΊΡ€ΠΈΠΏΡ‚ΡŠΡ‚ ΠΏΡ€Π°Π²ΠΈ слСдното, Π·Π° Π΄Π° ΠΊΠΎΠ½Ρ„ΠΈΠ³ΡƒΡ€ΠΈΡ€Π° Certbot Π΄Π° ΠΎΠ±Ρ€Π°Π±ΠΎΡ‚Π²Π° сСртификати ΠΎΡ‚ Let's Encrypt Π² NGINX:

  • Π‘ΠΏΠΈΡ€Π° NGINX
  • Π˜Π·Ρ‚Π΅Π³Π»Ρ ΠΏΡ€Π΅ΠΏΠΎΡ€ΡŠΡ‡ΠΈΡ‚Π΅Π»Π½ΠΈΡ‚Π΅ TLS настройки
  • Изпълнява Certbot, Π·Π° Π΄Π° ΠΏΠΎΠ»ΡƒΡ‡ΠΈ сСртификати Π·Π° сайта
  • РСстартира NGINX Π·Π° ΠΈΠ·ΠΏΠΎΠ»Π·Π²Π°Π½Π΅ Π½Π° сСртификати
  • ΠšΠΎΠ½Ρ„ΠΈΠ³ΡƒΡ€ΠΈΡ€Π° Certbot Π΄Π° сС изпълнява всСки Π΄Π΅Π½ Π² 3:24 сутринта, Π·Π° Π΄Π° ΠΏΡ€ΠΎΠ²Π΅Ρ€ΠΈ Π΄Π°Π»ΠΈ сСртификатитС трябва Π΄Π° Π±ΡŠΠ΄Π°Ρ‚ ΠΏΠΎΠ΄Π½ΠΎΠ²Π΅Π½ΠΈ, ΠΈ Π°ΠΊΠΎ Π΅ Π½Π΅ΠΎΠ±Ρ…ΠΎΠ΄ΠΈΠΌΠΎ, Π΄Π° ΠΈΠ·Ρ‚Π΅Π³Π»ΠΈ Π½ΠΎΠ²ΠΈ сСртификати ΠΈ Π΄Π° рСстартира NGINX.

ΠΊΠΎΠ΄ Π½Π° скрипта

echo " Stopping NGINX in order to set up Let's Encrypt"
service nginx stop

mkdir -p /var/www/certbot
chown www-data:www-data /var/www/certbot
chmod g+s /var/www/certbot

if [ ! -f ${NGINX_CONF_DIR}/options-ssl-nginx.conf ]; then
  echo " Downloading recommended TLS parameters"
  curl --retry 6 -Ls -z "Tue, 14 Apr 2020 16:36:07 GMT" 
    -o "${NGINX_CONF_DIR}/options-ssl-nginx.conf" 
    "https://raw.githubusercontent.com/certbot/certbot/master/certbot-nginx/certbot_nginx/_internal/tls_configs/options-ssl-nginx.conf" 
    || echo "Couldn't download latest options-ssl-nginx.conf"
fi

if [ ! -f ${NGINX_CONF_DIR}/ssl-dhparams.pem ]; then
  echo " Downloading recommended TLS DH parameters"
  curl --retry 6 -Ls -z "Tue, 14 Apr 2020 16:49:18 GMT" 
    -o "${NGINX_CONF_DIR}/ssl-dhparams.pem" 
    "https://raw.githubusercontent.com/certbot/certbot/master/certbot/certbot/ssl-dhparams.pem" 
    || echo "Couldn't download latest ssl-dhparams.pem"
fi

# If tls_certs_init.sh hasn't been run before, remove the self-signed certs
if [ ! -d "/etc/letsencrypt/accounts" ]; then
  echo " Removing self-signed certificates"
  rm -rf "${CERT_DIR}"
fi

if [ "" = "${LETS_ENCRYPT_STAGING:-}" ] || [ "0" = "${LETS_ENCRYPT_STAGING}" ]; then
  CERTBOT_STAGING_FLAG=""
else
  CERTBOT_STAGING_FLAG="--staging"
fi

if [ ! -f "${CERT_DIR}/fullchain.pem" ]; then
  echo " Generating certificates with Let's Encrypt"
  certbot certonly --standalone 
         -m "${WORDPRESS_ADMIN_EMAIL}" 
         ${CERTBOT_STAGING_FLAG} 
         --agree-tos --force-renewal --non-interactive 
         -d "${TLS_HOSTNAME}"
fi

echo " Starting NGINX in order to use new configuration"
service nginx start

# Write crontab for periodic Let's Encrypt cert renewal
if [ "$(crontab -l | grep -m1 'certbot renew')" == "" ]; then
  echo " Adding certbot to crontab for automatic Let's Encrypt renewal"
  (crontab -l 2>/dev/null; echo "24 3 * * * certbot renew --nginx --post-hook 'service nginx reload'") | crontab -
fi

Π”ΠΎΠΏΡŠΠ»Π½ΠΈΡ‚Π΅Π»Π½Π° пСрсонализация Π½Π° вашия сайт

Π“ΠΎΠ²ΠΎΡ€ΠΈΡ…ΠΌΠ΅ ΠΏΠΎ-Π³ΠΎΡ€Π΅ Π·Π° Ρ‚ΠΎΠ²Π° ΠΊΠ°ΠΊ Π½Π°ΡˆΠΈΡΡ‚ скрипт ΠΊΠΎΠ½Ρ„ΠΈΠ³ΡƒΡ€ΠΈΡ€Π° NGINX ΠΈ NGINX Unit Π΄Π° обслуТват Π³ΠΎΡ‚ΠΎΠ² Π·Π° производство сайт с Π°ΠΊΡ‚ΠΈΠ²ΠΈΡ€Π°Π½ TLSSSL. ΠœΠΎΠΆΠ΅Ρ‚Π΅ ΡΡŠΡ‰ΠΎ Ρ‚Π°ΠΊΠ°, Π² зависимост ΠΎΡ‚ Π²Π°ΡˆΠΈΡ‚Π΅ Π½ΡƒΠΆΠ΄ΠΈ, Π΄Π° Π΄ΠΎΠ±Π°Π²ΠΈΡ‚Π΅ Π² Π±ΡŠΠ΄Π΅Ρ‰Π΅:

  • ΠŸΠΎΠ΄ΠΊΡ€Π΅ΠΏΠ° Brotli, ΠΏΠΎΠ΄ΠΎΠ±Ρ€Π΅Π½Π° компрСсия Π² Π΄Π²ΠΈΠΆΠ΅Π½ΠΈΠ΅ ΠΏΡ€Π΅Π· HTTPS
  • ModSecurity с ΠΏΡ€Π°Π²ΠΈΠ»Π° Π·Π° wordpressΠ·Π° прСдотвратяванС Π½Π° Π°Π²Ρ‚ΠΎΠΌΠ°Ρ‚ΠΈΠ·ΠΈΡ€Π°Π½ΠΈ Π°Ρ‚Π°ΠΊΠΈ Π½Π° вашия сайт
  • Ρ€Π΅Π·Π΅Ρ€Π²Π½ΠΎ ΠΊΠΎΠΏΠΈΠ΅ Π·Π° WordPress, ΠΊΠΎΠΉΡ‚ΠΎ Π²ΠΈ ΠΏΠΎΠ΄Ρ…ΠΎΠΆΠ΄Π°
  • Π—Π°Ρ‰ΠΈΡ‚Π° ΠΏΡ€Π΅Π· AppArmor (Π½Π° Ubuntu)
  • Postfix ΠΈΠ»ΠΈ msmtp, Π·Π° Π΄Π° ΠΌΠΎΠΆΠ΅ WordPress Π΄Π° ΠΈΠ·ΠΏΡ€Π°Ρ‰Π° ΠΏΠΎΡ‰Π°
  • ΠŸΡ€ΠΎΠ²Π΅Ρ€ΠΊΠ° Π½Π° вашия сайт, Π·Π° Π΄Π° Ρ€Π°Π·Π±Π΅Ρ€Π΅Ρ‚Π΅ ΠΊΠΎΠ»ΠΊΠΎ Ρ‚Ρ€Π°Ρ„ΠΈΠΊ ΠΌΠΎΠΆΠ΅ Π΄Π° ΠΏΠΎΠ΅ΠΌΠ΅

Π—Π° ΠΎΡ‰Π΅ ΠΏΠΎ-Π΄ΠΎΠ±Ρ€Π° производитСлност Π½Π° сайта ΠΏΡ€Π΅ΠΏΠΎΡ€ΡŠΡ‡Π²Π°ΠΌΠ΅ Π΄Π° надстроитС Π΄ΠΎ NGINX Plus, Π½Π°ΡˆΠΈΡΡ‚ Ρ‚ΡŠΡ€Π³ΠΎΠ²ΡΠΊΠΈ ΠΏΡ€ΠΎΠ΄ΡƒΠΊΡ‚ ΠΎΡ‚ ΠΊΠΎΡ€ΠΏΠΎΡ€Π°Ρ‚ΠΈΠ²Π΅Π½ клас, Π±Π°Π·ΠΈΡ€Π°Π½ Π½Π° NGINX с ΠΎΡ‚Π²ΠΎΡ€Π΅Π½ ΠΊΠΎΠ΄. НСговитС Π°Π±ΠΎΠ½Π°Ρ‚ΠΈ Ρ‰Π΅ ΠΏΠΎΠ»ΡƒΡ‡Π°Ρ‚ Π΄ΠΈΠ½Π°ΠΌΠΈΡ‡Π½ΠΎ Π·Π°Ρ€Π΅Π΄Π΅Π½ ΠΌΠΎΠ΄ΡƒΠ» Brotli, ΠΊΠ°ΠΊΡ‚ΠΎ ΠΈ (срСщу Π΄ΠΎΠΏΡŠΠ»Π½ΠΈΡ‚Π΅Π»Π½ΠΎ Π·Π°ΠΏΠ»Π°Ρ‰Π°Π½Π΅) NGINX ModSecurity WAF. НиС ΡΡŠΡ‰ΠΎ ΠΏΡ€Π΅Π΄Π»Π°Π³Π°ΠΌΠ΅ NGINX App Protect, WAF ΠΌΠΎΠ΄ΡƒΠ» Π·Π° NGINX Plus, Π±Π°Π·ΠΈΡ€Π°Π½ Π½Π° Π²ΠΎΠ΄Π΅Ρ‰Π° Π² индустрията тСхнология Π·Π° сигурност ΠΎΡ‚ F5.

NB Π—Π° ΠΏΠΎΠ΄Π΄Ρ€ΡŠΠΆΠΊΠ° Π½Π° силно Π½Π°Ρ‚ΠΎΠ²Π°Ρ€Π΅Π½ сайт ΠΌΠΎΠΆΠ΅Ρ‚Π΅ Π΄Π° сС ΡΠ²ΡŠΡ€ΠΆΠ΅Ρ‚Π΅ със спСциалиститС Southbridge. НиС Ρ‰Π΅ осигурим Π±ΡŠΡ€Π·Π° ΠΈ Π½Π°Π΄Π΅ΠΆΠ΄Π½Π° Ρ€Π°Π±ΠΎΡ‚Π° Π½Π° вашия сайт ΠΈΠ»ΠΈ услуга ΠΏΡ€ΠΈ всякакви натоварвания.

Π˜Π·Ρ‚ΠΎΡ‡Π½ΠΈΠΊ: www.habr.com