V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
爱意满满的作品展示区。
1156909789
V2EX  ›  分享创造

利用 yajs 云函数,不到 50 行代码实现基金变动提醒

  •  
  •   1156909789 ·
    mtnbgx · 2023-10-25 16:46:44 +08:00 · 2346 次点击
    这是一个创建于 437 天前的主题,其中的信息可能已经有所发展或是发生改变。

    第一步 直接新建 fund.ts 编写

    import axios from 'axios'
    import type { FUNCAPP, FUNCCTX } from '../context'
    const ctx: FUNCCTX = _CTX
    const app: FUNCAPP = _APP
    
    // 基金代码
    const code = '012414'
    //企业微信 api
    const qyApi = 'https://qyapi.weixin.qq.com/cgi-bin/webhook/send?key=xxx'
    
    // http 访问时输出
    export const main = async () => {
        const { name, price, ratio } = await getFundData(code)
        return { data: { fund: { name, price, ratio } } }
    }
    
    // cron 定时任务执行方法
    export const cron = async () => {
        console.log('cron start')
        const { name, price, ratio } = await getFundData(code)
        if (ratio < -0.2 || ratio > 2) {
            await axios.post(qyApi, {
                "msgtype": "text",
                "text": {
                    "content": `请注意${name}基金变动`
                }
            })
        }
    }
    
    const getFundData = async (code: string) => {
        const str: string = await axios.get(`http://hqf.stock.sohu.com/kfund/${code}_6.up`)
            .then(res => res.data)
        //剔除 fortune_hq( );
        const jsonStr = str.substring(11).slice(0, -3).replace(/\'/g, '"')
        const data = JSON.parse(jsonStr)
        const name = data.price[1]
        const price = parseFloat(data.price[2])
        const ratio = parseFloat(data.price[3])
        const result = { name, price, ratio }
        // 可以 db 保存起来
        // await ctx.redis.setex(dayjs().format('YYYY-MM-DD') + '-' + code, 7200, JSON.stringify(result))
        // await ctx.knex('fund').insert(result) //先得创建表
        return result
    }
    

    第二步:修改配置文件的 token 和 cron

    exports.config = {
        default: {
            project: "test",
            token: "123456",
            url: "http://127.0.0.1:3000",
            secret: {},
            crons: [
                { label: 'fund', name: 'fund', cron: '0 40 14 * * *' }
            ]
        }
    }
    

    第三步:部署

    yajs -n fund
    yajs --cron
    

    完成搞定,撒花

    相关代码已上传 github

    https://github.com/mtnbgx/yajs-example

    https://github.com/mtnbgx/yajs

    Yajs 是一个自运行的云函数开源框架,运行内存小于 100m ,适合各种 serverless 、云开发退坑后替代

    10 条回复    2023-10-26 00:18:08 +08:00
    kkk9
        1
    kkk9  
       2023-10-25 16:52:57 +08:00   ❤️ 1
    看是推广框架放心了,😅
    8863824
        2
    8863824  
       2023-10-25 16:58:09 +08:00
    还行,我目前也有类似需求,不过都是直接用 pm2 管理的。
    不过要是能直接提供云服务,然后 git 一提交能自动跑就爽了
    gongquanlin
        3
    gongquanlin  
       2023-10-25 17:00:11 +08:00
    @8863824 云函数、laf.dev 、vercel 都满足你的需求呀
    1156909789
        4
    1156909789  
    OP
       2023-10-25 17:03:17 +08:00
    @8863824 可以的,但是需要自己配置一下 Jenkins 之类的工具,代码提交后运行 yajs -p 发布全部函数
    1156909789
        5
    1156909789  
    OP
       2023-10-25 17:04:19 +08:00
    @gongquanlin 提供一个轻量自托管的解决方案而已,看需求选择咯
    whileFalse
        6
    whileFalse  
       2023-10-25 17:11:44 +08:00 via Android
    个人自建云函数是闲得慌么,用 cron 就完了
    8863824
        7
    8863824  
       2023-10-25 19:45:00 +08:00
    @gongquanlin 你说的这种是托管网站的吧。我想要的偏这种定时任务一点,最好是可以有个监控面板
    wzblog
        8
    wzblog  
       2023-10-25 19:47:42 +08:00
    可以的,还会继续完善项目吗?已 star
    1156909789
        9
    1156909789  
    OP
       2023-10-25 20:00:34 +08:00
    @wzblog 会的,我自己也要用
    gongquanlin
        10
    gongquanlin  
       2023-10-26 00:18:08 +08:00
    @8863824 那就是青龙面板了
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2666 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 05:43 · PVG 13:43 · LAX 21:43 · JFK 00:43
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.