Kako stvoriti Node.js RESTful API koristeći Express.js na Ubuntu 16.04 LTS

U ovom vodiču naučit ćete kako postaviti potpuni RESTful API, koji će služiti HTTP zahtjeve koristeći Node.js i Express dok ga obrnuti proxy putem NGINX-a, na Ubuntu 16.04 LTS. Koristit ćemo aplikaciju pod nazivom Postman, vrlo poznati razvojni alat API-ja, za testiranje našeg API-ja i uvjeravanje da je potpuno funkcionalan i da radi ispravno. Node.js je brzi, višeplatformski JavaScript okvir koji se temelji na Chromeovom V8 motoru. Koristi se u desktop i poslužiteljskim aplikacijama i poznat je po rukovanju petlji s jednim niti. Koristit ćemo Node.js kao pozadinu za naš RESTful API, u paketu s Express.js, našim okvirom web aplikacije izgrađenom za Node.js. Express.js je objavljen kao besplatni i otvoreni softver. Express je na strani poslužitelja, napisan u JavaScriptu i dizajniran je za izgradnju API-ja, što ga čini savršenim za naš projekt. S druge strane, Postman je vrlo moćan HTTP klijent, s razvojem API-ja na umu. Sadrži sve alate koje biste mogli poželjeti za razvoj API-ja.

Instaliranje Poštara

Prvo, želite prijeći na Postmanovu web stranicu , te preuzeti i instalirati Postman za svoje glavno računalo (ne vaš poslužitelj). Sve upute za instalaciju bit će na njihovoj web stranici.

Instaliranje Node.js

Za početak, prvo ćemo morati instalirati Node.js kako bismo mogli početi razvijati naš API. Node.js ćemo preuzeti i instalirati sa službene web stranice.

 curl -sL https://deb.nodesource.com/setup_8.x | sudo -E bash -
 sudo apt-get install -y nodejs

Osim toga, također ćete htjeti zgrabiti potrebne alate za izgradnju, koji će vam biti od pomoći pri sastavljanju modula.

sudo apt-get install build-essential

Za ovaj vodič koristit ćemo LTS verziju Node.js, a to je verzija 8.9.3.

Inicijalizacija našeg Node.js projekta

Morat ćemo inicijalizirati novi Node.js projekt, koji će sadržavati aplikaciju. Da biste to učinili, stvorite novi direktorij.

 mkdir expressapi 

Promijenite u novi imenik. Kada uđete, pokrenite npm initi ispunite sve potrebne upute. Zabilježite "ulaznu točku" vaše aplikacije: ovu ćete datoteku izraditi kasnije. Nakon što završite, vidjet ćete package.jsondatoteku u vašem trenutnom direktoriju. Djeluje kao opis našeg projekta i navodi sve ovisnosti potrebne za funkcioniranje.

Postavljanje Express.js

Sada ćemo konfigurirati Express.js i njegove ovisnosti.

npm install express

Započet će proces instalacije. Trebat će nekoliko minuta da se sve završi preuzimanje.

Pokrećemo našu glavnu datoteku

Zatim ćemo kreirati našu glavnu početnu datoteku za naš API. Ovdje ćete koristiti "ulaznu točku" koju ste vidjeli u package.jsondatoteci. Radi ovog vodiča, koristit ću zadanu shemu imenovanja, index.js.

touch index.js

Zatim ga otvorite u uređivaču teksta nano.

nano index.js

U našoj glavnoj datoteci želimo prvo pozvati sve naše glavne pakete i registrirati naše rute.

var express = require('express');        
var app = express();                 
var bodyParser = require('body-parser');
app.use(bodyParser.urlencoded({ extended: true }));
app.use(bodyParser.json());
var port = process.env.PORT || 8080;  
const router = express.Router();
router.get('/', function(req, res) {
    res.json({ message: 'API is Online!' });   
});

app.use('/api', router);
app.listen(port);
console.log('Listening on port ' + port);

U osnovi ono što ovdje radimo je inicijalizacija naše aplikacije i postavljanje osnovnog usmjerivača za naš API. Imajte na umu da smo port naše aplikacije postavili na 8080. Ovaj broj će nam trebati kada konfiguriramo naš RESTful API. Sada smo spremni krenuti naprijed i testirati naš API.

