Opened 8 years ago
Closed 8 years ago
#1388 closed defect (fixed)
Rasql_Memory leak with swith case expression
Reported by: | Bang Pham Huu | Owned by: | bbell |
---|---|---|---|
Priority: | blocker | Milestone: | 9.4 |
Component: | rasserver | Version: | development |
Keywords: | Cc: | Dimitar Misev | |
Complexity: | Medium |
Description
Dimitar, this script will run a simple WCPS query with switch and case expression, however, it will take around 100 MB Ram for 2 queries and when running attached script, the memory is not released (i.e: it will quickly fill the RAM).
WCPS query
for data in (mr )return encode(switch case data = 0 return {red: 0; green: 0; blue: 0} case data = 1 return {red: 200; green: 200; blue: 200} case data = 7 return {red: 255; green: 0; blue: 0} case data = 9 return {red: 255; green: 255; blue: 255} case data = 14 return {red: 149; green: 0; blue: 148} case data = 16 return {red: 254; green: 168; blue: 0} case data = 20 return {red: 23; green: 250; blue: 255} case data = 26 return {red: 255; green: 255; blue: 0} case data = 33 return {red: 255; green: 235; blue: 0} case data = 34 return {red: 147; green: 112; blue: 219} case data = 39 return {red: 176; green: 48; blue: 96} case data = 47 return {red: 255; green: 127; blue: 80} case data = 48 return {red: 231; green: 142; blue: 79} case data = 49 return {red: 178; green: 178; blue: 178} case data = 59 return {red: 255; green: 165; blue: 0} case data = 62 return {red: 107; green: 142; blue: 35} default return {red: 0; green: 0; blue: 255} , "png")
Attachments (2)
Change History (11)
by , 8 years ago
follow-up: 2 comment:1 by , 8 years ago
comment:2 by , 8 years ago
Replying to dmisev:
Can you put the rasql query here from the petascope log?
http://rasdaman.org/attachment/ticket/1388/log.tar.gz please check here.
comment:3 by , 8 years ago
sorry for misread your request, I put the rasql query
SELECT encode(CASE WHEN ( data = 0 ) THEN ( (0) * { 1c,0c,0c } + (0) * { 0c,1c,0c } + (0) * { 0c,0c,1c } ) WHEN ( data = 1 ) THEN ( (200) * { 1c,0c,0c } + (200) * { 0c,1c,0c } + (200) * { 0c,0c,1c } ) WHEN ( data = 7 ) THEN ( (255) * { 1c,0c,0c } + (0) * { 0c,1c,0c } + (0) * { 0c,0c,1c } ) WHEN ( data = 9 ) THEN ( (255) * { 1c,0c,0c } + (255) * { 0c,1c,0c } + (255) * { 0c,0c,1c } ) WHEN ( data = 14 ) THEN ( (149) * { 1c,0c,0c } + (0) * { 0c,1c,0c } + (148) * { 0c,0c,1c } ) WHEN ( data = 16 ) THEN ( (254) * { 1c,0c,0c } + (168) * { 0c,1c,0c } + (0) * { 0c,0c,1c } ) WHEN ( data = 20 ) THEN ( (23) * { 1c,0c,0c } + (250) * { 0c,1c,0c } + (255) * { 0c,0c,1c } ) WHEN ( data = 26 ) THEN ( (255) * { 1c,0c,0c } + (255) * { 0c,1c,0c } + (0) * { 0c,0c,1c } ) WHEN ( data = 33 ) THEN ( (255) * { 1c,0c,0c } + (235) * { 0c,1c,0c } + (0) * { 0c,0c,1c } ) WHEN ( data = 34 ) THEN ( (147) * { 1c,0c,0c } + (112) * { 0c,1c,0c } + (219) * { 0c,0c,1c } ) WHEN ( data = 39 ) THEN ( (176) * { 1c,0c,0c } + (48) * { 0c,1c,0c } + (96) * { 0c,0c,1c } ) WHEN ( data = 47 ) THEN ( (255) * { 1c,0c,0c } + (127) * { 0c,1c,0c } + (80) * { 0c,0c,1c } ) WHEN ( data = 48 ) THEN ( (231) * { 1c,0c,0c } + (142) * { 0c,1c,0c } + (79) * { 0c,0c,1c } ) WHEN ( data = 49 ) THEN ( (178) * { 1c,0c,0c } + (178) * { 0c,1c,0c } + (178) * { 0c,0c,1c } ) WHEN ( data = 59 ) THEN ( (255) * { 1c,0c,0c } + (165) * { 0c,1c,0c } + (0) * { 0c,0c,1c } ) WHEN ( data = 62 ) THEN ( (107) * { 1c,0c,0c } + (142) * { 0c,1c,0c } + (35) * { 0c,0c,1c } ) ELSE ( (0) * { 1c,0c,0c } + (0) * { 0c,1c,0c } + (255) * { 0c,0c,1c } ) END, "png\" , "xmin=0.0;ymin=0.0;xmax=256.0;ymax=211.0;crs=OGC:Index2D") FROM test_mr AS data
follow-up: 6 comment:4 by , 8 years ago
Patch submitted for review, here's the most important valgrind output:
==20489== 20,737,128 bytes in 864,047 blocks are definitely lost in loss record 356 of 357 ==20489== at 0x4C2E0EF: operator new(unsigned long) (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so) ==20489== by 0xA5E41C: QtCaseOp::evaluateInducedOp(std::vector<QtData*, std::allocator<QtData*> >*) (qtcaseop.cc:257) ==20489== by 0xA5F3FF: QtCaseOp::evaluate(std::vector<QtData*, std::allocator<QtData*> >*) (qtcaseop.cc:399) ==20489== by 0xA2AF29: QtConversion::evaluate(std::vector<QtData*, std::allocator<QtData*> >*) (qtconversion.cc:155) ==20489== by 0xA01215: QtOperationIterator::next() (qtoperationiterator.cc:231) ==20489== by 0xA51B13: QueryTree::evaluateRetrieval() (querytree.cc:172) ==20489== by 0x99CAF0: ServerComm::executeQuery(unsigned long, char const*, ExecuteQueryRes&) (servercomm2.cc:1600) ==20489== by 0x7E0504: doStuff() (directql.cc:1062) ==20489== by 0x7E0C4A: main (directql.cc:1128) ==20489== ==20489== 20,737,344 bytes in 864,056 blocks are definitely lost in loss record 357 of 357 ==20489== at 0x4C2E0EF: operator new(unsigned long) (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so) ==20489== by 0xA5E438: QtCaseOp::evaluateInducedOp(std::vector<QtData*, std::allocator<QtData*> >*) (qtcaseop.cc:258) ==20489== by 0xA5F3FF: QtCaseOp::evaluate(std::vector<QtData*, std::allocator<QtData*> >*) (qtcaseop.cc:399) ==20489== by 0xA2AF29: QtConversion::evaluate(std::vector<QtData*, std::allocator<QtData*> >*) (qtconversion.cc:155) ==20489== by 0xA01215: QtOperationIterator::next() (qtoperationiterator.cc:231) ==20489== by 0xA51B13: QueryTree::evaluateRetrieval() (querytree.cc:172) ==20489== by 0x99CAF0: ServerComm::executeQuery(unsigned long, char const*, ExecuteQueryRes&) (servercomm2.cc:1600) ==20489== by 0x7E0504: doStuff() (directql.cc:1062) ==20489== by 0x7E0C4A: main (directql.cc:1128) ==20489== ==20489== LEAK SUMMARY: ==20489== definitely lost: 41,478,816 bytes in 1,728,284 blocks ==20489== indirectly lost: 5 bytes in 1 blocks ==20489== possibly lost: 4,200 bytes in 175 blocks ==20489== still reachable: 135,805 bytes in 662 blocks ==20489== suppressed: 0 bytes in 0 blocks
comment:5 by , 8 years ago
Milestone: | 9.3 → 9.4 |
---|
comment:6 by , 8 years ago
Owner: | set to |
---|---|
Status: | new → assigned |
Replying to dmisev:
Patch submitted for review, here's the most important valgrind output:
http://codereview.rasdaman.org/D266
So it seems like Vlad was supposed to take over, but I can't see anything committed yet.
@Vlad, what's the status about this issue?
comment:7 by , 8 years ago
Priority: | major → blocker |
---|
Bumping up priority, memory leaks should really be eliminated as much as possible.
comment:8 by , 8 years ago
Owner: | changed from | to
---|
comment:9 by , 8 years ago
Resolution: | → fixed |
---|---|
Status: | assigned → closed |
Can you put the rasql query here from the petascope log?