微服務商城(1)開篇、服務劃分

參考:https://mp.weixin.qq.com/s?__biz=Mzg2ODU1MTI0OA==&mid=2247485597&idx=1&sn=7e85894b7847cc50df51d66092792453&scene=21#wechat_redirect

為什么選擇go-zero

go-zero 為我們提供了許多高并發場景下的實用工具,比如為了降低接口耗時我們往往需要并發的請求依賴的服務,這個時候我們可以使用 mapreduce 并行的處理請求;面對海量請求為了降低Redis壓力和提高響應時間,我們可以使用 collection 構建本地緩存;避免用戶連續請求造成服務壓力可以使用 limit 做用戶級別的限流等等。好的框架能夠給我的項目開發帶來事半功倍的效果,Go-zero的簡潔易用性與內置的開箱即用的工具和服務治理能力助力我們構建一個高并發高可靠的系統。

產品需求

在這里插入圖片描述
比較核心的功能點,比如請求量非常高的首頁Banner我們如何優化,搶購商品如何保證不超賣,交易過程中分布式事務的實現等我們都會重點介紹。
以及后邊我自己添加整合的ES加速搜索、客服中心、AI推薦等等。

服務劃分

  • 商家服務(shop) - 商家的注冊、登錄

  • 商品服務(product) - 商品的添加、信息查詢、庫存管理等功能

  • 購物車服務(cart) - 購物車的增刪改查

  • 訂單服務(order) - 生成訂單,訂單管理

  • 支付服務(pay) - 通過調用第三方支付實現支付功能

  • 賬號服務(user) - 用戶信息、等級、封禁、地址管理

  • 推薦服務(recommend) - 首頁商品推薦、ES商品搜索、AI商品詢問推薦

  • 評論服務(reply) - 商品的評論功能、評論的回復功能

  • 客服服務(Customer Service) - 用戶與店鋪客服溝通、店鋪創建群聊
    在這里插入圖片描述
    在每個服務目錄下我們又會分為多個服務,主要會有如下幾類服務:

  • api - 對外的BFF服務,接受來自客戶端的請求,暴露HTTP接口

  • rpc - 對內的微服務,僅接受來自內部其他微服務或者BFF的請求,暴露gRPC接口

  • rmq - 負責進行流式任務處理,上游一般依賴消息隊列,比如kafka等

  • admin - 也是對內的服務,區別于rpc,更多的是面向運營側的且數據權限較高,通過隔離可帶來更好的代碼級別的安全,直接提供HTTP接口

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/82991.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/82991.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/82991.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

《隱私計算:數據安全與隱私保護的新希望》

一、引言 在數字化時代,數據已成為企業和組織的核心資產。然而,數據的收集、存儲和使用過程中面臨著諸多隱私和安全挑戰。隱私計算作為一種新興技術,旨在解決數據隱私保護和數據共享之間的矛盾。本文將深入探討隱私計算的基本概念、技術原理、…

MySQL 學習(九)bin log 與 redo log 的區別有哪些,為什么快速恢復使用 redo log 而不用 bin log?

目錄 一、bin log 與 redo log 的區別1)實現方式不同:2)日志內容不同:3)記錄方式不同:4)使用場合不同: 二、為什么快速恢復使用 redo log 而不用 bin log? 面試題&#x…

用Array.from實現創建一個1-100的數組