Testiranje našeg API-ja s Postmanom

U direktoriju projekta pokrenite sljedeće.

node <filename>.js

Ovo će pokrenuti API, gdje <filename>je početna datoteka koju ste naveli u package.jsondatoteci. Zatim otvorite Postman na svom PC/Mac računalu i kliknite Newgumb " " u gornjem desnom kutu, a zatim kliknite " Request". Kad ste tamo, trebali biste vidjeti traku s natpisom " GET" pored nje. Ovdje ćemo unijeti URL našeg zahtjeva. Jednostavno unesite sljedeće u odjeljak URL zahtjeva i kliknite " Send".

`http://your-server-ip:3000/api` 

Vidjet ćete " 'API is online'".

API rute

Za rukovanje rutama koristit ćemo Express usmjerivač. Ako ne znate što je usmjerivač, u biti je to kako krajnje točke aplikacije odgovaraju na zahtjeve klijenata. Evo ruta koje ćemo postaviti kao primjer:

  • /api/numbers - Prikazuje sve brojeve od 1-10.

  • /api/letters - Prikazuje sva slova od AZ.

Sada ćemo postaviti našu prvu međuprogramsku strukturu rute, ovako.

router.use(function(req, res, next) {
   console.log('We've got something.');
   next() //calls next middleware in the application.
});

router.route('/numbers/:number').get((req, res) => {
     res.json({result: req.params.number + 1})
});

U ovom primjeru postavili smo situaciju u kojoj korisnik može zatražiti zbroj broja + 1 navodeći njegov oblik riječi, koristeći metodu GET. Koristimo router.route()funkciju da pokažemo koji broj želimo poslati natrag kao rezultat. Parametri se imenuju s " :" ispred njih. Ovim parametrima pristupamo putem req.params.

Evo primjera sa slovima.

   router.route('/letters/:letter').get((req, res) => {
     res.json({result: req.params.letter.toUpperCase()})
});

Koristimo istu metodu kao gore, ali pismo šaljemo s velikim slovima.

Uvod u NGINX

NGINX je dobro poznati softver otvorenog koda koji se koristi za web posluživanje, obrnuti proxy server, streaming i još mnogo toga. Koristit ćemo NGINX za obrnuti proxy naš API, kako bi nam omogućili da ga pokrenemo na portu 80, jer Node.js ne dopušta veze na portovima manjim od 1024 bez root pristupa. Ovo može biti korisno kada povezujete svoju domenu s poslužiteljem.

Postavljanje NGINX-a

Za početak instaliranja NGINX-a morat ćete pokrenuti sljedeće u svom terminalu i pričekati da se instalacija završi.

sudo apt-get install nginx

Zatim ćemo htjeti stvoriti datoteku naše web stranice koju će NGINX koristiti za obrnuti proxy naše aplikacije.

sudo nano /etc/nginx/sites-available-api.js

Popunite datoteku sljedećim, a zatim CTRL+ Oda biste je spremili.

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:8080/;
                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;
       }
}

Koristeći isti port na kojem smo ranije pokrenuli našu aplikaciju, govorimo Nginxu da preusmjeri sve zahtjeve s naše IP adrese na portu 80na naš API koji radi na portu 8080.

Zatim omogućite obrnuti proxy simbolom povezivanja naše novostvorene datoteke s sites-availablemapom:

sudo ln -s /etc/nginx/sites-available/api /etc/nginx/sites-available

To će osigurati da će NGINX obrnuti proxy naš API.

Prvo pokretanje s NGINX-om

Nakon što završimo našu NGINX konfiguraciju, pokrenut ćemo NGINX, a zatim pokrenuti naš API. Prvo ponovno pokrenite NGINX.

sudo systemctl restart nginx

Zatim se vratite u svoj API direktorij i pokrenite ga.

node <filename>.js

Aplikacija će se pokrenuti na portu 80. Jednostavno pokrenite test odozgo s Postman-om kako biste bili sigurni da sve radi ispravno.

Održavanje rada našeg API-ja

