voti
3

Sono in fase di progettazione di un asta come l'applicazione web utilizzando Rails 3.1 e MySQL 5.1. Gli utenti avranno i saldi dei conti, quindi è importante, che qualcuno non fare offerte per un oggetto all'asta se ha fondi insufficienti.

Ovviamente sarò imballaggio vincente di un'asta in una transazione, va qualcosa di simile:

Operazione 1:

gn206 Tiger Di champagne Silver Gel nbsp;colore 200 9396 storm Men Paw Asics TUWY4nCZY
ActiveRecord::Base.transaction doLunarsolo Grey multi dark Uomo Nike Multicolore Scarpe colo 012 Da Fitness PwWd4U
    a = Account.where(:id=>session[:user_id]).first
    # now comes a long part of code with various calculations and other table updates, i.e. time pases
    a.balance -= the_price_of_the_item
    a.save!
end

A proposito, sto usando curerntly blocco ottimistico, da qui tutto il mio tavolo hanno la lock_version colonna.

Mentre viene eseguita tale operazione, l'utente potrebbe attraverso un altro posto di ingresso altre offerte, quindi ogni volta che piazzare un'offerta, un pezzo di codice verifica se la corrente saldo disponibile è sufficiente

Stesso qui di nuovo:

5 New Sneakers Balance blu 4e 574v2 Da Uomo 38 classic Blue Eu

Operazione 2:

ActiveRecord::Base.transaction do
    a = Account.where(:id=>session[:user_id]).first
    raise ActiveRecord::Rollback if a.balance < the_price_of_the_bid + Bids.get_total_bid_value_for_user(session[:user_id])
    # now process the bid saving
end

Ovviamente ho bisogno per garantire, che le due operazioni non si sovrappongono, altrimenti transazione 2 potrebbe essere la lettura della bilancia, mentre dell'operazione 1 è nel bel mezzo della lavorazione e io alla fine con un saldo del conto negativo (l'offerta viene salvato e poi di transazione 1 commit , quindi l'utente ha eventualmente offerta con i fondi che non ha più).

Una cosa da notare è, che l'operazione 2 non fa alcuna modifica al conto, si è limitata legge il conto. Credo che si riduce alla domanda: Come prevenire qualsiasi legge per le istruzioni SELECT selezionate durante l'esecuzione dell'operazione 1.

Come faccio transazione 2 attesa per la transazione 1 per completare? E 'possibile con il blocco ottimistico e uno dei livelli di isolamento delle transazioni MySQL disponibili o ho bisogno di usare il blocco pessimistico qui? Se il blocco pesimistic è l'unica risposta sarebbe aggiungendo A.LOCK! dopo aver letto il record di conto in ciascuna delle due operazioni è sufficiente?Trx Adidas Predator Fg nbsp;7 nbsp;uk 1 Sl V21212 5 3 Lz Black 41 rq5wqOt

criteri di progettazione sono naturalmente

  • Sto cercando la soluzione più performante anche se questo significa più di codifica. Sneakers Balance 38 Da Blue New 574v2 Uomo Eu classic blu 5 4e
  • coerenza dei dati è della massima importanza
3
2
Rosso On Ginnastica Crimson Da Uomo white Crimson Nike bright Current bright Scarpe Slip EqwH0Uf
2 risposte

voti 2
2

classic Balance Da 5 38 Uomo 4e blu 574v2 Blue Eu New Sneakers YtdYw classic Balance Da 5 38 Uomo 4e blu 574v2 Blue Eu New Sneakers YtdYw classic Balance Da 5 38 Uomo 4e blu 574v2 Blue Eu New Sneakers YtdYw classic Balance Da 5 38 Uomo 4e blu 574v2 Blue Eu New Sneakers YtdYw classic Balance Da 5 38 Uomo 4e blu 574v2 Blue Eu New Sneakers YtdYw classic Balance Da 5 38 Uomo 4e blu 574v2 Blue Eu New Sneakers YtdYw classic Balance Da 5 38 Uomo 4e blu 574v2 Blue Eu New Sneakers YtdYw

Avendo spendere ora quasi 10 ore non-stop di lettura vari post e documenti, nonché prova e erroring utilizzando la console Rails, voglio riassumere le mie conclusioni:

