通过 Serverless 架构构建在线广告推荐系统

Serverless 架构是一种新型的云计算架构,它可以帮助开发者构建高可用、高可扩展性的应用程序,同时也能够节省服务器成本。在这篇文章中,我们将探讨如何使用 Serverless 架构构建一个在线广告推荐系统,该系统可以帮助广告主更好地定位目标受众,提高广告投放效果。

架构设计

我们的广告推荐系统将使用 AWS Lambda、Amazon API Gateway、Amazon S3 和 Amazon DynamoDB。其中,AWS Lambda 是一种无服务器计算服务,可以在没有服务器的情况下运行代码;Amazon API Gateway 是一种服务,可以帮助开发者构建、部署和管理 API;Amazon S3 是一种对象存储服务,可以存储和检索任意类型的数据;Amazon DynamoDB 是一种非关系型数据库服务,可以存储和检索任意类型的数据。

整个系统的架构如下图所示:

在这个架构中,我们将使用 AWS Lambda 来处理请求,并将结果存储在 Amazon DynamoDB 中。我们还将使用 Amazon S3 存储广告素材,并使用 Amazon API Gateway 提供 RESTful API 接口。

数据模型设计

在开始编写代码之前,我们需要设计我们的数据模型。我们的广告推荐系统将包含三个数据模型:用户、广告和广告投放记录。

用户

用户数据模型将包含以下属性:

  • 用户 ID
  • 年龄
  • 性别
  • 地理位置
  • 兴趣标签

广告

广告数据模型将包含以下属性:

  • 广告 ID
  • 广告名称
  • 广告素材 URL
  • 广告类型
  • 广告投放位置
  • 广告投放时间段
  • 广告投放预算

广告投放记录

广告投放记录数据模型将包含以下属性:

  • 投放 ID
  • 用户 ID
  • 广告 ID
  • 投放时间
  • 投放地理位置

代码实现

创建 DynamoDB 表

首先,我们需要创建 DynamoDB 表来存储我们的数据。我们将创建三个表:users、ads 和 ad-deliveries。

----- --- - -------------------
----- -------- - --- ---------------

--------------- - ----- ------- -- -
    --- -
        ----- ----------------------
            ---------- --------
            --------------------- -
                - -------------- --------- -------------- --- -
            --
            ---------- -
                - -------------- --------- -------- ------ -
            --
            ---------------------- -
                ------------------ --
                ------------------- -
            -
        -------------

        ----- ----------------------
            ---------- ------
            --------------------- -
                - -------------- ------- -------------- --- -
            --
            ---------- -
                - -------------- ------- -------- ------ -
            --
            ---------------------- -
                ------------------ --
                ------------------- -
            -
        -------------

        ----- ----------------------
            ---------- ----------------
            --------------------- -
                - -------------- ------------- -------------- --- --
                - -------------- --------- -------------- --- --
                - -------------- ------- -------------- --- -
            --
            ---------- -
                - -------------- ------------- -------- ------ -
            --
            ----------------------- -
                -
                    ---------- ---------------
                    ---------- -
                        - -------------- --------- -------- ------ -
                    --
                    ----------- -
                        --------------- -----
                    --
                    ---------------------- -
                        ------------------ --
                        ------------------- -
                    -
                --
                -
                    ---------- -------------
                    ---------- -
                        - -------------- ------- -------- ------ -
                    --
                    ----------- -
                        --------------- -----
                    --
                    ---------------------- -
                        ------------------ --
                        ------------------- -
                    -
                -
            --
            ---------------------- -
                ------------------ --
                ------------------- -
            -
        -------------

        ------ -
            ----------- ----
            ----- ---------------------- ------- --------------
        --
    - ----- ------- -
        -------------------
        ------ -
            ----------- ----
            ----- --------------------- -------- --------
        --
    -
--

创建 Lambda 函数

接下来,我们需要创建 Lambda 函数来处理请求。我们将创建两个函数:一个用于存储用户数据,另一个用于推荐广告。

存储用户数据

----- --- - -------------------
----- -------- - --- ---------------