U proizvodnom okruženju, želite biti sigurni da imate upravitelja procesa za svoje Node aplikacije, kako biste osigurali da one ostaju raditi zauvijek u pozadini. U ovom vodiču koristit ćemo upravitelj procesa pod nazivom PM2 (Process Manager 2), koji je upravitelj procesa za Node.js aplikacije koji će ih zauvijek održavati na životu s minimalnim zastojima. PM2 dolazi s mnogim korisnim alatima za upravljanje, kao što su zaustavljanje, ponovno učitavanje, pauziranje i još mnogo toga. Da biste instalirali PM2, upišite sljedeće i pričekajte da se instalira.

sudo npm install pm2 -g

Nakon što se instalira, sve što trebate učiniti je provjeriti jeste li u direktoriju projekta, upisati sljedeće i aplikacija će se pokrenuti.

pm2 start <filename>.js

Upravljanje našom aplikacijom s PM2

Kao što je ranije spomenuto, PM2 ima neke korisne alate koje možete koristiti za bolje upravljanje svojom aplikacijom.

  • pm2 stop- Kao što ime sugerira, ovo vam omogućuje da zaustavite trenutno pokrenutu aplikaciju i zaustavite njezin proces. Ako vaša aplikacija daje neočekivani rezultat, zaustavljanje će vam dobro doći.

  • pm2 list- Funkcija popisa omogućuje vam da vidite sve trenutno pokrenute aplikacije putem PM2, mapirane prema njihovim nazivima. Ako trebate brzo provjeriti vrijeme rada svoje aplikacije, trebali biste koristiti ovaj alat.

  • pm2 restart- Ako se vaša aplikacija iz nekog razloga zamrzne, a želite je ponovno učitati, pm2 restart čini upravo to. To će ubiti proces prijave i pokrenuti ga ponovno, pod drugim procesom.

  • pm2 monit- Ugrađeni alat za praćenje PM2 omogućuje vam pregled grafa specifičnih pojedinosti vaše aplikacije, kao što je korištenje CPU/RAM-a, u grafu u stilu ncurses. Ovo je korisno ako želite vizualnu sliku opterećenja vaše aplikacije.

Završne napomene

Sada smo dovršili naš zadatak stvaranja RESTful API-ja, koristeći Node.js, Express, i obrnuto proxy s NGINX-om. Slobodno proširite ovaj vodič. Sa svojim novim API-jem možete učiniti mnogo sjajnih stvari, kao što je dodavanje metoda provjere autentičnosti, baze podataka, bolje rukovanje rutama i pogreškama i još mnogo, puno više. Ako imate domenu, s "A" zapisom koji je već postavljen na vašu IP adresu, tada ćete moći pristupiti svom API-ju sa svoje domene. Ako želite saznati više o Express.js, posjetite njihovu web stranicu na http://expressjs.com . Da biste saznali više o NGINX-u i obrnutom proxy-u, posjetite http://nginx.com . Da biste pročitali više o PM2, posjetite njihovu stranicu na http://pm2.keymetrics.io .


Tri besplatne upravljačke ploče poslužitelja (brza instalacija)

Tri besplatne upravljačke ploče poslužitelja (brza instalacija)

1. Virtualmin/Webmin Virtualmin je moćna i fleksibilna upravljačka ploča za web hosting za Linux i UNIX sustave temeljena na poznatoj web bazi otvorenog koda

Postavljanje Yii aplikacije na Ubuntu 14.04

Postavljanje Yii aplikacije na Ubuntu 14.04

Yii je PHP okvir koji vam omogućuje brži i lakši razvoj aplikacija. Instalacija Yii-a na Ubuntu je jednostavna, kao što ćete naučiti točno

Upotreba Logrotate za upravljanje datotekama dnevnika

Upotreba Logrotate za upravljanje datotekama dnevnika

Uvod Logrotate je uslužni program za Linux koji pojednostavljuje administraciju datoteka dnevnika. Obično se pokreće jednom dnevno putem cron posla i upravlja bazom dnevnika

Kako instalirati Apache Cassandra 3.11.x na CentOS 7

Kako instalirati Apache Cassandra 3.11.x na CentOS 7

Korištenje drugog sustava? Apache Cassandra je besplatni i otvorenog koda NoSQL sustav upravljanja bazom podataka koji je osmišljen kako bi osigurao skalabilnost, visoku