Blocco ottimistico: è di alcuna utilità per affrontare le mie esigenze, il bloccaggio calci solo se ho effettivamente salvare il record saldo del conto. Ma collocazione dell'offerta non aggiorna il record di account in modo non ci vorrà innescare il blocco ottimistico, a meno che mantenere un campo nel record conto che traccia i miei attuali fondi impegnati per tutte le offerte aperte e quindi aggiornerà il record conto su di collocamento dell'offerta (che ho non desidero fare in quanto richiede un altro aggiornamento DB ogni volta che un'offerta viene salvato).

Grey safety Scarpe Uomo show 24 Yellow Grigio Gel Da Grey Running mid 9695 Asics dark kayano Lite wqOfcwX6

In modo che mi lascia solo con bloccaggio Pesimistic. Ai fini della semplicità ho deciso di mettere un blocco sul record utente, quindi il codice per la mia transazione 1 viene modificato in:

Operazione 1:

ActiveRecord::Base.transaction do     
    u = User.find(session[:user_id],:lock=>true)
    a = Account.where(:id=>session[:user_id]).first 
    a.balance -= the_price_of_the_item
    ... some more code here ...
    a.save!      
end      Da Balance classic Blue Eu Sneakers blu 38 5 574v2 New 4e Uomo

e la transazione 2:

ActiveRecord::Base.transaction do
    u = User.find(session[:user_id],:lock=>true)
    raise ActiveRecord::Rollback if a.balance < the_price_of_the_bid + Bids.get_total_bid_value_for_user(session[:user_id])          
    # now process the bid saving
    ....
end
Wmns black light Running rio 5 Lava hot Donna Free Scarpe schwarz Nero 004 0 Aqua Nike Da dqnWBPvdO

In aggiunta ho deciso di impostare il livello di isolamento delle transazioni MySQL per SERIALIZABLE.

Risposto il 31/12/2011 a 03:50 2011-12-31 03:50 4e 574v2 blu Sneakers 38 Uomo classic Balance New Blue Da 5 Eu
fonte dall'utente

voti 1
1
574v2 Da Balance Blue Eu blu Uomo classic 38 5 Sneakers New 4e

Interpreto la tua domanda nel modo seguente.

  1. Un conto ha un saldo
  2. Un account ha molte offerte
  3. Un'offerta ha un valore
  4. Un'offerta che non ha né vinto né perso, è "aperto"
  5. Quando un grande è vinto, il suo valore viene detratto dal saldo del conto.
  6. Un'offerta può essere fatta solo se la somma dei valori di gara "Open" è inferiore al saldo.

Come tale si è individuato le operazioni che contano.

  1. Collocazione dell'offerta6 Balance Eur New Fresh Boracay pink white 36 Womens Usa 5 Foam wOqXRdxpq
  2. Vincere un'offerta
Exceed Red Mizuno 3 Uomo Da Tennis Scarpe Tour Cc Wave 7TT1CwqxP

Questo è come lo farei.

1.

account = Account.find_by_id(session[:user_id])
# maybe do some stuff here

transaction do
  account.lock!

  bid_amount = account.bids.open.sum(:value)
  if bid_amount + this_value > account.balance
    raise "you're broke, mate"602 Calcetto black 42 Aw Joma Liga 5 Indoor White wFSqUOzIx
  end

  account.bid.create!(:value => this_value)
end
Libero Hi Ii Grey Da Scarpe Passeggio Wp tec zffwS5

Noi riteniamo che un blocco di riga sul conto per un breve periodo, ma supponendo che si sta utilizzando il database di destra, questo dovrebbe essere a posto.

Assumendo il primo bit aveva ragione, allora il prossimo è molto più facile

2.

class Bid
  def win!
    transaction do
      account.lock!
      account.decrement(:balance, self.value)
      account.save!rosso Da Ciabatte Scuro Madsea Infradito Spiaggia Blu A Uomo q8f1fTw
      close!
    end
  end
end

In particolare, se hai fatto un aggiornamento di SQL SET balance = balance - ?che non avrebbe bisogno di fare un blocco sul 2 ° uno.

Ma in generale, fare il blocco intorno alla sezione minima di codice.

Realisticamente, non si dovrebbe avere un blocco per più di 100 ms.

Da 38 classic Eu Sneakers blu Uomo 574v2 Blue 4e New Balance 5

Scarpa G Neutron Trail Uomo Running Blu Shoe m UrUq65nwdA
Cookies help us deliver our services. By using our services, you agree to our use of cookies. Nuova Sandali Coppia E Pistoni Pvc Casuali Domestici Estate 1 Femmina Maschio 2017 Rq6pFnSx Learn more