Aktywne Wpisy

mirko_anonim +18
✨️ Obserwuj #mirkoanonim
Ehh nie napiszę niczego odkrywczego ale naprawdę mam dość w tym kraju i chodzi mi tutaj o to że prawdopodobnie nigdy nie będzie mnie stać na mieszkanie.
Jestem z patologicznej rodziny, cudem udało mi się osiągnąć w życiu wyjść na prostą. Nie będę o tym się rozdzierał ale kosztowało mnie to dużo niż przeciętną osobę na ulicy.
Dziś mam 33 lata i zarobki ponad 6k, jestem kucharzem.
Moja dziewczyna
Ehh nie napiszę niczego odkrywczego ale naprawdę mam dość w tym kraju i chodzi mi tutaj o to że prawdopodobnie nigdy nie będzie mnie stać na mieszkanie.
Jestem z patologicznej rodziny, cudem udało mi się osiągnąć w życiu wyjść na prostą. Nie będę o tym się rozdzierał ale kosztowało mnie to dużo niż przeciętną osobę na ulicy.
Dziś mam 33 lata i zarobki ponad 6k, jestem kucharzem.
Moja dziewczyna
źródło: 7d8522502a0e4c536d3fa0a9cc96356285c666279c0ba39beee66a5b7968f84a
Pobierz
smuteczek2000s +37
Dziękuję serio.
Byliście wspaniałym gronem!
Będę tęsknić, ale życie się zmienia, nowy rok... stara ja, ale w sumie już chyba wystarczy.
#atencyjnysmuteczek
Byliście wspaniałym gronem!
Będę tęsknić, ale życie się zmienia, nowy rok... stara ja, ale w sumie już chyba wystarczy.
#atencyjnysmuteczek
źródło: temp_file7088298369503819281
Pobierz![Motorniczy dostał pięścią w twarz. Zareagował na p-----c na przystanku [VIDEO]](https://wykop.pl/cdn/c3397993/c325b0049a6a4a8662cc75990f2c58c04ea0b97549587ac260933fe8eb9f8f8f,q80.jpg)




Mirki, czytam sobie różne pytania z system design i natrafiłem na coś takiego:
Jakbyście do tego podeszli? ChatGPT sugeruje
@Transactional@lock(LockModeType.PESSIMISTIC_WRITE)
@query("SELECT k FROM Kupon k WHERE k.kod = :kod")
Optional<Kupon> findByKodForUpdate(String kod);
i
@Transactionalpublic boolean wykorzystajKupon(String kod) {
return kuponRepository.findByKodForUpdate(kod).map(kupon -> {
if (kupon.getWykorzystania() < kupon.getLimitUzyc()) {
kupon.setWykorzystania(kupon.getWykorzystania() + 1);
kuponRepository.save(kupon);
return true;
} else {
return false;
}
}).orElse(false);
}
już pomijając polskie nazwy i save na już persisted encji
Czy ma to sens, czy jest to wystarczające?
Zakładając, że tak - to czy byłoby to wydajne i skalowane? W NoSQLowej bazie byłby pewnie łatwiej o wydajność, ale czy da się wtedy zrobić takiego locka?
1. Relacyjność raczej musi być - wątpię, aby w docelowym systemie nie chcielibyśmy powiązać kuponu z użytkownikiem i zamówieniem
2. Jednak aby zachować szybki response przechowywałbym użyte kupony w jakiejś NoSQL bazie - pewnie jakiś cache (Redis).
3. Gdy dostaniemy odpowiedź, że kupon jest/był dostępny to łączyłbym się już z transakcyjną bazą danych i w update tak jak sugerował @VlIN inkrementowałbym kupon
@Patres: No ale tutaj też z kolei miałbyś kolejny narzut na synchronizację bazy z cache. Cache nie zawsze jest spójny z tym co jest na bazie. I to też nie byłoby takie trywialne jak to ugryźć.
100 kuponów | 200 requestów:
1..99 - brak reakcji z cache -> obsługą przez relacyjną bazę danych
- weź kupon z licznika kuponów przez ten UPDATE
- jak się udało to dodaj do osobnej tabeli COUPON_USES event że kupon został wykorzystany w danym czasie i ew. jakiś stan wykorzystania kuponu, Reserved, used, cancelled
- Powiąż jakoś ten event z rekordem zamówienia
- commit transakcji
@VlIN: Operacja update nie zwraca nic,przynajmniej tak jest w JPA w Javie, ewentualnie Integer
@Patres: a co niby z tym ma wspólnego relacyjność? Bazy relacyjne nie nazywają się relacyjne dlatego że między tabelami są związki (klucz obcy, klucz główny). W bazach NoSQL też takie związki między użytkownikiem a zamówieniem zamodelujesz.
2. Zdajesz sobie sprawę z tego że cały system bankowy / płatniczy zbudowano bez ACID?