Kako instalirati MODX Revolution na FreeBSD 11 FAMP VPS

Kako instalirati MODX Revolution na FreeBSD 11 FAMP VPS

Korištenje drugog sustava? MODX Revolution je brz, fleksibilan, skalabilan, open source, Enterprise-grade Content Management System (CMS) napisan u PHP-u. To i

Kako instalirati i konfigurirati ArangoDB na CentOS 7

Kako instalirati i konfigurirati ArangoDB na CentOS 7

Korištenje drugog sustava? Uvod ArangoDB je NoSQL baza podataka otvorenog koda s fleksibilnim modelom podataka za dokumente, grafikone i ključ-vrijednosti. to je

Postavljanje poslužitelja Half Life 2 na CentOS 6

Postavljanje poslužitelja Half Life 2 na CentOS 6

Ovaj vodič će pokriti proces instaliranja poslužitelja za igre Half Life 2 na sustavu CentOS 6. Korak 1: Instaliranje preduvjeta Kako biste postavili ou

Postavljanje Counter Strike: Source na Debianu

Postavljanje Counter Strike: Source na Debianu

U ovom vodiču postavljat ćemo poslužitelj igre Counter Strike: Source na Debianu 7. Ove su naredbe testirane na Debianu 7, ali bi također trebale raditi o

Kako instalirati Unturned 2.2.5 na Debian 8

Kako instalirati Unturned 2.2.5 na Debian 8

U ovom vodiču naučit ćete kako postaviti Unturned 2.2.5 poslužitelj na Vultr VPS s Debianom 8. Napomena: Ovo je uređena verzija Unturneda koja ne

Kako instalirati Harbor na CentOS 7

Kako instalirati Harbor na CentOS 7

Harbor je poslužitelj registra otvorenog koda poslovne klase koji pohranjuje i distribuira Docker slike. Harbor proširuje Docker Distribution otvorenog koda b

Kako instalirati OpenMeetings na CentOS 7

Kako instalirati OpenMeetings na CentOS 7

Korištenje drugog sustava? Apache OpenMeetings je aplikacija za web konferencije otvorenog koda. Napisan je na Javi i podržava više poslužitelja baze podataka. ja

Kako instalirati Cuberite na CentOS 6 ili 7 poslužitelj

Kako instalirati Cuberite na CentOS 6 ili 7 poslužitelj

Uvod Što je kuberit? Cuberite je skalabilna implementacija Minecraft poslužitelja otvorenog koda koja je napisana na C++. Ima plugi koji je jednostavan za korištenje

Kako postaviti trajne aplikacije Node.js na Ubuntu 16.04

Kako postaviti trajne aplikacije Node.js na Ubuntu 16.04

Node.js aplikacije su popularne zbog svoje sposobnosti skaliranja. Pokretanje više istovremenih procesa na više poslužitelja daje manje kašnjenje i duže vrijeme rada

Instalacija Teamspeaka na CentOS 7

Instalacija Teamspeaka na CentOS 7

Teamspeak je VOIP poslužitelj koji se može koristiti za timove/više ljudi za komunikaciju. Relativno je lagan i siguran, budući da se ažuriranja objavljuju

Izrada Jekyll bloga na CentOS 7

Izrada Jekyll bloga na CentOS 7

Korištenje drugog sustava? Jekyll je dobra alternativa WordPressu. Ne zahtijeva nikakve baze podataka i radi s jezikom koji je mnogima poznat

Korištenje datoteke Hosts za testiranje web-mjesta

Korištenje datoteke Hosts za testiranje web-mjesta

Datoteka hosts posebna je datoteka na vašem računalu radne stanice koja će pohraniti informacije o IP-u i imenu. Ova se datoteka provjerava prije DNS-a, pa ako stavite a

Kako instalirati Koel na Fedora 28

Kako instalirati Koel na Fedora 28

Korištenje drugog sustava? Koel je jednostavna web-bazirana osobna aplikacija za strujanje zvuka napisana u Vueu na strani klijenta i Laravel na strani poslužitelja. Koe

Kako instalirati aplikaciju Mailtrain Newsletter na Debian 9

Kako instalirati aplikaciju Mailtrain Newsletter na Debian 9

