Kafka đã thay đổi hệ thống eCommerce trở nên mạnh mẽ như thế nào so với cách cũ

แชร์
ฝัง
  • เผยแพร่เมื่อ 7 ก.พ. 2025

ความคิดเห็น • 72

  • @SaMi-kv6yi
    @SaMi-kv6yi 2 หลายเดือนก่อน +2

    cái này triển khai còn thiếu cái bước quản lý trạng thái giao dịch và theo dõi các transaction để bù trừ nếu cần rollback nữa. Chứ múc cơ bản khóc meo meo luôn nhá.

  • @TuanNguyen-gf7td
    @TuanNguyen-gf7td 7 หลายเดือนก่อน +1

    Em đang tìm hiểu về Kafka mong anh ra sớm video ạ.

  • @hoangan_nguyen
    @hoangan_nguyen 7 หลายเดือนก่อน +4

    hay quá anh ơi, anh apply kafka vào go project luôn nha anh

    • @anonystick
      @anonystick  7 หลายเดือนก่อน +1

      Tất nhiên rồi hen

  • @huyphanquang1780
    @huyphanquang1780 7 หลายเดือนก่อน +7

    Cái này là SAGA Pattern, việc implement SAGA bằng RabbitMQ hay Kafka cái nào cũng được , thậm chí dùng RabbitMQ còn tốt hơn vì nó có cơ chế ACK cũng như cơ chế broker rất clear. Nhưng SAGA lý thuyết thì hay chứ khi vào thực tế xử lý rollback distributed transaction chưa bao giờ là dễ dàng cả, nhất là ở bước Payment ấy

    • @QUANNGUYEN-hm7ql
      @QUANNGUYEN-hm7ql 6 หลายเดือนก่อน

      tôi thấy saga chả khác gì truyền thống:))

    • @xenky0
      @xenky0 6 หลายเดือนก่อน +2

      Trong video này còn không áp dụng transactions thì lgi có saga ở đây :D

  • @TMonkey96
    @TMonkey96 7 หลายเดือนก่อน +3

    tính ra e làm Kafka đc hơn 3 năm Outsource cho Nokia mà e còn chưa biết hết mấy cái này nữa @@

    • @anonystick
      @anonystick  7 หลายเดือนก่อน +2

      Giờ biết mà. Cố lên nào

  • @anh.dinhhoangquang98
    @anh.dinhhoangquang98 7 หลายเดือนก่อน

    hóng tiếp ạ

    • @manhnk.7143
      @manhnk.7143 6 หลายเดือนก่อน

      ok bạn nhe

  • @sonhai4539
    @sonhai4539 7 หลายเดือนก่อน +3

    Anh có thể làm video so sánh NAST vs RMQ vs Kafka đc không anh❤

    • @anonystick
      @anonystick  7 หลายเดือนก่อน +1

      Anh chưa có cơ hội làm về NATS em à...

    • @ovothanh4778
      @ovothanh4778 6 หลายเดือนก่อน +2

      Nats = kafka + rabbitmq + grpc, cực xịn xò nha

  • @QuangNguyen-mn6yq
    @QuangNguyen-mn6yq 7 หลายเดือนก่อน +1

    Anh làm về kiểm thử database được không ạ

  • @PhuNguyen-kg1st
    @PhuNguyen-kg1st 4 หลายเดือนก่อน +2

    Em có 1 thắc mắc, là nếu mình đẩy vào quee như vậy nếu 1 step trong order nó failed thì các service trước đó cũng phải update lại phải không anh. Ví dụ một trước lúc "do payment" thì mình có 1 bước là "update inventory" vậy nếu mình bị failed ở "payment service" thì làm sao để back về update lại cái "inventery service" kia v ah, có phải mình sẽ public 1 event từ con "payment server" thanh toán failed thì con "inventory server" lắng nghe event failed của con "payment service" và update lại phải không anh.

    • @anonystick
      @anonystick  4 หลายเดือนก่อน +1

      Có em tất cả phải transaction. SAGA pattern

  • @killerpt8493
    @killerpt8493 6 หลายเดือนก่อน +2

    Mn cho e hỏi trong kiến trúc microservice thương mại điện tử thì khi đặt hàng sẽ kiểu tra số lượng hàng trc hay số tiền có trc ạ.Hay nó sẽ làm đồng thời kiểu bắn message đến 1 topic rồi cả 2 service sock và pay sẽ nhận và check cùng lúc ạ.nếu check đồng thời thì khi trả về nó đag ở 2 topic thì sao đồng bộ dc ạ

    • @anonystick
      @anonystick  6 หลายเดือนก่อน +1

      25 - Section 25: Order Service Api (part 1) | th-cam.com/video/rpoQjTm9In4/w-d-xo.html
      26 - Section 26: Order service Part 2 | Tiếp đến là Redis chuyên sâu - th-cam.com/video/mswayRA-870/w-d-xo.html

  • @hyy1856
    @hyy1856 7 หลายเดือนก่อน +9

    Mô hình này đảm bảo website nhỏ thôi bạn. Mô hình săn sale kiểu 7/7 shopee CCU lớn gần như lỗi hoàn toàn. Đền voucher sập cty.

    • @khangoduc8675
      @khangoduc8675 7 หลายเดือนก่อน

      vậy theo anh thì những hệ thống lớn họ sẽ dùng gì để handling event?

    •  7 หลายเดือนก่อน

      website nhỏ là nhỏ cở nào bạn ?

    • @hyy1856
      @hyy1856 7 หลายเดือนก่อน

      @@khangoduc8675 họ áp dụng cả cách của chủ kênh chia sẻ, nhưng về vấn đề order thì buộc phải đồng bộ. không thể run bất đồng bộ được. Như tiki họ dùng ring buffer

    • @hyy1856
      @hyy1856 7 หลายเดือนก่อน

      @@khangoduc8675 riêng khâu order vẫn phải dùng đồng bộ bạn nhé, còn làm sao để tối ưu khâu order đồng bộ mà nhanh thì có keyword là ring buffer. Các khâu khác thì có thể dùng như video bạn chủ hướng dẫn.

    • @phucnote3684
      @phucnote3684 7 หลายเดือนก่อน

      🤣

  • @HoangPhung-hf7cs
    @HoangPhung-hf7cs 7 หลายเดือนก่อน

    e thấy hay nha

  • @vuquang7888
    @vuquang7888 4 หลายเดือนก่อน

    cho em hỏi nếu hệ thống nào cũng như này thì sao ta không áp dụng hết Go đi ạ theo em thấy anh demo thì Go quá mạnh có khi nó realtime luôn vậy cần gì tốn chi phí cho những thằng khác trong khi Go handle được tận hàng triệu request mà còn có khả năng chia sẻ thông tin giữa các luồng quá mạnh rồi ạ. Mong anh làm video làm về vấn đề này ạ

    • @vuquang7888
      @vuquang7888 4 หลายเดือนก่อน

      @placeholder612 Ngoài mấy vấn đề khách quan này có gì khác không ạ. Em vẫn thấy nếu IO bounds thì thằng Gin (framework của GO) cũng có ấy ạ, với lại em thấy dev nó cũng nhanh. Em là dân chuyên JS từ BE đến FE và làm C#.
      Do em thấy mọi người nói Go mạnh thì có tìm hiểu và học 1 thời gian thì có code lại dự án đang chạy của công ty sang Go thì đúng nó nhanh thật mà thời gian dev cũng ko lâu đâu ạ nếu so với 1 dự án Nhật chạy như vậy.
      Vậy có điều gì làm mọi người không nên bỏ hết mấy ngôn ngữ kia và chọn Go nhỉ. Em không tân bốc nó hay gì chỉ là thắc mắc 1 ngôn ngữ cái gì cũng mạnh vậy sao không bỏ hết mấy ngôn ngữ khác theo nó thôi kiểu giống như C top 1 tại sao không làm C thôi mà lại qua Python trong khi Python chạy rất chậm có khi gặp lỗi throttling liên tục không fix được nữa

    • @vuquang7888
      @vuquang7888 4 หลายเดือนก่อน

      @placeholder612 nhưng theo em thấy những nguyên nhân khách quan đó nó không phải là nan giải và có thể handle được
      - Và những dự án mới bây giờ người ta cũng không chọn Golang là bước phát triển đầu tiên
      - Giống như việc em đưa 1 con game với lúc đầu là server Nodejs khi lượng user request quá cao em bị chết và dường như nó phải làm em phải đi handle case đó trong khi em đổi qua Golang chỉ mất tầm 1 tháng 3 tuần xong và nó có tốc độ nhanh và em không còn phải đau đầu giải quyết mấy cái vụ request đó nữa và dường như nó không gặp lại trong 2 tháng hơn hiện nay
      - Website thì em không biết nhưng có thể handle trong thời gian ngắn được thôi ạ nhưng tại sao người ta vẫn muốn chọn ngôn ngữ khác thay vì Go ta
      => Em chỉ thắc mắc thôi ạ vì em là dân Chuyển C#, Python em thấy Go nó mạnh mà sao mọi người lại cứ phải chọn Nodejs và java làm gì trong khi hiệu năng và tốc độ thì Golang ăn dứt truy bảo mật thì Golang nó cũng ngang ngang java không vượt trội thôi. Nhưng về chung quy nó vẫn mạnh hơn nhiều

  • @hieule1022
    @hieule1022 3 หลายเดือนก่อน +1

    có video thực hành cơ chế này cho bài toán thực tế ko anh?

    • @anonystick
      @anonystick  3 หลายเดือนก่อน

      JAVA

    • @hieule1022
      @hieule1022 3 หลายเดือนก่อน

      @@anonystickJavascript có ko ạ?

  • @cunanh2112
    @cunanh2112 7 หลายเดือนก่อน

    anh ơi, để học khóa backend nodejs của anh cần nắm những kiến thức gì trước ạ, và trong khóa đấy có phải code FE không ạ ?

    • @letuan5069
      @letuan5069 7 หลายเดือนก่อน +1

      hiểu đọc hiểu code js, ko có code FE trong khoá này

    • @cunanh2112
      @cunanh2112 7 หลายเดือนก่อน

      @@letuan5069 e cảm ơn ạ

  • @udemytiengviet956
    @udemytiengviet956 7 หลายเดือนก่อน

    A cho e hỏi với e có kinh nghiệm 4 năm Java , giờ đang muốn switch qua NodeJS. Học xong khoá NodeJS của a thì có vô dự án thực tế chiến được chưa ạ ? Thank a

    • @rawmetal3052
      @rawmetal3052 7 หลายเดือนก่อน

      Vãi ông middle java lại switch qua NodeJS làm gì làm Junior từ đầu down lương thì sao

  • @VietTran-y2p
    @VietTran-y2p 7 หลายเดือนก่อน

    anh lam khoa hoc java anh oi

    • @anonystick
      @anonystick  7 หลายเดือนก่อน

      Xong go đã nha em

  • @ngonam22
    @ngonam22 7 หลายเดือนก่อน

    Anh ơi, cho e hỏi nếu dùng API gateway bắn mess tới Kafka xong Service tương ứng sẽ xử lý theo design Event Driven, thay vì Gateway forward trực tiếp tới service đó thì có ổn không a nhỉ?
    Các Gateway như Kong hay Traefik đều chỉ forward trực tiếp thôi. E cám ơn

    • @huytranuc8610
      @huytranuc8610 7 หลายเดือนก่อน

      gateway thì làm đúng việc của cái tên nó là điều hướng thôi b, để service bên trong đẩy vào kafka nếu cần

    • @ngonam22
      @ngonam22 7 หลายเดือนก่อน

      ⁠@@huytranuc8610tại nếu bạn dùng service đẩy thì lại tốn 1 step từ Gateway connect tới service đó. Này mình code thêm plugin tích hợp vào Gateway cho nó đẩy thẳng vào Kafka, thằng service phụ trách chỉ cần subscribe mess thôi. Làm như này thì Loose coupling rất cao và cũng dễ scale nữa, Kafka nó tự handle cả rồi
      Đó là cái mới mà mình đọc của mo hinh Event Driven API (có thể mới với mình thôi 😂)

  • @thanhtuan357
    @thanhtuan357 7 หลายเดือนก่อน +1

    Chú cho con hỏi nếu một node bị lỗi thì có thể ACID của db sẽ ko đảm bảo thì làm thế nào ạ. Vd update cart OK nhưng update inventory thì Fail. Thì cái này có cách nào khác phục ko ạ. Với lại độ trễ khi nữa. Nếu response order trả về OK cái con gọi api lấy lại list cart thì có lúc nó sẽ không trả về đúng dữ liệu mới thì cái cách nào giảm thiểu hoac khắc phục ko ạ ( này mà mástẻr - slave thì độ trễ tăng nữa ). Xin chú giải đáp ạ

    • @anonystick
      @anonystick  7 หลายเดือนก่อน

      Trước tiên hiểu sâu về ACID: Section 110: LÀM CHỦ MYSQL - Nguyên tắc ACID, sự cô lập vs cơ chế trong transaction HIỂU SÂU
      th-cam.com/video/ylidVS4HvtE/w-d-xo.html

    • @anonystick
      @anonystick  7 หลายเดือนก่อน

      Sau đó lấy ví dụ thanh toán làm thực tế mức cô lập trong db

    • @VuTuanIT
      @VuTuanIT 7 หลายเดือนก่อน +1

      Khi sử dụng kafka thì bạn phải đánh đổi ACID, thay vào đó phải handle tính nhất quán của dữ liệu thủ công, bạn có thể tìm hiểu các khái niệm eventually consistent, event sourcing, saga pattern. Những kỹ thuật này được thường được sử dụng để đảm bảo tính nhất quán dữ liệu

    • @thanhtuan357
      @thanhtuan357 7 หลายเดือนก่อน

      @@anonystick đạ cảm ơn chú.

    • @thanhtuan357
      @thanhtuan357 7 หลายเดือนก่อน +1

      @@VuTuanIT dạ cảm ơn Anh ạ. Cho em hỏi thêm với. Mấy app liên quan tới tiền như bank thì bắt buộc phải đảm bảo ACID hả Anh.

  • @n0osp0m123
    @n0osp0m123 7 หลายเดือนก่อน

    dạ mô hình này mình đang follow kiểu pub sub thì a cho em hỏi nếu như mình dùng cluster nhiều node nhiều pod, instance nó cùng sub thì mình xử lý duplicate như thế nào anh ạ?

    • @tamleminh755
      @tamleminh755 7 หลายเดือนก่อน

      nhiều node nhiều pod là sao nhỉ. Ý của bạn là pod của bạn scale trong cùng 1 instance hay sao ?

    • @xenky0
      @xenky0 6 หลายเดือนก่อน

      Kafka nó tự lo vấn đề này rồi, tùy vào cách sử dụng, nó mạnh lắm, tìm hiểu consumer group, topic, và partition nhé

    • @n0osp0m123
      @n0osp0m123 6 หลายเดือนก่อน

      @@tamleminh755 đúng rùi ạ, nhiều pod của service A chẳng hạn

    • @n0osp0m123
      @n0osp0m123 6 หลายเดือนก่อน

      @@tamleminh755 nhiều pod của 1 service ấy ạ, mà service ấy là consumer, thí dụ default là 1 khi mà scale lên 3 4 pod thì mình xử lý ntn ấy ạ

    • @kira0992
      @kira0992 5 หลายเดือนก่อน

      @@n0osp0m123 cho các pod vào trong cùng consumer group, kafka nó sẽ tự distribute messages đến các pod, ko bị duplicate khi consume message đâu.

  • @ArtLifeDev
    @ArtLifeDev 7 หลายเดือนก่อน

    ❤❤❤❤

  • @nhacdongque-u9x
    @nhacdongque-u9x 7 หลายเดือนก่อน +1

    Thế còn click house thì sao a nhỉ nó với cái Kafka này cái nào ngon hơn

    • @thientranhoang2658
      @thientranhoang2658 6 หลายเดือนก่อน

      clickhouse tính chất nó là database mà bác, nó không chuyên về queue như cái này

  • @jan9102
    @jan9102 7 หลายเดือนก่อน

    NATS thì sao bác

    • @anonystick
      @anonystick  7 หลายเดือนก่อน

      Anh chưa có cơ hội làm về NATS em à...