Инсталирайте Lets Encrypt SSL в приложението WordPress с едно щракване
Въведение Lets Encrypt е услуга на сертифициращ орган, която предлага безплатни TLS/SSL сертификати. Процесът на инсталиране е опростен от Certbot,
Hapi.js е богата, здрава и мощна рамка на Node.js, предназначена за изграждане на уеб приложения в екосистемата на Node.js. Неговият прост дизайн го прави лесен за започване. Hapi използва много от най-новите функции на JavaScript ES6 в основата си, като обещанията на ES6. За тези от вас, които са използвали Express преди, Hapi ви позволява да опитате нещо ново и да изпитате всички най-нови функции на JavaScript.
В този урок нашата цел ще бъде да настроим основна уеб страница на Hapi.js, която се хоства от нашия Vultr VPS, на Ubuntu 16.04 LTS. За тези, които имат домейн за своя сайт, ние ще използваме обратен прокси, за да свържем нашия домейн с нашия уебсайт. И накрая, ще се научим как да го управляваме с мениджър на процеси. Сега, след като извадихме това, нека започваме.
Ще трябва да инсталираме Node.js. За да направите това на Ubuntu 16.04 LTS, следвайте тези инструкции.
Ще трябва да добавим хранилището на NodeSource APT, което съдържа най-новата LTS версия на Node.js.
curl -sL https://deb.nodesource.com/setup_8.x | sudo -E bash -
sudo apt-get install -y nodejs
Изтегляме скрипт, който ще използваме, за да добавим хранилището към нашия списък с източници, както и да инсталираме Node.js от хранилището на NodeSource.
В допълнение към инсталирането на самия Node.js, ние също ще трябва да инсталираме някои необходими инструменти за изграждане, които ще помогнат при изграждането на всички модули, които може да се наложи да инсталираме.
sudo apt-get install -y build-essential
Това просто изтегля и инсталира инструментите за изграждане от хранилището.
Добра практика е да посочим папка, която ще използваме за нашето приложение, която ще съдържа всички данни на нашето приложение, като конфигурационни файлове и скриптове за стартиране. Създайте папка, като я наименувате както искате. В името на този урок, предполагам, че сте го кръстили site
.
mkdir site
След като сте направили папката, сега можем да се променим в нея. Уверете се, че сте в директорията, която току-що създадохте, стартирайте съветника за NPM пакети.
npm init
Той ще ви помоли да въведете няколко различни неща, като името на вашето приложение, стартов файл, лиценз и т.н. Повечето полета можете да оставите по подразбиране, с изключение на по-очевидните полета, като името на вашето приложение. В крайна сметка ще изглежда така:
{
"name": "site",
"version": "1.0.0",
"description": "Hapi.js site",
"main": "index.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"author": "rich",
"license": "MIT"
}
След като сте доволни от резултата, щракнете, за ENTERда запазите файла.
След като вашата директория е създадена успешно, можем да продължим да инсталираме Hapi.js. Както споменахме по-горе, ние ще използваме NPM за изтегляне на Hapi.js, както и неговите зависимости, за нашия проект. В директорията на проекта изпълнете следното.
npm install hapi.js
Това изтегля Hapi.js от NPM и го инсталира в директорията на нашите проекти. В същото изпълнение всички зависимости, на които Hapi.js може да разчита, също се изтеглят за наше удобство.
Сега е време да настроим нашето основно приложение Hapi.js файл. Това ще съдържа целия ни код за приложението. По-нататък по пътя можем да разширим кода на нашето приложение и да добавим още неща към него, както сметнем за добре.
След това ще създадем нашия стартов файл. Обърнете се към main
секцията на вашия package.json
файл, за да определите как точно да наименувате файла. Тъй като използвах схемата за именуване по подразбиране, нашият файл ще се нарича index.js
.
nano index.js
След като сте вътре в нано текстовия редактор, създайте базовия си код на приложение, така.
const Hapi=require('hapi');
const server=Hapi.server({
host:'localhost',
port: 3000
});
server.route({
method:'GET',
path:'/',
handler:((request,h)) => {
return 'Sample Hapi.js Application';
}
});
async function start() {
try {
await server.start();
} catch (err) {
console.log(err);
process.exit(1);
}
console.log(`Our server is running! ${server.info.uri}`);
};
start();
Първо импортираме модула Hapi. След това инициализираме нашия сървърен конструктор, който съдържа хоста, на който искаме да стартираме сървъра, както и порта, който е 3000
за този урок. След това настройваме основен рутер, който показва, че всеки път, когато някой посети сайта, ще бъде посрещнат с просто съобщение. В допълнение към всичко, имаме функция за асинхрон, за да стартираме нашия сървър, който ще влезе в конзолата, която работи нашия сървър. Когато приключите, запазете и затворете файла ( CTRL+ X)
Сега, когато основният ни файл е настроен, ние сме готови да стартираме нашето приложение.
node index.js
Ако видите " Our server is running!
" в конзолата, значи сървърът стартира успешно.
Тъй като Nginx е наличен в хранилищата на Ubuntu по подразбиране, инсталацията е лесна. Просто актуализирайте списъците си с пакети и го инсталирайте.
sudo apt update
sudo apt install nginx -y
След опресняване на списъците с пакети, Nginx и неговите зависимости ще бъдат инсталирани.
За да може Nginx да обърне прокси нашето приложение, ще трябва да създадем конфигурационен файл. Този конфигурационен файл ще съдържа информация за нашето приложение, което Nginx ще използва за обратния прокси.
Изтрийте конфигурацията по подразбиране, създадена от Nginx, тъй като по-късно ще я заменим със собствена.
sudo rm /etc/nginx/sites-enabled/default
Направете нов файл в sites-available
папката. Що се отнася до именуването, можем да се придържаме към просто site
, за простота.
sudo nano /etc/nginx/sites-available/site
Във файла поставете следното и запазете.
server {
listen 80;
location / {
proxy_set_header X-Real-IP
$remote_addr;
proxy_set_header
X-Forwarded-For
$proxy_add_x_forwarded_for;
proxy_set_header Host
$http_host;
proxy_set_header
X-NginX-Proxy true; proxy_pass
http://127.0.0.1:3000/;
proxy_redirect off;
proxy_http_version 1.1;
proxy_set_header Upgrade
$http_upgrade;
proxy_set_header Connection
"upgrade";
proxy_redirect off;
proxy_set_header
X-Forwarded-Proto $scheme;
}
}
В този файл казваме на Nginx да слуша порт 80
. Ние също така задаваме прокси преминаването към localhost
адреса и порта 3000
, който е същият порт като нашето приложение Hapi.
Сега можете да се върнете обратно до директорията на приложението си и да стартирате сайта. След като сайтът стартира, просто отидете до http://yourdomain.com
или http://yourip
и ще видите текста „ Hello World
“.
PM2 може да бъде намерен в хранилището на NPM и можете да го инсталирате глобално, за да бъде достъпен отвсякъде, така.
sudo npm install pm2 -g
На -g
знамето в края показва, че ние искаме да инсталирате модула в папката глобални модули, което ще ни позволи да го използва извън нашия проект директория. Това се използва, за да може нашият проект да се държи като нормално системно приложение.
След като инсталирате PM2, отидете обратно до директорията на вашия проект. Синтаксисът за стартиране на нашето приложение сега ще бъде малко по-различен. Ето как ще го направим с PM2.
pm2 start index.js --name site
Ние използваме стартовата функция PM2, която основно създава профил за нашето приложение под името site
. След като изпълните тази команда, вашият уебсайт ще стартира, но ще забележите, че регистрационните файлове няма да се покажат. Това е така, защото начинът, по който виждаме регистрационните файлове сега, е различен.
pm2 logs site
Можете дори да посочите колко реда регистрационни файлове искате да видите с --lines
аргумента.
Успешно сте настроили уеб сървър на Hapi.js, проксихте го обратно с Nginx и научихте как да го управлявате по-добре с PM2. С тези знания можете допълнително да разширите този урок и да направите много напреднало приложение Hapi.js. За да научите повече за възможностите на Hapi, посетете тяхната официална документация . Ако искате да научите повече за възможностите на PM2, вижте тяхното кратко ръководство .
Въведение Lets Encrypt е услуга на сертифициращ орган, която предлага безплатни TLS/SSL сертификати. Процесът на инсталиране е опростен от Certbot,
Използване на различна система? Ако закупите сървър на Debian, винаги трябва да имате най-новите корекции за сигурност и актуализации, независимо дали спите или не
PHP и свързаните с него пакети са най-често използваните компоненти при разгръщане на уеб сървър. В тази статия ще научим как да настроим PHP 7.0 или PHP 7.1 o
Squid е популярна, безплатна програма за Linux, която ви позволява да създадете уеб прокси за препращане. В това ръководство ще видите как да инсталирате Squid на CentOS, за да ви обърне
Въведение Lighttpd е форк на Apache, чиято цел е да бъде много по-малко ресурсоемка. Той е лек, откъдето идва и името му, и е доста лесен за използване. Инсталирайте
1. Virtualmin/Webmin Virtualmin е мощен и гъвкав контролен панел за уеб хостинг за Linux и UNIX системи, базиран на добре познатата уеб база с отворен код
Yii е PHP рамка, която ви позволява да разработвате приложения по-бързо и лесно. Инсталирането на Yii в Ubuntu е лесно, както ще научите точно l
Този урок обяснява как да настроите DNS сървър с помощта на Bind9 на Debian или Ubuntu. В цялата статия заменете your-domain-name.com съответно. При th
Въведение Logrotate е помощна програма за Linux, която опростява администрирането на лог файлове. Обикновено се изпълнява веднъж на ден чрез cron задание и управлява базата от регистрационни файлове
Icinga2 е мощна система за наблюдение и когато се използва в модел главен-клиент, тя може да замени необходимостта от проверки на базата на NRPE. Главният клиент
Използване на различна система? Red5 е медиен сървър с отворен код, внедрен в Java, който ви позволява да стартирате Flash многопотребителски приложения, като например предаване на живо
В тази статия ще видим как да компилирате и инсталирате основната линия на Nginx от официалните източници на Nginx с модула PageSpeed, който ви позволява да
Използване на различна система? Apache Cassandra е безплатна система за управление на база данни NoSQL с отворен код, която е проектирана да осигури мащабируемост, висока
Използване на различна система? Vanilla forum е приложение за форум с отворен код, написано на PHP. Той е напълно адаптивен, лесен за използване и поддържа външен
Използване на различна система? Въведение Kanboard е безплатна програма за управление на проекти с отворен код, която е предназначена да улеснява и визуализира
Използване на различна система? Въведение Kanboard е безплатна програма за управление на проекти с отворен код, която е предназначена да улеснява и визуализира
Използване на различна система? Gitea е алтернатива с отворен код, самостоятелно хоствана система за контрол на версиите, задвижвана от Git. Gitea е написана на Голанг и е
Използване на различна система? Gitea е алтернатива с отворен код, самостоятелно хоствана система за контрол на версиите, задвижвана от git. Gitea е написана на Голанг и е
Въведение Lynis е безплатен инструмент за одит на системата с отворен код, който се използва от много системни администратори за проверка на целостта и заздравяване на техните системи. аз
Използване на различна система? Thelia е инструмент с отворен код за създаване на уебсайтове за е-бизнес и управление на онлайн съдържание, написано на PHP. Изходен код на Thelia i
Изкуственият интелект не е в бъдещето, тук е точно в настоящето. В този блог Прочетете как приложенията за изкуствен интелект са повлияли на различни сектори.
Вие също сте жертва на DDOS атаки и сте объркани относно методите за превенция? Прочетете тази статия, за да разрешите вашите запитвания.
Може би сте чували, че хакерите печелят много пари, но чудили ли сте се някога как печелят такива пари? нека обсъдим.
Искате ли да видите революционни изобретения на Google и как тези изобретения промениха живота на всяко човешко същество днес? След това прочетете в блога, за да видите изобретенията на Google.
Концепцията за самоуправляващи се автомобили да тръгват по пътищата с помощта на изкуствен интелект е мечта, която имаме от известно време. Но въпреки няколкото обещания, те не се виждат никъде. Прочетете този блог, за да научите повече…
Тъй като науката се развива с бързи темпове, поемайки много от нашите усилия, рискът да се подложим на необяснима сингулярност също нараства. Прочетете какво може да означава сингулярността за нас.
Методите за съхранение на данните може да се развиват от раждането на данните. Този блог обхваща развитието на съхранението на данни на базата на инфографика.
Прочетете блога, за да разберете различни слоеве в архитектурата на големи данни и техните функционалности по най-простия начин.
В този дигитално задвижван свят устройствата за интелигентен дом се превърнаха в решаваща част от живота. Ето няколко невероятни предимства на интелигентните домашни устройства за това как те правят живота ни струващ и по-опростен.
Наскоро Apple пусна macOS Catalina 10.15.4 допълнителна актуализация за отстраняване на проблеми, но изглежда, че актуализацията причинява повече проблеми, водещи до блокиране на mac машини. Прочетете тази статия, за да научите повече