--------------- - ----- ------- -- -
    ----- - ------- ---- ------- --------- --------- - - -----------------------

    --- -
        ----- ------------------
            ---------- --------
            ----- -
                ------- - -- ------ --
                ---- - -- -------------- --
                ------- - -- ------ --
                --------- - -- -------- --
                ---------- - --- --------- -
            -
        -------------

        ------ -
            ----------- ----
            ----- -------------------- ---- ----- --------------
        --
    - ----- ------- -
        -------------------
        ------ -
            ----------- ----
            ----- --------------------- ------ ---- ------
        --
    -
--

推荐广告

----- --- - -------------------
----- -------- - --- ---------------

--------------- - ----- ------- -- -
    ----- - ------ - - ---------------------
    ----- - -------- - - -----------------------

    --- -
        -- --- ---- ---------
        ----- -------- - ----- ------------------
            ---------- --------
            ---- -
                ------- - -- ------ -
            -
        -------------

        ----- --------- - ---------------------------

        -- --- --- -- ---- --------- --- --------
        ----- ------- - ----- ----------------
            ---------- ------
            ---------- -----------------
            ----------------------- --------- - -----------
            ----------------- -------------------- -------------
            -------------------------- -
                ------------ - -- -------- --
                ------------- - --- --------- -
            -
        -------------

        ----- --- - ------------------------ -- -
            ------ -
                ----- ------------
                ------- --------------
                ------ ------------
            --
        ---

        -- ---- -- -------- ------
        ----- ---------- - --------------------------
        ----- ------------------
            ---------- ----------------
            ----- -
                ----------- - -- ---------- --
                ------- - -- ------ --
                ----- - -- ----------- --
                ------------- - -- --- -------------------- --
                ----------------- - -- -------- -
            -
        -------------

        ------ -
            ----------- ----
            ----- -------------------
        --
    - ----- ------- -
        -------------------
        ------ -
            ----------- ----
            ----- --------------------- ------------ -----
        --
    -
--

创建 API Gateway

最后,我们需要创建 API Gateway 来提供 RESTful API 接口。我们将创建两个资源:一个用于存储用户数据,另一个用于推荐广告。我们还将为推荐广告资源创建一个路径参数,用于指定用户 ID。

----- --- - -------------------
----- ---------- - --- -----------------

--------------- - ----- ------- -- -
    --- -
        ----- --------- - ------------------------

        -- ------ ---- --------
        ----- ------------ - ----- ---------------------------
            ---------- ----------
            --------- ------ ------------------------------------------------------------
            --------- -------
        -------------

        -- ------ ---- ---- ------
        ----- ----------------------
            ---------- ----------
            ----------- ----------------
            ----------- -------
            ------------------ ------
        -------------

        -- ------ ---- ---- -----------
        ----- ---------------------------
            ---------- ----------
            ----------- ----------------
            ----------- -------
            ---------------------- -------
            ----- ------
            ---- -----------------------------------------------------------------------
            ------------ ------ ----------------------------------------------------------
            ----------------- -
                ------------------- -------------- -------- ------- ---------- ----- ----------------------------- ------ ----- -------------------------- --------- ----- ----------------------------- ----------- ----- ------------------------------- ------------ ------ --------------------------------
            -
        -------------

        -- ------ ---- ---- ------ --------
        ----- ------------------------------
            ---------- ----------
            ----------- ----------------
            ----------- -------
            ----------- ------
            --------------- -
                ------------------- -------
            -
        -------------

        -- ------ ---- ---- ----------- --------
        ----- -----------------------------------
            ---------- ----------
            ----------- ----------------
            ----------- -------
            ----------- ------
            ------------------ -
                ------------------- ----
            -
        -------------

        -- ------ ------------- --------
        ----- -------------------- - ----- ---------------------------
            ---------- ----------
            --------- ------ ------------------------- ---------- ---------- ------ - --------------------------
            --------- ---------------
        -------------

        -- ------ ---------------------- --------
        ----- -------------------------- - ----- ---------------------------
            ---------- ----------
            --------- ------------------------
            --------- ----------
        -------------

        -- ------ -------------------------------- ------
        ----- ----------------------
            ---------- ----------
            ----------- ------------------------------
            ----------- -------
            ------------------ ------
        -------------

        -- ------ -------------------------------- -----------
        ----- ---------------------------
            ---------- ----------
            ----------- ------------------------------
            ----------- -------
            ---------------------- -------
            ----- ------
            ---- ---------------------------------------------------------------------------------------------------------------------------------------------
            ------------ ------ ----------------------------------------------------------
            ----------------- -
                ------------------- ------------------- ---------- ----------------------------- ------- --------------------
            -
        -------------

        -- ------ -------------------------------- ------ --------
        ----- ------------------------------
            ---------- ----------
            ----------- ------------------------------
            ----------- -------
            ----------- ------
            --------------- -
                ------------------- -------
            -
        -------------

        -- ------ -------------------------------- ----------- --------
        ----- -----------------------------------
            ---------- ----------
            ----------- ------------------------------
            ----------- -------
            ----------- ------
            ------------------ -
                ------------------- --------------------
            -
        -------------

        ------ -
            ----------- ----
            ----- ------------------- ------- ------- --------------
        --
    - ----- ------- -
        -------------------
        ------ -
            ----------- ----
            ----- --------------------- -------- --- ---------
        --
    -
