DDR爱好者之家 Design By 杰米
前言
由于工作需要,设计到了阿里云的弹性计算,这里便记录下来
技术栈
- node.js
- postgresql
- nodemailer
controller + services
编写postgresql lib
不管异常还是正常都返回resolve,在resolve中处理结果,通过success字段去处理
const { Pool } = require('pg'); const config = require('../config/default.js'); const { database: { HOST, PORT, DATABASE, USERNAME, PASSWORD, }, } = config; const pool = new Pool({ port: PORT, host: HOST, user: USERNAME, password: PASSWORD, database: DATABASE, }); /** * * @param sql 接收的sql语句 * @param {Array} values sql语句参数 * @return { Object } { success: boolean, err || data } */ const query = async function( sql = 'select NOW()', values = []) { return new Promise(resolve => { pool.connect((err, client, release) => { if (err) { return console.error('Error acquiring client', err.stack) } const params = Array.isArray(values) "htmlcode">const config = { // 数据库配置 database: { DATABASE: 'databasename', USERNAME: 'root', PASSWORD: '123456', PORT: '3433', HOST: 'localhost', }, }; module.exports = config;Controller
BaseController
首先编写一个基类,用于封装一些通用的方法
const pool = require('../lib/postgre'); // 导入封装好的mysql库 const { query } = pool; // 导入query方法 class BaseController { constructor() { } // 查询表内所有数据(非删除) async list() { const sql = `select * from ${this.table}`; return await query(sql); } async excute(sql, vals = []) { // 执行方法 return await query(sql, vals); } // log 方法 log({func, err}) { console.log(`excute function[${func}] occured error : ${err.message || err}`); } } module.exports = BaseController;InqueryController
具体的业务逻辑Controller类
const BaseController = require('./BaseController'); // 获得基类 // 继承基类 class InqueryController extends BaseController { constructor() { super(); this.table = 'data_table'; // 赋值table } // 可以重写基类的方法,如果有业务需要 async list() { const sql = `select * from ${this.table} ORDER BY created_at DESC `; return await this.excute(sql); } async getUnsendCustomer(vals) { const sql = `select * from ${this.table} where created_at > $1 ORDER BY created_at DESC`; // 统一在基类调用sql参数 return await this.excute(sql, vals); } } module.exports = InqueryController;Service
BaseService
统一封装的方法,基类
// 需要绑定this的方法 const funcs = [ 'list', ] class BaseService { constructor() { this.controller = null; // 循环遍历绑定this, 在koa绑定route的时可用到 funcs.forEach(item => { this[item] = this[item].bind(this) }); } // 查询方法 async list(ctx) { if (!ctx) { return await this.controller.list(); } // controller返回的是一个对象,success(成功为true, 失败为false), data(成功则有此数据), err(失败则有此对象) const { success: flag, data, error } = await this.controller.list(); if (flag) { // success ctx.body = { data, code: 200, } } else { // failed ctx.body = { code: 500, error, }; } } } module.exports = BaseServiceInqueryService
具体的业务逻辑
// 导入基类 const BaseService = require('./BaseService'); // 导入对应的controller const Controller = require('../controller/InqueryController'); // 获取MailSender Service const MailService = require('./MailSender'); const Helper = require('../util/Helper'); const funcs = [ 'unsendUser', ]; // 生成一次controller const controller = new Controller(); class InqueryService extends BaseService { constructor() { super() // 绑定对应的controller this.controller = controller; funcs.forEach(item => { this[item] = this[item].bind(this); }); } getMailOpts(i) { // you can use the data from database to combine the message const message = 'Hello world!'; return return { message, // 可以从配置文件读取或者oss to: 'xxxx@gmail.com', subject: 'Hello World', }; } async unsendUser() { const list = await this.controller.list(); if (list.length > 0) { const mailer = new MailService(); const errorList = []; iterateList.forEach(async i => { const mailerOption = this.getMailOpts(i); const { success, ...rest } = await mailer.sendToAuitAdmin(mailerOption); if (!success) { errorList.push(rest); } }); const lastestTime = iterateList[0].created_at; if (errorList.length === 0) { return { code: 200, message: 'Success', }; } } else { return { code: 204, message: 'No user found', }; } } } module.exports = new InqueryService();index.js
函数计算的逻辑
const inqueryService = require('./services/InqueryService'); exports.handler = async function(event, context, callback) { const result = await inqueryService.unsendUser(); callback(null, result); };总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。
DDR爱好者之家 Design By 杰米
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
DDR爱好者之家 Design By 杰米
暂无评论...
更新日志
2024年11月25日
2024年11月25日
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]