社区/学习指南/云开发 Serverless 极简入门手册

三个小案例

案例 1:文章阅读数服务

我们搭建自己的博客、或者个人网站,往往需要统计服务。统计服务分为两种,一种是类似百度、友盟的统计,可以根据数据来看 PV/UV 或者人群画像。但是有时候也需要展示每一篇文章的阅读数给“读者”看。阅读统计服务既可以服务后者的,也可以服务自己。
可以参考 serverless 实践:打造自己的阅读计数组件 这篇文章。

统计单篇文章/单个页面的阅读计数

核心代码如下:

"use strict";
const tcb = require("tcb-admin-node");
const app = tcb.init({
  env: "你的环境 ID",
});
const db = app.database();
const _ = db.command;

exports.main = async (event, context) => {
  let coll = "read_count";
  let path = decodeURIComponent(event.queryStringParameters.path || "");
  let host = decodeURIComponent(event.queryStringParameters.host || "");

  if (!path && !host) {
    return {
      status: 0,
      info: "必须传入 host 和 path 参数",
    };
  }
  let data = await db
    .collection(coll)
    .where({
      host: host,
      path: path,
    })
    .limit(1)
    .get();

  //更新
  if (data.data.length) {
    let doc_id = data.data[0]._id;
    await db
      .collection(coll)
      .doc(doc_id)
      .update({
        count: _.inc(1),
      });
    let obj = await db.collection(coll).doc(doc_id).get();
    return {
      status: 1,
      count: obj.data[0].count,
    };
  }
  //增加
  else {
    let o = await db.collection(coll).add({
      host: host,
      path: path,
      count: 1,
    });
    return {
      status: 1,
      count: 1,
    };
  }
};

如果自己不想开发和搭建,但是想使用现成的服务,可以参考阅读 https://github.com/serverless80/tongji,已经部署为独立服务了。

案例 2:大学之巅小程序

2018 年,开发了一款小程序名叫「大学之巅」,里面包含 2600 + 所高校数据;2019 年将小程序数据库改造成了「小程序云开发」,当然目前还有些图片是存在 OSS 上,没有搬迁。可以扫码体验 。

小程序效果如下:

当然,这个小程序的数据开源了,在 https://github.com/vczero/serverless-colleage。有了数据,再使用云开发造一个小程序见识很 easy 的事了。

案例 3: 个人相册小程序

有很多美好的回忆,有很多重要的图片,图片管理难很棘手。手机一年换一部,图片传输费劲还经常丢失。经常提示空间不足,删了一遍又一遍。于是开发了一款小程序:小小收藏夹,用来管理自己需要收藏的私人图片。可以扫描体验:

小程序效果如下:

代码已经开源,请参考:https://github.com/vczero/CloudPhoto

结语

拥抱 Serverless,拥抱云开发吧,用时代的生产力,去做一些有趣的事情......

本文出自 王利华