THẢO LUẬN

Jan 20th, 10:43 a.m.

Dạ đúng rồi. Cảm ơn b nhiều ạ

+1
Jan 20th, 8:59 a.m.

Co đc dùng thử k bạn nhỉ, hay dùng thì mất phí từ đầu luôn?

0

chí mạng luôn bro ạ 😂

0

@yuisofull chỗ này thì có 2 cái limit, 1 là số opened file, 2 là số ephemeral port của haproxy khi trỏ tới 1 ip + port backend. Nên để tăng số lượng ws connection thì ngoài việc cấu hình lại opened file và ephemeral port range thì nếu full sẽ cần 1 là thêm backend server, 2 là thêm IP cho con HAproxy để có thể mở nhiều connection hơn.

0

cho mình hỏi là 1 proxy server hay 1 backend server cũng có số port giới hạn, vậy muốn mở nhiều websocket connection thì phải có nhiều proxy server và backend server nhỉ

0
Jan 18th, 11:39 p.m.

được bạn. mục đích của mapping tự động là đỡ phải viết code thủ công. ví dụ bạn có 5 lớp thì sẽ rất tốn thời gian để (.setOne, .setTwo) và dễ gây nhầm lẫn. vì đây là bài hướng dẫn cơ bản nên mình không thêm các chi tiết đó vào. Bạn xem phầm mapping có phần map từ dto sang entity. thì id của dto sẽ không được mapping qua. và còn một số tính năng như mapping với tùy chọn tên trường giữa 2 bảng khác nhau. mapping từ id sang class của một thực thể. Ví dụ Category và product và mỗi cái đều có dto -> có 4 class. ở productId bạn chỉ lưu id của category thôi. thì bạn vẫn mapping từ ProductDto(name, price, categoryId) sang một thực thể product với category đúng của nó. Và còn nhiều tính năng hay ho hữa + lý do dùng Mapstruct là hiệu suất của nó nhanh trong top 2. so với các các lib mapping khác như ModelMapper (tuy nhiên modelMapper dễ dùng hơn). Nhưng quan trọng nhất là chúng ta nên biết mấy món đồ chơi này dùng thế nào. chứ không thì viết bằng tay cho chắc nhé.

0

Mình vừa đăng ký trên Locker nhưng ko thấy có bảng giá. Mình dùng dự án cá nhân có 1 dev là mình thôi.

0

VITE_REVERB_APP_KEY giữ mặc định nhé bạn,

lỗi của bạn như kia là ko kết nối được tới reverb luôn ấy:

  • check lại cấu hình nginx đoạn location của reverb nhé
  • check docker compose xem service reverb đã lên chưa? check logs của nó xem có lỗi ko?

như trong bài mình note, ở lần start đầu tiên, lúc chưa có DB, reverb nó có thể gặp lỗi vì nó cố gắng connect tới db ngay khi start, vậy nên sau khi bạn chạy migrate --seed thì có thể bạn sẽ cần docker compose down rồi up lại nha

0

Với điều kiện bạn thấy lead của bạn đủ thân nhé

0

Bài viết hay quá! Mình cũng đã update giá trị cho file .env như sau:

VITE_REVERB_PORT=8000
VITE_REVERB_PATH="/reverb"

Nhưng có vẻ websocket vẫn không kết nối và update real time được. Mình thấy biến VITE_REVERB_APP_KEY có dùng trong reverb nhưng trong file .env vẫn đang set giá trị là "my-app-key". Bạn cho mình hỏi có cần update giá trị cho biến VITE_REVERB_APP_KEY ko ạ?

Screenshot 2025-01-17 192317.png

0
Avatar
đã bình luận câu trả lời trong câu hỏi
Jan 17th, 10:11 a.m.

@cuongvnb cần add URL của frontend vào springboot, xem ví dụ http://localhost:4200 là frontend

import org.springframework.context.annotation.Configuration; import org.springframework.web.servlet.config.annotation.CorsRegistry; import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

@Configuration public class WebConfig implements WebMvcConfigurer {

@Override
public void addCorsMappings(CorsRegistry registry) {
    registry.addMapping("/**") 
            .allowedOrigins("http://localhost:4200") // Replace with your frontend URL
            .allowedMethods("GET", "POST", "PUT", "DELETE")
            .allowedHeaders("*")
            .allowCredentials(true); 
}

}

0

Cảm ơn chủ thread có bài viết bổ ích, mình cũng muốn góp 1 chút ạ 🎁

https://drinking-game.web.app/

https://play.google.com/store/apps/details?id=com.stark.drinking

0
Jan 17th, 6:43 a.m.

@dieptv_dev Các thông tin và giải pháp đưa ra cần phải chính xác. Sẽ có nhiều bạn đọc bài viết này và với các bạn mới, có thể sẽ định hướng sai và ghim vào đầu những ý tưởng không đúng.

Kiến thức đơn thuần chỉ là đúng - sai. Trong môi trường chia sẻ kiến thức mong bạn hiểu cho những phản biện này.

0
Jan 17th, 4:26 a.m.
  1. Đây là đưa ra một hệ thống cơ bản. Còn trong một bài viết đưa ra hết vấn đề của một hệ thống thực tế là không thể nào.
  2. Raid làm sao giải quyết đc hết các vấn đề. Còn hệ thống phân tán giải quyết mỗi vấn đề tốc độ truy cập thì cũng không đúng.
  3. Như đã nói, newsfeed nó còn áp dụng thuật toán, lọc, như tw cũng có một bộ thuật toán cho news feed r, vấn đề ở đây là thiết kế cơ bản và cách tổ chức

Bài viết chỉ đưa ra 1 cách suy nghĩ tổng quan về một hệ thống, chứ kp là đưa ra thiết kế chi tiết. Bạn thông cảm

0

js tự tạo thêm array null cho tới đúng số key id được thêm vào, thật là nguy hiểm

0
Jan 17th, 1:52 a.m.

sharding theo user_id có đúng không? shard có giới hạn của nó còn user_id thì quá nhiều.

Vụ lưu bản sao thì không đúng. Các hệ thống ổ cứng tự nó có giải pháp Raid để backup rồi. Người ta chỉ clone data theo region để tối ưu tốc độ truy cập thôi.

DB thiết kế quá sơ sài và không đúng. Cốt lõi trong Social network là các post. news feed cũng là các post. img - user - follower nó còn thiển cận quá.

Thiết kế newsfeed cũng quá sơ sài, không ý nghĩa gì. Newsfeed là phần khó nhất cả về thuật toán lần hiệu năng. Một câu hỏi đơn giản như là làm sao để tin lên newsfeed không bị lặp lại cũng đau đầu rồi. (Youtube làm vụ này rất dở, xem bị lặp suốt).

Nói chung, đặt yêu cầu 500tr người dùng là quá lớn. Với cỡ đó thì chỉ cần đi vào giải quyết 1 vde trong đấy là đủ, 1 bài thế này quá loãng và ít thông tin. Đơn giản như photo_id cũng tốn không ít giấy mực rồi.

0
Jan 16th, 3:23 p.m.

Dạ em cảm ơn tác giả của bài viết vì đã bỏ ra nhiều tâm huyết, diễn đạt logic và dễ hiểu lắm ạ

0

Có web đấy bạn, Locker.io 👍️

0

Bên này có web hay gì để xem thêm ko b ?

0
Viblo
Hãy đăng ký một tài khoản Viblo để nhận được nhiều bài viết thú vị hơn.
Đăng kí