Opened 12 years ago

Closed 9 years ago

#342 closed enhancement (duplicate)

Memory leak detection

Reported by: mrusu Owned by: Jinsongdi Yu
Priority: minor Milestone: 9.0.x
Component: systemtest Version: 8.4
Keywords: Cc:
Complexity: Medium

Description (last modified by mrusu)

Would be useful to have a memory leak detection option, especially combined with systemtest.

Change History (11)

comment:1 by Jinsongdi Yu, 12 years ago

Description: modified (diff)
Resolution: fixed
Status: newclosed

comment:2 by mrusu, 12 years ago

Description: modified (diff)
Resolution: fixed
Status: closedreopened

Reopened the ticket, since it refers to something else than ../systemtest/testcases_fixed/test_memleak
As I could see, test_memleak checks for errors 801 (system overload) or 206 (error in base dbms), but not for memory leaks caused by the code, when the allocated memory is not freed afterwards. I am sure there are quite a number of occurrences.

comment:3 by abeccati, 11 years ago

Thanks Mihaela, Would you please add a little more detail on the description about what should be done to solve this (e.g. use a code analysis tool or else).

Do we already have relevant consequences on that or will the servers restart (countdown) take care of cleaning them? In the latter case I think we can move this to "Future" milestone with minor priority.

Alan

comment:4 by Dimitar Misev, 11 years ago

I assume the test should run valgrind or similar on directql (not rasql, valgrind can't be attached to server processes), and automatically extract from the valgrind output whether there is a memleak or not.

Server restart can fix memleaks, but sometimes, e.g. nasty memleak during import or a million queries between restarts it can be fatal.

Last edited 11 years ago by Dimitar Misev (previous) (diff)

comment:5 by Dimitar Misev, 11 years ago

Milestone: 8.5
Priority: majorminor

I put it for 8.5 but Jin can reassign this to someone else or different milestone, he's the owner of systemtest after all.

comment:6 by Jinsongdi Yu, 11 years ago

the Makefile in systemtest should know —enable-debug and run the test.sh if the debug is on

comment:7 by Dimitar Misev, 11 years ago

What should it know?

comment:8 by Jinsongdi Yu, 11 years ago

the ./configure —enable-debug
with will set RMANDEBUG=on, CXXFLAGS+=" -g3 -gdwarf-2 -O0 "
test queries can be fetched from ../systemtest/testcases_mandatory/test_select/test_rasql/

comment:9 by Dimitar Misev, 11 years ago

We could try to write a C++ client directly integrated in the server in the style of directql or source:relblobif/test/test_tilecache.cc which would run all the queries in source:systemtest/testcases_mandatory, and run this through valgrind.

comment:10 by Dimitar Misev, 11 years ago

Milestone: 8.59.0

comment:11 by Dimitar Misev, 9 years ago

Resolution: duplicate
Status: reopenedclosed

duplicate #919

Note: See TracTickets for help on using tickets.