一、代碼實現 let arr Array.from({length: 100}, (_, i) > i 1); 二、代碼分析 1、Array.from(arrayLike, mapFn) (1)arrayLike 類數組對象(如 { length: 100 })本身沒有索引屬性(如 0: undefined, 1: undefi…

javaScript簡單版

簡介 JavaScript(簡稱:JS)是一門跨平臺、面向對象的腳本語言,是用來控制網頁行為,實現頁面的交互效果。 JavaScript和Java是完全不同的語言,不論是概念還是設計。但是基礎語法類似。 組成: ECMAScript:規定了JS基礎語法核心知…

Python刷題練習

文章目錄 1.尋找相同字串2.密鑰格式化3.五鍵鍵盤的輸出4.單詞重量5.輸出指定字母在字符串的中的索引6.污染水域7.九宮格按鍵輸入8.任務最優調度9.高效的任務規劃 1.尋找相同字串 題目描述: 給你兩個字符串t和p,要求從t中找到一個和p相同的連續子串,并輸…

MATLAB實現振幅調制(AM調制信號)

AM調制是通信專業非常重要的一個知識點。今天我們使用MATLAB編程實現AM調制。 我們實現輸入一個載波信號的頻率與調制信號的頻率后,再輸入調幅度,得到已調信號的波形與包絡信號的波形,再使用FFT算法分析出已調信號的頻譜圖。 源代碼&#x…

JJJ:linux ida

文章目錄 1.總結2.各類函數2.1 分配一個倉庫2.2 銷毀倉庫2.3 從倉庫里面分配一個整數id2.4 將上面分配的整數id從倉庫里面刪除2.5 在指定范圍內分配一個id 1.總結 ida使用起來很簡單,就是先分配一個倉庫一樣的實例,再從這個倉庫里面分配一個獨一無二的整…

FastByteArrayOutputStream和ByteArrayInputStream有什么區別

FastByteArrayOutputStream 和 ByteArrayInputStream 是兩種完全不同的 Java I/O 類,它們的主要區別體現在 設計目的 和 使用場景 上。以下是詳細對比: 1. 核心區別總結 特性FastByteArrayOutputStream (Spring框架)ByteArrayInputStream (JDK原生)所屬…

docker-compose——安裝redis

文章目錄 一、編寫docker-compose.yaml文件二、編寫redis.conf文件三、啟動docker-compose 一、編寫docker-compose.yaml文件 version: 3.3 services:redis:image: redis:latestcontainer_name: redisrestart: alwaysports:- 6379:6379volumes:- ./redis/data:/data- ./redis/…

東芝推出新的SCiB模塊,散熱性能加倍,適用于電動公交車、電動船舶和固定應用

東京—東芝公司推出了一種新的SCiB模塊,這是一種專為電動汽車、電動船舶和固定應用而設計的鋰離子電池。新產品采用鋁制底板,散熱量約為當前模塊的兩倍。它將于2025年4月中旬在日本和全球上市。 鋰離子電池的使用越來越多,而且越來越多樣化&a…

【進程控制二】進程替換和bash解釋器

【進程控制二】進程替換 1.exec系列接口2.execl系列2.1execl接口2.2execlp接口2.3execle 3.execv系列3.1execv3.2總結 4.實現一個bash解釋器4.1內建命令 通過fork創建的子進程,會繼承父進程的代碼和數據,因此本質上還是在執行父進程的代碼 進程替換可以將…

Java基礎語法之數組

數組 一、認識數組 1.什么是數組 數組就是一個容器,用來存一批同種類型的數據。 舉例 20, 10, 80, 60, 90 int[] arr {20, 10, 80, 60, 90};張三, 李四, 王五 String[] names {"張三", "李四", "王五"};2.為什么要使用數組 假設…

Java死鎖排查:線上救火實戰指南

想象一下,你正在值班,突然監控告警紅成一片,用戶反饋雪花般飄來:“系統卡死了!用不了了!” —— 這很可能就是Java應用遭遇了“死鎖”這個大魔王。這時候,你就是救火隊長,首要任務不…

006-nlohmann/json 結構轉換-C++開源庫108杰

絕大多數情況下,程序和外部交換的數據,都是結構化的數據。 1. 手工實現——必須掌握的基本功 在的業務類型的同一名字空間下,實現 from_json 和 to_json 兩個自由函數(必要時,也可定義為類型的友元函數)&a…

白盒測試——基本路徑測試法

一、實驗名稱 白盒測試——基本路徑測試法 二、實驗目的 白盒測試是結構測試,是依據被測程序的內部邏輯結構設計測試用例,驅動被測程序運行完成的測試,通過本實驗希望: 1、掌握基本路徑測試法的基本概念,用具體的例子…

【嵌入模型與向量數據庫】

目錄 一、什么是向量? 二、為什么需要向量數據庫? 三、向量數據庫的特點 四、常見的向量數據庫產品 FAISS 支持的索引類型 vs 相似度 五、常見向量相似度方法對比 六、應該用哪種 七、向量數據庫的核心邏輯 🔍 示例任務:…

matlab中和三角函數相關的內容

和三角相關的函數 以下內容為Ai輸出 函數描述示例sin(x)正弦函數,返回x的正弦值,x單位為弧度sin(pi/2)cos(x)余弦函數,返回x的余弦值,x單位為弧度cos(pi)tan(x)正切函數,返回x的正切值,x單位為弧度tan(pi…

scratch基礎-外觀模塊

一、本次任務 二、內容詳解 1、模塊介紹 1、說[你好] (2)秒:臨時對話框,短暫對話 2、說[你好]:持續顯示對話框,長文本顯示 3、思考[嗯…] (2)秒:臨時顯示思考氣泡,用于角色思考 4、思考[嗯…] &#xff1a…

TAOCMS漏洞代碼學習及分析

路由規則 分為前臺和后臺&#xff0c; 前臺在api.php中 <?php session_start(); include(config.php); include(SYS_ROOT.INC.common.php); $ctrl$_REQUEST[ctrl]; $action$_REQUEST[action]; $mucfirst($action); if(!in_array($m,array(Api,Comment)))d…

Spring @Scheduled注解詳解

文章目錄 1.Scheduled注解定義2.配置 Scheduled2.1 開啟定時任務支持2.2 創建定時任務 3. 常用屬性3.1 fixedRate3.2 fixedDelay3.3 cron 4.工作原理4.1 基于TaskScheduler4.2 使用 ThreadPoolTaskScheduler4.3 定時任務的執行流程 5. 延時執行的定時任務5.1 創建定時任務類5.2…