master
commit
4b2e011f38
@ -0,0 +1,92 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
require('dotenv').config();
|
||||||
|
|
||||||
|
const path = require('path');
|
||||||
|
|
||||||
|
const {
|
||||||
|
SiteLog,
|
||||||
|
SiteWorker,
|
||||||
|
} = require(path.join(__dirname, '..', '..', 'lib', 'site-lib'));
|
||||||
|
|
||||||
|
module.rootPath = path.resolve(__dirname, '..', '..');
|
||||||
|
module.pkg = require(path.resolve(__dirname, '..', '..', 'package.json'));
|
||||||
|
|
||||||
|
module.config = {
|
||||||
|
environment: process.env.NODE_ENV,
|
||||||
|
root: module.rootPath,
|
||||||
|
component: { name: 'LoganSiteWorker', slug: 'logan-site-worker' },
|
||||||
|
site: require(path.join(module.rootPath, 'config', 'site')),
|
||||||
|
};
|
||||||
|
|
||||||
|
class LoganSiteWorker extends SiteWorker {
|
||||||
|
|
||||||
|
constructor (dtp) {
|
||||||
|
super(dtp, dtp.config.component);
|
||||||
|
}
|
||||||
|
|
||||||
|
async start ( ) {
|
||||||
|
await super.start();
|
||||||
|
|
||||||
|
const { LoganWorker } = await import('dtp-logan-api');
|
||||||
|
|
||||||
|
this.log.info('creating Logan worker');
|
||||||
|
this.loganWorker = new LoganWorker();
|
||||||
|
|
||||||
|
this.log.info('initializing Logan worker');
|
||||||
|
await this.loganWorker.initialize({
|
||||||
|
api: {
|
||||||
|
enabled: process.env.DTP_LOGAN === 'enabled',
|
||||||
|
key: process.env.DTP_LOGAN_API_KEY,
|
||||||
|
scheme: process.env.DTP_LOGAN_SCHEME,
|
||||||
|
host: process.env.DTP_LOGAN_HOST,
|
||||||
|
},
|
||||||
|
queue: {
|
||||||
|
enabled: true,
|
||||||
|
name: 'logan',
|
||||||
|
redis: {
|
||||||
|
host: process.env.REDIS_HOST,
|
||||||
|
port: process.env.REDIS_PORT,
|
||||||
|
username: process.env.REDIS_USERNAME, // requires Redis >= 6
|
||||||
|
password: process.env.REDIS_PASSWORD,
|
||||||
|
keyPrefix: process.env.REDIS_PREFIX,
|
||||||
|
},
|
||||||
|
defaultJobOptions: {
|
||||||
|
attempts: 3,
|
||||||
|
priority: 10,
|
||||||
|
removeOnComplete: true,
|
||||||
|
removeOnFail: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
async stop ( ) {
|
||||||
|
if (this.loganWorker) {
|
||||||
|
await this.loganWorker.close();
|
||||||
|
delete this.loganWorker;
|
||||||
|
}
|
||||||
|
await super.stop();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
(async ( ) => {
|
||||||
|
|
||||||
|
module.log = new SiteLog(module, module.config.component);
|
||||||
|
|
||||||
|
if (!process.env.DTP_LOGAN_API_KEY) {
|
||||||
|
console.log('Must define DTP_LOGAN_API_KEY environment variable to run test');
|
||||||
|
process.exit(-1);
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
module.worker = new LoganSiteWorker(module);
|
||||||
|
await module.worker.start();
|
||||||
|
|
||||||
|
module.log.info(`${module.pkg.name} v${module.pkg.version} ${module.config.component.name} started`);
|
||||||
|
} catch (error) {
|
||||||
|
module.log.error('failed to start worker', { component: module.config.component, error });
|
||||||
|
process.exit(-1);
|
||||||
|
}
|
||||||
|
|
||||||
|
})();
|
@ -1,13 +0,0 @@
|
|||||||
[program:dtp-base:newsroom]
|
|
||||||
numprocs=1
|
|
||||||
process_name=%(program_name)s_%(process_num)02d
|
|
||||||
command=/home/dtp/.nvm/versions/node/v16.13.0/bin/node --optimize_for_size --max_old_space_size=1024 --gc_interval=100 app/workers/newsroom.js
|
|
||||||
directory=/home/dtp/live/dtp-base
|
|
||||||
autostart=true
|
|
||||||
autorestart=true
|
|
||||||
startretries=3
|
|
||||||
stopsignal=INT
|
|
||||||
stderr_logfile=/var/log/dtp-base/newsroom.err.log
|
|
||||||
stdout_logfile=/var/log/dtp-base/newsroom.out.log
|
|
||||||
user=dtp
|
|
||||||
environment=HOME='/home/dtp/live/dtp-base',HTTP_BIND_PORT=30%(process_num)02d,NODE_ENV=production,LOGNAME=newsroom
|
|
@ -0,0 +1,13 @@
|
|||||||
|
[program:sites-chat]
|
||||||
|
numprocs=1
|
||||||
|
process_name=%(program_name)s_%(process_num)02d
|
||||||
|
command=/home/dtp/bin/node --optimize_for_size --max_old_space_size=1024 --gc_interval=100 app/workers/chat.js
|
||||||
|
directory=/home/dtp/live/dtp-sites
|
||||||
|
autostart=true
|
||||||
|
autorestart=true
|
||||||
|
startretries=3
|
||||||
|
stopsignal=INT
|
||||||
|
stderr_logfile=/var/log/dtp/dtp-sites-chat.err.log
|
||||||
|
stdout_logfile=/var/log/dtp/dtp-sites-chat.out.log
|
||||||
|
user=dtp
|
||||||
|
environment=HOME='/home/dtp/live/dtp-sites',NODE_ENV=production,LOGNAME=dtp-sites-chat
|
@ -1,13 +1,13 @@
|
|||||||
[program:host-services]
|
[program:sites-host-services]
|
||||||
numprocs=1
|
numprocs=1
|
||||||
process_name=%(program_name)s_%(process_num)02d
|
process_name=%(program_name)s_%(process_num)02d
|
||||||
command=/home/dtp/.nvm/versions/node/v16.13.0/bin/node --optimize_for_size --max_old_space_size=1024 --gc_interval=100 app/workers/host-services.js
|
command=/home/dtp/bin/node --optimize_for_size --max_old_space_size=1024 --gc_interval=100 app/workers/host-services.js
|
||||||
directory=/home/dtp/live/dtp-sites
|
directory=/home/dtp/live/dtp-sites
|
||||||
autostart=true
|
autostart=true
|
||||||
autorestart=true
|
autorestart=true
|
||||||
startretries=3
|
startretries=3
|
||||||
stopsignal=INT
|
stopsignal=INT
|
||||||
stderr_logfile=/var/log/dtp-sites/host-services.err.log
|
stderr_logfile=/var/log/dtp/dtp-sites-host-services.err.log
|
||||||
stdout_logfile=/var/log/dtp-sites/host-services.out.log
|
stdout_logfile=/var/log/dtp/dtp-sites-host-services.out.log
|
||||||
user=dtp
|
user=dtp
|
||||||
environment=HOME='/home/dtp/live/dtp-sites',HTTP_BIND_PORT=30%(process_num)02d,NODE_ENV=production,LOGNAME=host-services
|
environment=HOME='/home/dtp/live/dtp-sites',NODE_ENV=production,LOGNAME=dtp-sites-host-services
|
||||||
|
@ -0,0 +1,13 @@
|
|||||||
|
[program:dtp-sites:logan]
|
||||||
|
numprocs=1
|
||||||
|
process_name=%(program_name)s_%(process_num)02d
|
||||||
|
command=/home/dtp/bin/node --optimize_for_size --max_old_space_size=1024 --gc_interval=100 app/workers/logan.js
|
||||||
|
directory=/home/dtp/live/dtp-sites
|
||||||
|
autostart=true
|
||||||
|
autorestart=true
|
||||||
|
startretries=3
|
||||||
|
stopsignal=INT
|
||||||
|
stdout_logfile=/var/log/dtp/dtp-sites-logan.out.log
|
||||||
|
stderr_logfile=/var/log/dtp/dtp-sites-logan.err.log
|
||||||
|
user=dtp
|
||||||
|
environment=HOME='/home/dtp/live/dtp-sites',NODE_ENV=production,LOGNAME=dtp-sites-logan
|
@ -0,0 +1,13 @@
|
|||||||
|
[program:sites-media]
|
||||||
|
numprocs=1
|
||||||
|
process_name=%(program_name)s_%(process_num)02d
|
||||||
|
command=/home/dtp/bin/node --optimize_for_size --max_old_space_size=1024 --gc_interval=100 app/workers/media.js
|
||||||
|
directory=/home/dtp/live/dtp-sites
|
||||||
|
autostart=true
|
||||||
|
autorestart=true
|
||||||
|
startretries=3
|
||||||
|
stopsignal=INT
|
||||||
|
stderr_logfile=/var/log/dtp/dtp-sites-media.err.log
|
||||||
|
stdout_logfile=/var/log/dtp/dtp-sites-media.out.log
|
||||||
|
user=dtp
|
||||||
|
environment=HOME='/home/dtp/live/dtp-sites',NODE_ENV=production,LOGNAME=dtp-sites-media
|
@ -1,13 +1,13 @@
|
|||||||
[program:dtp-sites:newsletter]
|
[program:sites-newsletter]
|
||||||
numprocs=1
|
numprocs=1
|
||||||
process_name=%(program_name)s_%(process_num)02d
|
process_name=%(program_name)s_%(process_num)02d
|
||||||
command=/home/dtp/.nvm/versions/node/v16.13.0/bin/node --optimize_for_size --max_old_space_size=1024 --gc_interval=100 app/workers/newsletter.js
|
command=/home/dtp/bin/node --optimize_for_size --max_old_space_size=1024 --gc_interval=100 app/workers/newsletter.js
|
||||||
directory=/home/dtp/live/dtp-sites
|
directory=/home/dtp/live/dtp-sites
|
||||||
autostart=true
|
autostart=true
|
||||||
autorestart=true
|
autorestart=true
|
||||||
startretries=3
|
startretries=3
|
||||||
stopsignal=INT
|
stopsignal=INT
|
||||||
stderr_logfile=/var/log/dtp-sites/newsletter.err.log
|
stderr_logfile=/var/log/dtp/dtp-sites-newsletter.err.log
|
||||||
stdout_logfile=/var/log/dtp-sites/newsletter.out.log
|
stdout_logfile=/var/log/dtp/dtp-sites-newsletter.out.log
|
||||||
user=dtp
|
user=dtp
|
||||||
environment=HOME='/home/dtp/live/dtp-sites',HTTP_BIND_PORT=30%(process_num)02d,NODE_ENV=production,LOGNAME=sites-newsletter
|
environment=HOME='/home/dtp/live/dtp-sites',NODE_ENV=production,LOGNAME=dtp-sites-newsletter
|
@ -0,0 +1,13 @@
|
|||||||
|
[program:sites-newsroom]
|
||||||
|
numprocs=1
|
||||||
|
process_name=%(program_name)s_%(process_num)02d
|
||||||
|
command=/home/dtp/bin/node --optimize_for_size --max_old_space_size=1024 --gc_interval=100 app/workers/newsroom.js
|
||||||
|
directory=/home/dtp/live/dtp-sites
|
||||||
|
autostart=true
|
||||||
|
autorestart=true
|
||||||
|
startretries=3
|
||||||
|
stopsignal=INT
|
||||||
|
stderr_logfile=/var/log/dtp/dtp-sites-newsroom.err.log
|
||||||
|
stdout_logfile=/var/log/dtp/dtp-sites-newsroom.out.log
|
||||||
|
user=dtp
|
||||||
|
environment=HOME='/home/dtp/live/dtp-sites',NODE_ENV=production,LOGNAME=dtp-sites-newsroom
|
@ -0,0 +1,13 @@
|
|||||||
|
[program:sites-reeeper]
|
||||||
|
numprocs=1
|
||||||
|
process_name=%(program_name)s_%(process_num)02d
|
||||||
|
command=/home/dtp/bin/node --optimize_for_size --max_old_space_size=1024 --gc_interval=100 app/workers/reeeper.js
|
||||||
|
directory=/home/dtp/live/dtp-sites
|
||||||
|
autostart=true
|
||||||
|
autorestart=true
|
||||||
|
startretries=3
|
||||||
|
stopsignal=INT
|
||||||
|
stderr_logfile=/var/log/dtp/dtp-sites-reeeper.err.log
|
||||||
|
stdout_logfile=/var/log/dtp/dtp-sites-reeeper.out.log
|
||||||
|
user=dtp
|
||||||
|
environment=HOME='/home/dtp/live/dtp-sites',NODE_ENV=production,LOGNAME=dtp-sites-reeeper
|
@ -1,13 +1,13 @@
|
|||||||
[program:dtp-sites]
|
[program:sites]
|
||||||
numprocs=1
|
numprocs=2
|
||||||
process_name=%(program_name)s_%(process_num)02d
|
process_name=%(program_name)s_%(process_num)02d
|
||||||
command=/home/dtp/.nvm/versions/node/v16.13.0/bin/node --optimize_for_size --max_old_space_size=1024 --gc_interval=100 dtp-sites.js
|
command=/home/dtp/bin/node --optimize_for_size --max_old_space_size=1024 --gc_interval=100 dtp-sites.js
|
||||||
directory=/home/dtp/live/dtp-sites
|
directory=/home/dtp/live/dtp-sites
|
||||||
autostart=true
|
autostart=true
|
||||||
autorestart=true
|
autorestart=true
|
||||||
startretries=3
|
startretries=3
|
||||||
stopsignal=INT
|
stopsignal=INT
|
||||||
stderr_logfile=/var/log/dtp-sites/dtp-sites.err.log
|
stderr_logfile=/var/log/dtp/dtp-sites-%(process_num)02d.err.log
|
||||||
stdout_logfile=/var/log/dtp-sites/dtp-sites.out.log
|
stdout_logfile=/var/log/dtp/dtp-sites-%(process_num)02d.out.log
|
||||||
user=dtp
|
user=dtp
|
||||||
environment=HOME='/home/dtp/live/dtp-sites',HTTP_BIND_PORT=30%(process_num)02d,NODE_ENV=production,LOGNAME=dtp-sites
|
environment=HOME='/home/dtp/live/dtp-sites',HTTP_BIND_PORT=34%(process_num)02d,HTTPS_BIND_PORT=35%(process_num)02d,NODE_ENV=production,LOGNAME=dtp-sites
|
Loading…
Reference in new issue