|
Author: jleroux
Date: Mon Dec 7 13:02:30 2009 New Revision: 887917 URL: http://svn.apache.org/viewvc?rev=887917&view=rev Log: "Applied fix from trunk for revision: 887916 " ------------------------------------------------------------------------ r887916 | jleroux | 2009-12-07 14:00:09 +0100 (lun. 07 d‚c. 2009) | 9 lignes A patch from Adrian Crum "ServerHit aborts transactions when trying to create entries with duplicate startTime(s)." (https://issues.apache.org/jira/browse/OFBIZ-2208) - OFBIZ-2208 This add synchronization for ServerHit entities creation. Hence startTime is no longer used. I have also removed some comment about the problem, and added one for startTime no longer used. Note: If synchronization proves to slow down sites we could introduce a properties in serverstats.properties to switch from using it or not since I did not remove startTime from the method signature Then we will use one or the other lines - serverHit.set("hitStartDateTime", new java.sql.Timestamp(startTime)); + serverHit.set("hitStartDateTime", getNowTimestamp()); ------------------------------------------------------------------------ Modified: ofbiz/branches/release09.04/ (props changed) ofbiz/branches/release09.04/framework/webapp/src/org/ofbiz/webapp/stats/ServerHitBin.java Propchange: ofbiz/branches/release09.04/ ------------------------------------------------------------------------------ --- svn:mergeinfo (original) +++ svn:mergeinfo Mon Dec 7 13:02:30 2009 @@ -1 +1 @@ -/ofbiz/trunk:765933,766011,766015,766293,766307,766316,766325,766462,766522,766800,767060,767072,767093,767098-767099,767102,767123,767125,767127,767279,767287,767671,767688,767694,767822,767845,768358,768490,768550,768675,768686,768705,768811,768815,768960,769030,769500,770272,770308,770997,771073,772401,772464-772465,773076,773557,773628,773659,773697,774014,774632,774661,774995,775292,775667,776227,776594,776620,776922,777004,777020,777768,777792,777893,777947,778078,778094,778107,778273,778278,778280,778364,778374,778402,778576,778594,778628,779020,779477,779496,779639,779834,779856,779866,779873,780111,780138,780180,780199,780203,780906,780945,781201,781534,781549,781669,781680,781694,782663,783257,783266,783833,783913,783917,785123,785764,785967,786778,787126,787435-787436,787442,787520,788965,788983,788987,789329,789337,789506,789548,796769,799185,800461,800846,801023,802346,804364,805307,806127,806377,808786-808787,808792,809141,810370,810438,810465,810807,810809,810 814,810832,810836,810878,810917,811020,811280,811297,811419,811528,811708,811714,811716,811793,811838,811860,811865,811870,812159,812182,812192,812456,812540,813126,813131,813283,813672,813702,814168,814205,814251,814349,814531,814576,814681,814731,815158,815165,815350,815687,815977,816255,816863,818030,818049,818150,818494,818500,818716,818976,819275-819276,819282,819337,821263,821270,822659,823877-823878,823883,823888,823892,824511,825181-825182,826253,827730,828971,829085,829376,829412,829416,829527,830091,830112,830366,830528,830677,830874,830880,831238,831801,832361,832698,832776,832908,833324,833686,833703,834825,835161,835357,835585,836015,881194,881713,882072,882326,882918,883933,884023,884529,884546,884758,885122,885702 +/ofbiz/trunk:765933,766011,766015,766293,766307,766316,766325,766462,766522,766800,767060,767072,767093,767098-767099,767102,767123,767125,767127,767279,767287,767671,767688,767694,767822,767845,768358,768490,768550,768675,768686,768705,768811,768815,768960,769030,769500,770272,770308,770997,771073,772401,772464-772465,773076,773557,773628,773659,773697,774014,774632,774661,774995,775292,775667,776227,776594,776620,776922,777004,777020,777768,777792,777893,777947,778078,778094,778107,778273,778278,778280,778364,778374,778402,778576,778594,778628,779020,779477,779496,779639,779834,779856,779866,779873,780111,780138,780180,780199,780203,780906,780945,781201,781534,781549,781669,781680,781694,782663,783257,783266,783833,783913,783917,785123,785764,785967,786778,787126,787435-787436,787442,787520,788965,788983,788987,789329,789337,789506,789548,796769,799185,800461,800846,801023,802346,804364,805307,806127,806377,808786-808787,808792,809141,810370,810438,810465,810807,810809,810 814,810832,810836,810878,810917,811020,811280,811297,811419,811528,811708,811714,811716,811793,811838,811860,811865,811870,812159,812182,812192,812456,812540,813126,813131,813283,813672,813702,814168,814205,814251,814349,814531,814576,814681,814731,815158,815165,815350,815687,815977,816255,816863,818030,818049,818150,818494,818500,818716,818976,819275-819276,819282,819337,821263,821270,822659,823877-823878,823883,823888,823892,824511,825181-825182,826253,827730,828971,829085,829376,829412,829416,829527,830091,830112,830366,830528,830677,830874,830880,831238,831801,832361,832698,832776,832908,833324,833686,833703,834825,835161,835357,835585,836015,881194,881713,882072,882326,882918,883933,884023,884529,884546,884758,885122,885702,887916 Modified: ofbiz/branches/release09.04/framework/webapp/src/org/ofbiz/webapp/stats/ServerHitBin.java URL: http://svn.apache.org/viewvc/ofbiz/branches/release09.04/framework/webapp/src/org/ofbiz/webapp/stats/ServerHitBin.java?rev=887917&r1=887916&r2=887917&view=diff ============================================================================== --- ofbiz/branches/release09.04/framework/webapp/src/org/ofbiz/webapp/stats/ServerHitBin.java (original) +++ ofbiz/branches/release09.04/framework/webapp/src/org/ofbiz/webapp/stats/ServerHitBin.java Mon Dec 7 13:02:30 2009 @@ -618,7 +618,7 @@ GenericValue serverHit = delegator.makeValue("ServerHit"); serverHit.set("visitId", visitId); - serverHit.set("hitStartDateTime", new java.sql.Timestamp(startTime)); + serverHit.set("hitStartDateTime", getNowTimestamp()); // A change was introduced with https://issues.apache.org/jira/browse/OFBIZ-2208. Since then startTime is not used anymore serverHit.set("hitTypeId", ServerHitBin.typeIds[this.type]); if (userLogin != null) { serverHit.set("userLoginId", userLogin.get("userLoginId")); @@ -651,27 +651,15 @@ Debug.logError("Unable to get localhost internet address: " + e.toString(), module); } - // The problem with - // - // serverHit.create(); - // - // is that if there are two requests with the same startTime (this should only happen with MySQL see https://issues.apache.org/jira/browse/OFBIZ-2208) - // then this will go wrong and abort the actual - // transaction we are interested in. - // Another way instead of using create is to store or update, - // that is overwrite in case there already was an entry, thus - // avoiding the transaction being aborted which is not - // less desirable than having multiple requests with the - // same startTime overwriting each other. - // This may not satisfy those who want to record each and - // every server hit even with equal startTimes but that could be - // solved adding a counter to the ServerHit's PK (a counter - // counting multiple hits at the same startTime). try { serverHit.create(); } catch (GenericEntityException e) { - Debug.logError(e, "Could not save ServerHit:", module); + Debug.logError(e, "Could not save ServerHit: ", module); } } } + + public synchronized java.sql.Timestamp getNowTimestamp() { + return new java.sql.Timestamp(System.currentTimeMillis()); + } } |
| Free forum by Nabble | Edit this page |
