Skip to content

Commit

Permalink
Merge pull request #465 from delight09/doc_VPS_fullfill_systemd-and-p…
Browse files Browse the repository at this point in the history
…assenger

Docs VPS.md fullfill - systemd and mod_passenger
  • Loading branch information
matt swanson authored Nov 30, 2017
2 parents 37880b2 + ebea85a commit 0a5cbb5
Showing 1 changed file with 71 additions and 0 deletions.
71 changes: 71 additions & 0 deletions docs/VPS.md
Original file line number Diff line number Diff line change
Expand Up @@ -113,6 +113,30 @@ add the lines
PATH=/home/stringer/.rbenv/bin:/bin/:/usr/bin:/usr/local/bin/:/usr/local/sbin
*/10 * * * * source $HOME/.bash_profile; cd $HOME/stringer/; bundle exec rake fetch_feeds;

Manage Stringer With Systemd
============================

You may want to manage Stringer as a systemd service on distributions come with systemd.

As stringer user, export app service files with foreman:

cd ~/stringer
mkdir systemd-services
foreman export systemd systemd-services -a stringer -u stringer

Logout stringer user, install systemd services:

sudo cp -a ~stringer/stringer/systemd-services/* /etc/systemd/system

As stringer user, close existing Stringer instance:

exit # exit racksh and app

Start app as a systemd service and make app run at startup

sudo systemctl start stringer.target
sudo systemctl enable stringer.target

Reverse Proxy With Nginx
========================

Expand All @@ -135,3 +159,50 @@ server {
}
}
```

Deploy Stringer With Passenger And Apache
=========================================

You may want to run Stringer with the existing Apache server. We need to install
*mod_passenger* and edit few files.

The installation of *mod_passenger* depends on VPS's system distribution release.
Offical installation guide is available at [Passenger Library](https://www.phusionpassenger.com/library/install/apache/install/oss/)

After validating the *mod_passenger* install, we will fetch dependencies again
to meet Passenger's default GEM_HOME set. As stringer user:

cd ~/stringer
bundle install --path vendor/bundle

Edit database.yml with correct database url:

cd ~/stringer
sed -i "s|url: .*|url: $DATABASE_URL|" config/database.yml

Add VirtualHost to your Apache installation, here's a sample configuration:

```bash
<VirtualHost *:80>
ServerName example.com
DocumentRoot /home/stringer/stringer/app/public

PassengerEnabled On
PassengerAppRoot /home/stringer/stringer
PassengerRuby /home/stringer/.rbenv/shims/ruby
# PassengerLogFile /dev/null # don't flow logs to apache error.log

<Directory /home/stringer/stringer/app/public>
Options FollowSymLinks
Require all granted
AllowOverride All
</Directory>


# you can harden your connection with https, don't forget
# change to <VirtualHost *:443>
# SSLCertificateFile /etc/path/to/example.com/fullchain.pem
# SSLCertificateKeyFile /etc/path/to/example.com/privkey.pem
# Include /etc/path/to/options-ssl-apache.conf
</VirtualHost>
```

0 comments on commit 0a5cbb5

Please sign in to comment.