Korištenje drugog sustava? Mailtrain je aplikacija za bilten otvorenog koda koja se samostalno hostira i izgrađena na Node.js i MySQL/MariaDB. Izvor Mailtrains je na GitHubu. ti

Instaliranje Akauntinga na Fedora 28

Instaliranje Akauntinga na Fedora 28

Korištenje drugog sustava? Akaunting je besplatan računovodstveni softver otvorenog koda i online računovodstveni softver dizajniran za male tvrtke i slobodnjake. Izgrađen je duhovito

Kako instalirati MODX Revolution na CentOS 7 LAMP VPS

Kako instalirati MODX Revolution na CentOS 7 LAMP VPS

Korištenje drugog sustava? MODX Revolution je brz, fleksibilan, skalabilan, besplatan i otvorenog koda, Enterprise-grade Content Management System (CMS) napisan i

Uspon strojeva: primjene AI u stvarnom svijetu

Uspon strojeva: primjene AI u stvarnom svijetu

Umjetna inteligencija nije u budućnosti, ovdje je upravo u sadašnjosti. U ovom blogu Pročitajte kako su aplikacije umjetne inteligencije utjecale na različite sektore.

DDOS napadi: kratak pregled

DDOS napadi: kratak pregled

Jeste li i vi žrtva DDOS napada i zbunjeni ste metodama prevencije? Pročitajte ovaj članak kako biste riješili svoje upite.

Jeste li se ikada zapitali kako hakeri zarađuju novac?

Jeste li se ikada zapitali kako hakeri zarađuju novac?

Možda ste čuli da hakeri zarađuju mnogo novca, ali jeste li se ikada zapitali kako zarađuju toliki novac? raspravimo.

Revolucionarni Googleovi izumi koji će vam olakšati život.

Revolucionarni Googleovi izumi koji će vam olakšati život.

Želite li vidjeti revolucionarne izume Googlea i kako su ti izumi promijenili život svakog čovjeka danas? Zatim čitajte na blogu kako biste vidjeli Googleove izume.

Friday Essential: Što se dogodilo s automobilima s umjetnom inteligencijom?

Friday Essential: Što se dogodilo s automobilima s umjetnom inteligencijom?

Koncept samovozećih automobila koji će krenuti na ceste uz pomoć umjetne inteligencije san je koji već neko vrijeme imamo. No, unatoč nekoliko obećanja, nigdje ih nema. Pročitajte ovaj blog kako biste saznali više…

Tehnološka singularnost: daleka budućnost ljudske civilizacije?

Tehnološka singularnost: daleka budućnost ljudske civilizacije?

Kako se znanost razvija velikom brzinom, preuzimajući mnoge naše napore, raste i rizik da se podvrgnemo neobjašnjivoj Singularnosti. Pročitajte što bi za nas mogla značiti singularnost.

Evolucija pohrane podataka – Infografika

Evolucija pohrane podataka – Infografika

Metode pohrane podataka su se razvijale možda od rođenja podataka. Ovaj blog pokriva evoluciju pohrane podataka na temelju infografike.

Funkcionalnosti slojeva referentne arhitekture velikih podataka

Funkcionalnosti slojeva referentne arhitekture velikih podataka

Pročitajte blog kako biste na najjednostavniji način upoznali različite slojeve u arhitekturi velikih podataka i njihove funkcionalnosti.

6 nevjerojatnih prednosti posjedovanja pametnih kućnih uređaja u našim životima

6 nevjerojatnih prednosti posjedovanja pametnih kućnih uređaja u našim životima

U ovom digitalnom svijetu, pametni kućni uređaji postali su ključni dio života. Evo nekoliko nevjerojatnih prednosti pametnih kućnih uređaja o tome kako naš život čine vrijednim življenja i jednostavnijim.

Ažuriranje dodataka macOS Catalina 10.15.4 uzrokuje više problema nego što ih rješava

Ažuriranje dodataka macOS Catalina 10.15.4 uzrokuje više problema nego što ih rješava

Nedavno je Apple izdao macOS Catalina 10.15.4 dodatak ažuriranju kako bi riješio probleme, ali čini se da ažuriranje uzrokuje više problema koji dovode do zalijevanja mac strojeva. Pročitajte ovaj članak da biste saznali više