Section C.8. Transactions


C.8. Transactions

  1. Never use ADO.NET transactions directly.

  2. Apply transactionFlowAttribute on the contract, not the service class.

  3. Do not perform transactional work in the service constructor.

  4. Using this book's terminology, configure services for either Client or Client/Service transactions. Avoid None or Service transactions.

  5. Using this book's terminology, configure callbacks for either Service or Service/Callbacks transactions. Avoid None or Callback transactions.

  6. When using the Client/Service or the Service/Callback modes, constrain the binding to flow transaction using the BindingRequirement attribute.

  7. On the client, always catch all exceptions thrown by a service configured for None or Service transactions.

  8. Strive to always configure operations to at least allow transactions:

     [ServiceContract] interface IMyContract {    [OperationContract]    [TransactionFlow(TransactionFlowOption.Allowed)]    void MyMethod1(...); } 

  9. Enable reliability and ordered delivery even when using transactions.

  10. In a service operation, never catch an exception and manually abort the transaction:

     //Avoid: [OperationBehavior(TransactionScopeRequired = true)] public void MyMethod( ) {    try    {       ...    }    catch    {       Transaction.Current.Rollback( );    } } 

  11. If you catch an exception in a transactional operation, always rethrow it or another exception.

  12. Always use the default isolation level of IsolationLevel.Serializable.

  13. Do not call one-way operations from within a transaction.

  14. Do not call nontransactional services from within a transaction.

  15. Do not access nontransactional resources (such as the filesystem) from within a transaction.

  16. Avoid transactional sessionful services.

  17. Prefer per-call transactional services.

  18. When using a sessionful or transactional singleton, use volatile resource managers to manage state and avoid explicitly state-aware programming or relying on the WCF instance deactivation on completion.




Programming WCF Services
Programming WCF Services
ISBN: 0596526997
EAN: 2147483647
Year: 2004
Pages: 148
Authors: Juval Lowy

flylib.com © 2008-2017.
If you may any questions please contact us: flylib@qtcs.net