Ovaj članak će vas provesti kroz implementaciju vaše Meteor aplikacije na Vultr VPS koji radi na Ubuntu 14.04. Može raditi i na drugim distribucijama Linuxa (pokušajte na vlastitu odgovornost).
Genijalni kolega po imenu Arunoda Susiripala, koji je prilično aktivan u Meteor zajednici, razvio je alat za implementaciju pod nazivom mupx (skraćeno od "Meteor Up X"), koji čini iznimno lakim postavljanje vaše Meteor aplikacije na udaljeni poslužitelj putem ssh-a. Mupx je nasljednik mupa. Provest ćemo vas kroz proces od početka do kraja. Mup obavlja većinu teškog dizanja, na sreću, pa će ovo biti povjetarac!
Naš prvi korak je instalirati mupx. To ćete učiniti na svojoj razvojnoj radnoj stanici, a ne na VPS poslužitelju! Provjerite jeste li već instalirali Node.js i pokrenite:
$ npm install -g mupx
Nakon dovršetka instalacije idite u mapu vašeg Meteor projekta, npr. /projects/myApp, i pokrenite sljedeće naredbe:
$ mkdir .deploy
$ cd $_
$ mupx init
Za one koji nisu upoznati sa $_sintaksom, to je prečac za posljednji argument koji se koristi u naredbi. Dakle, u ovom slučaju, cd $_izvršava se kao cd .deploy.
Vidjet ćete sljedeći izlaz:
Meteor Up: Production Quality Meteor Deployments
------------------------------------------------
Configuration file : mup.json
Settings file : settings.json
Empty Project Initialized!
Proces inicijalizacije stvara dvije datoteke mup.jsoni settings.json. Posljednju ćemo datoteku sada ostaviti na miru. Samo naprijed i otvori se mup.json. U trenutku pisanja ovog članka, zadana postavka mup.jsonizgleda ovako:
{
// Server authentication info
"servers": [
{
"host": "hostname",
"username": "root",
"password": "password",
// or pem file (ssh based authentication)
// WARNING: Keys protected by a passphrase are not supported
//"pem": "~/.ssh/id_rsa"
// Also, for non-standard ssh port use this
//"sshOptions": { "port" : 49154 },
// server specific environment variables
"env": {}
}
],
// Install MongoDB on the server. Does not destroy the local MongoDB on future setups
"setupMongo": true,
// Application name (no spaces).
"appName": "meteor",
// Location of app (local directory). This can reference '~' as the users home directory.
// i.e., "app": "~/Meteor/my-app",
// This is the same as the line below.
"app": "/path/to/the/app",
// Configure environment
// ROOT_URL must be set to your correct domain (https or http)
"env": {
"PORT": 80,
"ROOT_URL": "http://myapp.com"
},
// Meteor Up checks if the app comes online just after the deployment.
// Before mup checks that, it will wait for the number of seconds configured below.
"deployCheckWaitTime": 15,
// show a progress bar while uploading.
// Make it false when you deploy using a CI box.
"enableUploadProgressBar": true
}
Moramo promijeniti nekoliko stvari kako bi proces postavljanja funkcionirao.
Najprije obavezno postavite hostsvoju VPS IP adresu, na primjer:
"host": "123.123.123.123",
Ako trebate koristiti broj priključka koji nije zadani 22, to možete učiniti pomoću sshOptionspolja, na primjer:
"host": "123.123.123.123",
"sshOptions": { "port": 9876 },
Postavite usernamevrijednost bilo kojem korisniku kojem želite posjedovati instalaciju vaše Meteor aplikacije. Preporučujem da uklonite redak lozinke i umjesto toga koristite SSH ključ, iz sigurnosnih razloga. Odkomentirajte redak s pemvrijednošću i provjerite pokazuje li vaš SSH tajni ključ koji odgovara SSH javnom ključu koji ste instalirali na svoj VPS (u /root/.ssh/authorized_keys). Obavezno dodajte zarez nakon retka lozinke! Ako vaš SSH ključ ima pridruženu šifru, u pempotpunosti uklonite redak i provjerite je li vaš SSH privatni ključ predmemoran u ssh agentu (npr. na Macu, ssh-add <path to ssh private key>).
Ostavite setupMongopostavljenu na zadanu vrijednost.
Promijenite appNamenaziv svoje aplikacije Meteor. u našem slučaju:
"appName": "myApp",
... i postavite i lokaciju aplikacije u odnosu na ovu mapu za implementaciju:
"app": "..",
Na kraju, postavite ROOT_URLna određeni URL za svoju aplikaciju. Eksplicitno postavite broj porta na standardni HTTP port.
// Configure environment
"env": {
"ROOT_URL": "http://myapp.com",
"PORT": 80
},
To je to! Spremite mup.jsondatoteku, a zatim pokrenite:
$ mupx setup
U ovom trenutku mupx će ssh u vaš VPS, instalirati Docker, postaviti okruženje i povući odgovarajuće Docker slike. Sada implementirajte svoju aplikaciju:
$ mupx deploy
Sada ako odete na http://123.123.123.123, vaša će se aplikacija prikazati kada se stranica učita.
Podrška za više jezgri
Ako vaš VPS ima više jezgri, vaša aplikacija Meteor to može iskoristiti. Samo ćemo morati napraviti nekoliko brzih podešavanja.
Prvo ćete morati instalirati cluster paket. Idite u mapu svoje aplikacije Meteor (u ovom primjeru, /projects/myApp) i upišite:
$ meteor add meteorhacks:cluster
Sada uredite svoju mup.jsondatoteku i izmijenite odjeljak varijable okruženja na sljedeći način:
// Configure environment
"env": {
"ROOT_URL": "http://myapp.com",
"PORT": 80,
"CLUSTER_WORKERS_COUNT": "auto"
},
Budući da smo vašoj aplikaciji dodali novi paket, morat ćete ga ponovno implementirati.
$ mupx setup && mupx deploy
Ako ikada poželite promijeniti svoje varijable okruženja mup.jsonbez potrebe za implementacijom cijele aplikacije, jednostavno upotrijebite naredbu reconfigure. Ovo je korisno kada nije bilo promjena u aplikaciji.
$ mupx reconfig
Čestitamo, vaša aplikacija Meteor sada radi! Također, vaša će se aplikacija automatski pokrenuti svaki put kada se vaš VPS ponovo pokrene. Pripazite na buduće članke o postavljanju i upravljanju Meteorom.