Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/linhntaim/render-man
A middle man, also a module and an application, wants to render your SPA on the server.
https://github.com/linhntaim/render-man
application manager node node-js nodejs prerender prerender-io render seo server spa
Last synced: 3 days ago
JSON representation
A middle man, also a module and an application, wants to render your SPA on the server.
- Host: GitHub
- URL: https://github.com/linhntaim/render-man
- Owner: linhntaim
- License: mit
- Created: 2019-12-08T15:54:55.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2023-01-08T22:39:39.000Z (about 2 years ago)
- Last Synced: 2024-04-24T16:59:04.367Z (9 months ago)
- Topics: application, manager, node, node-js, nodejs, prerender, prerender-io, render, seo, server, spa
- Language: JavaScript
- Homepage:
- Size: 850 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# render-man
A middle man, also a module and an application, wants to render your SPA on the server.
## 1. As a module
### 1.1. Install
```shell script
npm install render-man
```
### 1.2. UsageCreate a `.js` file (such as `server.js`) with the following basic content:
```javascript
// server.jsconst {parseEnv} = require('dotenv-packed')
const RenderServerManager = require('render-man')parseEnv()
RenderServerManager.start()
```... then run it:
```shell script
node server.js
```*Note: As default, [Google Chrome](https://www.google.com/linuxrepositories/) is required to run. Please install it first.*
### 1.3. Configuration
Create an `.env` file along with application script (`server.js`) and make some configurations on it.
See [3. Configuration](#3-configuration) for environment variables that can be set.
## 2. As an application
### 2.1. The Google Chrome
Install [Google Chrome](https://www.google.com/linuxrepositories/).
### 2.2. The Application
Here are things to guide you to install on Ubuntu.
#### 2.2.1. Make the application run
- Clone and prepare the application:
```shell script
# Clone the application to /var/www/render-man
cd /var/www
git clone https://github.com/linhntaim/render-man.git render-man# Go install modules and create a folder for logging
cd render-man
npm install
mkdir logs
```- Copy and edit the environment variables files (`.env`). (*See [3. Configuration](#3-configuration) for more detail about what you should modify any value*)
```shell script
cp .env.example .env
vi .env
```- Install the `supervisor` and use it to handle the application's running.
```shell script
# Install supervisor
npm update && apt install supervisor -y# Create a configuration to run the application with supervisor
cat > /etc/supervisor/conf.d/render-man.conf
[program:render-man]
process_name=%(program_name)s_%(process_num)02d
directory=/var/www/render-man
command=npm start
autostart=true
autorestart=true
numprocs=1
environment=NODE_ENV=production
stderr_logfile=/var/www/render-man/logs/err.log
stdout_logfile=/var/www/render-man/logs/out.log
^Z# Update the configuration so supervisor can recognize it
supervisorctl reread
supervisorctl update# Start the application
supervisorctl start render-man:*
```- Now, the application is running. If troubles happen, try those commands:
```shell script
# Restart the application
supervisorctl restart render-man:*# Or if you want to stop first,
supervisorctl stop render-man:*
# ... then make some changes ...
# ... And finally, start it again.
supervisorctl start render-man:*
```- Do not forget to check the log files at where you have configured in `supervisor`.
```shell script
/var/www/render-man/logs/err.log
/var/www/render-man/logs/out.log
```#### 2.2.2. Use NGINX as a proxy server to the application:
- Firstly, make a NGINX configuration file such as `render-man.conf` (in folder `etc/nginx`):
```
index index.html;location / {
try_files $uri @renderman;
}location @renderman {
set $renderman 0;
if ($http_user_agent ~* "googlebot|bingbot|bingpreview|yandex|baiduspider|twitterbot|facebookexternalhit|rogerbot|linkedinbot|embedly|quora link preview|showyoubot|outbrain|pinterest\/0\.|pinterestbot|slackbot|vkShare|W3C_Validator|whatsapp") {
set $renderman 1;
}
if ($args ~ "_escaped_fragment_") {
set $renderman 1;
}
if ($http_user_agent ~ "Prerender") {
set $renderman 0;
}
if ($uri ~* "\.(js|css|xml|less|png|jpg|jpeg|gif|pdf|doc|txt|ico|rss|zip|mp3|rar|exe|wmv|doc|avi|ppt|mpg|mpeg|tif|wav|mov|psd|ai|xls|mp4|m4a|swf|dat|dmg|iso|flv|m4v|torrent|ttf|woff|svg|eot)") {
set $renderman 0;
}if ($renderman = 1) {
set $port 3000; # Port to run the application, set in .env file
set $renderman "localhost:${port}";
rewrite .* /$scheme://$host$request_uri? break;
proxy_pass http://$renderman;
}
if ($renderman = 0) {
rewrite .* /index.html?$query_string break;
}
}
```- Secondly, just include the configuration in some domain's settings:
```
server {
listen 443 ssl http2;
listen [::]:443 ssl http2;server_name render-man.com www.render-man.com;
include ssl.conf;
root /var/www/render-man;
include render-man.conf; # Render-Man configuration
}
```- Visit your site to check if the application works (remember to append the url by `?_render_man_=1`):
```
https://render-man.com?_render_man_=1
```## 3. Configuration
You can make some configuration via `.env` file.
*View [`.env.example`](https://github.com/linhntaim/render-man/blob/master/.env.example) file for example.*
- **`PORT`**
- Port for the application to run
- Default: `3000`.
- **`LOG_REQUESTS`**- See [`logRequests`](https://github.com/renderman/renderman#logrequests).
- Default: `false`.
- **`PAGE_DONE_CHECK_INTERVAL`**- See [`pageDoneCheckInterval`](https://github.com/renderman/renderman#pagedonecheckinterval).
- Default: `1000`.
- **`PAGE_LOAD_TIMEOUT`**- See [`pageLoadTimeout`](https://github.com/renderman/renderman#pageloadtimeout).
- Default: `20000`.
- **`WAIT_AFTER_LAST_REQUEST`**- See [`waitAfterLastRequest`](https://github.com/renderman/renderman#waitafterlastrequest).
- Default: `500`.
- **`FOLLOW_REDIRECTS`**- See [`followredirects`](https://github.com/renderman/renderman#followRedirects).
- Default: `false`.
- **`CHROME_LOCATION`**- See [`chromeLocation`](https://github.com/renderman/renderman#chromelocation).
- Default: ``.
- **`CHROME_FLAGS`**- Run Google Chrome with some options.
- Each option should be wrapped by double quotes (`"`) and separated by the comma (`,`). All should lie inside brackets (`[...]`).
- Example: `CHROME_FLAGS=["--no-sandbox","--headless"]`
- If there are no options, please leave it as blank inside brackets.
- Example: `CHROME_FLAGS=[]`.
- Default: `["--no-sandbox","--headless","--disable-gpu"]`.- **`USE_PLUGINS`**
- Plugins can be used:
- `basicAuth`
- See [`basicAuth`](https://github.com/renderman/renderman#basicauth).
- Extra environment variables can be added in `.env` files: `BASIC_AUTH_USERNAME`, `BASIC_AUTH_PASSWORD`.
- `removeScriptTags`
- See [`removeScriptTags`](https://github.com/renderman/renderman#removescripttags).
- `blockedResources`
- `httpHeaders`
- See [`httpHeaders`](https://github.com/renderman/renderman#httpheaders).
- `whitelist`
- See [`whitelist`](https://github.com/renderman/renderman#whitelist).
- `blacklist`
- See [`blacklist`](https://github.com/renderman/renderman#blacklist).
- `in-memory-cache`
- See [`in-memory-cache`](https://github.com/renderman/renderman#in-memory-cache).
- Each plugin should be wrapped by double quotes (`"`) and separated by the comma (`,`). All should lie inside brackets (`[...]`).
- Example: `USE_PLUGINS=["removeScriptTags","blockedResources,"httpHeaders"]`
- If there are no plugins, please leave it as blank inside brackets.
- Example: `USE_PLUGINS=[]`.
- Default: `[]`.