This tutorial explains step by step guide (with pics) about how to install
and setup Ghost blogging script with Nginx running at frontend while
Node.js at the backend of CentOS virtual private server / vps.
As we all know that Ghost is a publishing script developed to run on Node.js, a development platform can be installed even on a low end vps and supports web server out of the box. It means basically Node.js requires no additional web server, unlike PHP. But however, in production server, using only Node.js is really not-so wise practice. And here Nginx is available for the cool action. Nginx is really a phenomenal free web server with unbelievable performance. Nginx is used for almost everything: gzip encoding, static file serving, HTTP caching, SSL handling, load balancing and spoon feeding clients.
Ghost + Nginx + Node.js = Awesome! While Node.js itself doesn’t need thirdparty web server, but you’ll need to do some advanced optimization tasks to use Node.js as production environment especially if you are targeting thousands online visitors hourly. So this is why Nginx comes in handy because it requires not-so advanced optimization and setup tasks. Well at least, many have been familiar with Nginx.
Step 2 – In order to have Ghost lives on your server, the main requirement is Node.js must be available there. So go ahead install Node.js following my previous guide.
Step 3 – Next, install Ghost on your server via this guide. The steps are clear enough but one thing to note for this tutorial: pay attention to Step 12 point 3. Do not replace port 2368 with 80. You can leave the port as it is or use common secondary web port like 81, 82, or 8080. In this guide I stay with port 2368 (default).
Also, in the host part, use 127.0.0.1.
Step 4.a. Create nginx.repo file in yum.repos.d, nano editor will come in handy:
Step 4.b. Now put these lines there:
pic:
Now save that file by hitting Control+O on your keyboard then Control+X to exit nano editor.
Step 4.c. Now install nginx using simple yum command:
pic:
Once done, you’ll see something like this:
Yayy! It’s Nginx v1.4.4.
pic:
Step 5.a. Now make a backup copy of nginx.conf file (just for in case if things gone wrong):
pic:
Step 5.b. Open up nginx.conf file using file editor:
Step 5.c. Delete everything in there and replace it with the text below:
replace 1 at worker_processes line
with the number of how many CPU your vps is allocated. You can ask your
vps provider but most providers have it written in their website. In
this example, Ramnode allows only 1 CPU access for the 128MB SSD VZ
plan, so I use 1.
Also, replace 2368 with the port you defined in your config.js file at ghost folder (example: 8080, 81, 82, etc).
Once done, hit Control+O to save then Control+X to exit editor.
Step 5.d. Now create the virtual host file for your site’s domain:
replace domain.conf with your actual domain. Example:
Step 5.e. Now put these lines of code there:
Replace domain.tld with your own domain name and its TLD. In my example it is servermomghost.com
example of mine:
Another note: you can delete these lines if you don’t want to use www. These lines force your blog to be accessible via www so you can delete it if you don’t want www.
also change /var/www at this part with actual directory where you put Ghost:
In my example it is at /var/www/ghost.
Done? Save it and exit.
Step 5.f. Finally, text your nginx configuration before running it:
If everything is ok you should see the OK message:
Step 6 – Start nginx using this command, make sure you get OK message:
pic:
pic:
Step 8 – Create a file called “starter.sh” in /var/www directory:
Step 9 – now put these lines there, save it and exit:
pic:
Step 10 – Now issue this command syntax to make sure that newly created .sh file is executable:
pic:
Step 11 – Next, you may want to fix some permissions a bit:
pic:
Step 12 – Next, create a new cron, type this command:
Step 13 – Now put this in that file:
pic
Done? Save it and exit. You’ll get a message saying “crontab: installing new crontab“:
Step 14 – Finally, go to /var/www folder:
Step 15 – then start Ghost using this command:
That’s it. Now open up your browser and try accessing your blog.
Enjoy..
As we all know that Ghost is a publishing script developed to run on Node.js, a development platform can be installed even on a low end vps and supports web server out of the box. It means basically Node.js requires no additional web server, unlike PHP. But however, in production server, using only Node.js is really not-so wise practice. And here Nginx is available for the cool action. Nginx is really a phenomenal free web server with unbelievable performance. Nginx is used for almost everything: gzip encoding, static file serving, HTTP caching, SSL handling, load balancing and spoon feeding clients.
Ghost + Nginx + Node.js = Awesome! While Node.js itself doesn’t need thirdparty web server, but you’ll need to do some advanced optimization tasks to use Node.js as production environment especially if you are targeting thousands online visitors hourly. So this is why Nginx comes in handy because it requires not-so advanced optimization and setup tasks. Well at least, many have been familiar with Nginx.
Some Ingredients..
..used in this tutorial:- A VPS running CentOS. I use CentOS 6 32-bit running on a 128MB low end VPS by RamNode (SSD OpenVZ plan). You can use 64-bit especially if your box has more than 1024MB of RAM.
- Putty or Terminal on Mac and Linux to access your server.
- Basic knowledge about common bash command to manage a Linux vps.
- A cup of coffee or tea.
The Steps
Step 1 – Open up Putty or Terminal then login to your server as root or any user with root / sudo privilege.Step 2 – In order to have Ghost lives on your server, the main requirement is Node.js must be available there. So go ahead install Node.js following my previous guide.
Step 3 – Next, install Ghost on your server via this guide. The steps are clear enough but one thing to note for this tutorial: pay attention to Step 12 point 3. Do not replace port 2368 with 80. You can leave the port as it is or use common secondary web port like 81, 82, or 8080. In this guide I stay with port 2368 (default).
Also, in the host part, use 127.0.0.1.
Install Nginx
Step 4 – Now this part we’ll try to install Nginx on CentOS. You can follow my previous guide or simply follow what I gonna tell you below.Step 4.a. Create nginx.repo file in yum.repos.d, nano editor will come in handy:
1
| nano /etc/yum .repos.d /nginx .repo |
1
2
3
4
5
| [nginx] name=nginx repo baseurl=http: //nginx .org /packages/centos/ $releasever/$basearch/ gpgcheck=0 enabled=1 |
Now save that file by hitting Control+O on your keyboard then Control+X to exit nano editor.
Step 4.c. Now install nginx using simple yum command:
1
| yum install nginx -y |
Once done, you’ll see something like this:
Yayy! It’s Nginx v1.4.4.
Configuring Nginx
Step 5 – Now go to nginx default configuration directory:
1
| cd /etc/nginx/ |
Step 5.a. Now make a backup copy of nginx.conf file (just for in case if things gone wrong):
1
| cp nginx.conf nginx.conf.bak |
Step 5.b. Open up nginx.conf file using file editor:
1
| nano nginx.conf |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
| user nginx; worker_processes 1; pid /var/run/nginx .pid; events { worker_connections 768; # multi_accept on; } http { proxy_cache_path /var/cache/nginx levels=1:2 keys_zone=one:8m max_size=3000m inactive=600m; proxy_temp_path /var/tmp ; include mime.types; default_type application /octet-stream ; sendfile on; keepalive_timeout 65; gzip on; gzip_comp_level 6; gzip_vary on; gzip_min_length 1000; gzip_proxied any; gzip_types text /plain text /css application /json application /x-javascript text /xml application /xml application /xml +rss text /javascript ; gzip_buffers 16 8k; upstream ghost_upstream { server 127.0.0.1:2368; keepalive 64; } access_log /var/log/nginx/access .log; error_log /var/log/nginx/error .log; include /etc/nginx/conf .d/*.conf; } |
Also, replace 2368 with the port you defined in your config.js file at ghost folder (example: 8080, 81, 82, etc).
Once done, hit Control+O to save then Control+X to exit editor.
Step 5.d. Now create the virtual host file for your site’s domain:
1
| nano /etc/nginx/conf .d /domain .conf |
1
| nano /etc/nginx/conf .d /servermomghost .conf |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
| server { listen 80; server_name domain.tld www.domain.tld; if ($host = 'domain.tld' ) { rewrite ^/(.*)$ http: //www .domain.tld/$1 permanent; } # location ~ ^/(ghost/signup/) { # rewrite ^/(.*)$ http://domain.tld/ permanent; # } location ~ ^/(img/|css/|lib/|vendor/|fonts/|robots.txt|humans.txt) { root /var/www/core/client/assets ; access_log off; expires max; } location ~ ^/(shared/|built/) { root /var/www/core ; access_log off; expires max; } location ~ ^/(favicon.ico) { root /var/www/core/shared ; access_log off; expires max; } location ~ ^/(content /images/ ) { root /var/www ; access_log off; expires max; } location / { proxy_redirect off; 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 $http_host; proxy_set_header X-NginX-Proxy true ; proxy_set_header Connection "" ; proxy_http_version 1.1; proxy_cache one; proxy_cache_key ghost$request_uri$scheme; proxy_pass http: //ghost_upstream ; } } |
example of mine:
Another note: you can delete these lines if you don’t want to use www. These lines force your blog to be accessible via www so you can delete it if you don’t want www.
1
2
3
| if ($host = 'domain.tld' ) { rewrite ^/(.*)$ http: //www .domain.tld/$1 permanent; } |
1
2
3
4
5
| location ~ ^/(content /images/ ) { root /var/www ; access_log off; expires max; } |
Done? Save it and exit.
Step 5.f. Finally, text your nginx configuration before running it:
1
| nginx -t |
Step 6 – Start nginx using this command, make sure you get OK message:
1
| service nginx start |
Install Forever Service
Step 7 – Now issue this command to install Forever, a service to keep Ghost alive in the background and restart it if it ever stops or crashes:
1
| npm install forever -g |
Step 8 – Create a file called “starter.sh” in /var/www directory:
1
| nano /var/www/starter .sh |
1
2
3
4
5
6
7
8
| #!/bin/sh if [ $( ps aux | grep node | grep - v grep | wc -l | tr -s "\n" ) - eq 0 ] then export PATH= /usr/local/bin :$PATH export NODE_ENV=production NODE_ENV=production forever start --sourceDir /var/www index.js >> /var/log/nodelog .txt 2>&1 fi |
Step 10 – Now issue this command syntax to make sure that newly created .sh file is executable:
1
| chmod +x /var/www/starter .sh |
Step 11 – Next, you may want to fix some permissions a bit:
1
| chown -R nginx:nginx /var/www/ |
Step 12 – Next, create a new cron, type this command:
1
| crontab -e |
1
| @reboot /var/www/starter .sh |
Done? Save it and exit. You’ll get a message saying “crontab: installing new crontab“:
Step 14 – Finally, go to /var/www folder:
1
| cd /var/www |
1
| . /starter .sh |
Enjoy..
No comments:
Post a Comment