Hiện tại thì Locker chưa công bố giá chính thức và vẫn để user sử dụng miễn phí trong thời gian đầu bạn ạ, mk cũng ko rõ lắm. Để chắc chắn hơn bn thử contact với customer support xem 😅
@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.
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ỉ
đượ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é.
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
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 ạ?
THẢO LUẬN
Bài viết chi tiết quá. Cảm ơn bạn nhìu :>
Mời cười nhưng content không có gì để cười 😜
Kiến trúc Microservices là một khái niệm hot. Đó là lý do mình sẽ mày mò nghiên cứu và up bài lên đây!
Cùng theo dõi series này của mình và góp ý thêm những nhận xét nhé!
Bài viết này. của mình bị lặp!
@Tran_hieu cái này mình cũng ko rõ 😅
Cảm ơn bạn! Bài viết rất dễ hiểu
rút gọn link để chạy SEO với chạy quảng cáo trên các nền tảng tốt hơn thôi, còn về tốc độ thì chưa chắc
Hiện tại thì Locker chưa công bố giá chính thức và vẫn để user sử dụng miễn phí trong thời gian đầu bạn ạ, mk cũng ko rõ lắm. Để chắc chắn hơn bn thử contact với customer support xem 😅
Dạ đúng rồi. Cảm ơn b nhiều ạ
Co đc dùng thử k bạn nhỉ, hay dùng thì mất phí từ đầu luôn?
chí mạng luôn bro ạ 😂
@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.
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ỉ
đượ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é.
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.
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:
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 --seedthì có thể bạn sẽ cầndocker compose downrồiuplại nhaVới điều kiện bạn thấy lead của bạn đủ thân nhé
Bài viết hay quá! Mình cũng đã update giá trị cho file .env như sau:
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 ạ?