--

总结

通过使用 Serverless 架构,我们成功地构建了一个在线广告推荐系统。该系统可以帮助广告主更好地定位目标受众,提高广告投放效果。在这个过程中,我们使用了 AWS Lambda、Amazon API Gateway、Amazon S3 和 Amazon DynamoDB,这些服务可以帮助我们构建高可用、高可扩展性的应用程序,并且可以节省服务器成本。我们还设计了数据模型,并提供了示例代码,以便读者可以更好地理解如何使用 Serverless 架构构建应用程序。

来源:JavaScript中文网 ,转载请联系管理员! 本文地址:https://www.javascriptcn.com/post/65c81b60add4f0e0ff1fb377


猜你喜欢

  • Kubernetes 优化之调度器优化

    在 Kubernetes 中,调度器是非常重要的组件之一,它负责将容器化应用程序调度到可用的节点上,以实现负载均衡和高可用性。因此,调度器的优化对于 Kubernetes 应用的性能和稳定性至关重要。

    8 个月前
  • Enzyme 测试 React 组件详解

    React 是一个非常流行的前端框架,它的组件化设计让开发者可以更加高效地构建复杂的 UI 界面。但是,如何保证这些组件的质量呢?这就需要使用测试工具来帮助我们检测代码的正确性。

    8 个月前
  • ES6 语法在 ESLint 中的使用以及遇到的常见问题

    ESLint 是一个用于检查 JavaScript 代码风格的工具,在前端开发中被广泛使用。随着 ES6 语法的普及,ESLint 也支持了 ES6 语法的检查。本文将介绍 ES6 语法在 ESLin...

    8 个月前
  • 解决 Fastify 开启 gzip 压缩出现的问题

    在前端开发中,我们经常需要在服务器端开启 gzip 压缩来提高网站的性能和加载速度。而 Fastify 是一个快速、低开销、可扩展的 Node.js web 框架,它也支持 gzip 压缩。

    8 个月前
  • ES8 中绑定类方法的正确方式

    在 JavaScript 中,类的方法是非常重要的概念。它们是面向对象编程的核心,可以让我们轻松地组织代码和数据。在 ES8 中,我们有一种新的方式来绑定类方法,这种方式可以让我们更好地控制方法的作用...

    8 个月前
  • Angular.js SPA 应用中的前端组件库实现

    随着单页应用(SPA)的流行,前端组件库的需求也越来越大。在 Angular.js 中,我们可以通过自定义指令(Directive)来实现前端组件库的开发。本文将介绍如何在 Angular.js SP...

    8 个月前
  • ECMAScript 2018 中的 Rest/Spread 属性的使用指南

    前言 ECMAScript 2018 是 JavaScript 的最新标准,其中新增了许多有用的特性和语法糖。其中,Rest/Spread 属性是一个非常实用的特性,它可以使开发者更加高效地编写代码。

    8 个月前
  • 深入 ES2020 之 Optional Chaining 怎么用?

    前言 JavaScript 是前端开发中最常用的编程语言之一,而 ES2020 是 JavaScript 的最新版本,其中引入了许多新的特性和语法糖。本文将深入探讨 ES2020 中的 Optiona...

    8 个月前
  • ES6 中的 “Map” 类型在网页监控中的应用

    在网页监控和性能优化中,我们需要对页面中的各种资源进行监控和统计,以便及时发现和解决问题。而 ES6 中的“Map”类型,提供了一种非常方便的数据结构,可以帮助我们更好地管理和统计页面中的各种资源。

    8 个月前
  • React 中使用 Redux 中间件 Logger.js 方便调试

    在前端开发中,Redux 是一种非常流行的状态管理工具,它可以帮助我们更好地管理 React 应用中的数据流。然而,在开发过程中,我们经常需要调试 Redux 中的状态变化,这时候就需要用到 Redu...

    8 个月前
  • ES10 中新增的 Array.sort 方法详解及使用示例

    在 JavaScript 中,Array.sort 方法是用于对数组进行排序的常用方法。而在 ES10 中,Array.sort 方法新增了一些特性,使得其更加强大和灵活。

    8 个月前
  • ECMAScript 2021 中的 import() 函数

    ECMAScript 2021 引入了一个新的 import() 函数,它可以在运行时动态地加载模块。这个函数的引入让前端开发者们可以更加方便地管理代码和资源,提高应用的性能和可维护性。

    8 个月前
  • webpack4 中使用 url-loader 出现 "Invalid or unexpected token" 解决方法

    在前端开发中,Webpack 是一个非常流行的模块打包器。其中 url-loader 是一个可以将静态资源如图片嵌入 JavaScript/CSS 中或者输出到文件夹的插件。

    8 个月前
  • 恰到好处的 CSS Reset - 推荐 reset.css

    在 Web 开发中,各种浏览器的默认样式会带来很多麻烦。为了解决这个问题,有许多的 CSS Reset 选项可供选择。本文推荐使用 reset.css ,它能够恰到好处地重置浏览器的默认样式。

    8 个月前
  • Deno 中如何使用 CORS 进行跨域访问?

    在前端开发中,经常会遇到跨域访问的问题。Deno 是一个新兴的 JavaScript 运行时环境,它提供了一种安全的方式来编写和运行 JavaScript 和 TypeScript。

    8 个月前
  • 使用 Server-Sent Events 和 Flask 实现发货进度的实时监测

    在日常工作中,我们经常需要对订单进行管理,特别是在物流环节中,及时掌握发货情况非常重要。本文介绍如何使用 Server-Sent Events(以下简称 SSE)和 Flask 框架快速实现订单发货进...

    8 个月前
  • 解决使用 Tailwind CSS 后样式显示不一致的问题

    Tailwind CSS 是一种流行的 CSS 框架,它可以帮助前端开发人员快速创建漂亮且一致的用户界面。然而,在实际开发中,有时候我们会遇到样式不一致的问题,这给我们带来了很多烦恼。

    8 个月前
  • PWA 使用中遇到 Web App Manifest 格式错误的解决方法

    什么是 PWA 和 Web App Manifest? PWA (Progressive Web Apps) 是一种新型的 Web 应用程序,它可以在各种设备和浏览器上提供本机应用程序的体验,并具有更...

    8 个月前
  • LESS 中如何使用 exclusion(补集) 选择器

    在CSS中,想要选取一个元素的子元素或是特定类别的元素很简单,只需使用后代选择器或者类选择器即可。但是当需要选取除了某个元素或类别以外的元素时该怎么办呢?LESS提供了一种强大而便捷的功能:exclu...

    8 个月前
  • 在 Webpack 中使用 Sass 和 Less

    Sass 和 Less 是两种常用的 CSS 预处理器,它们可以让我们编写更加简洁、易于维护的样式代码。Webpack 是现代前端开发中广泛使用的打包工具,可以让我们更高效地管理和构建项目。

    8 个月前

相关推荐

    暂无文章