Cannot get the value from dogpile.cache from different modules.

xeon Mailinglist xeonmailinglist at gmail.com
Tue Dec 29 13:22:12 EST 2015


On Tuesday, December 29, 2015 at 5:38:17 PM UTC, xeon Mailinglist wrote:
> On Tuesday, December 29, 2015 at 5:33:43 PM UTC, Peter Otten wrote:
> > xeon Mailinglist wrote:
> > 
> > > On Tuesday, December 29, 2015 at 4:18:10 PM UTC, Peter Otten wrote:
> > >> xeon Mailinglist wrote:
> > >> 
> > >> > On Tuesday, December 29, 2015 at 11:16:10 AM UTC, xeon Mailinglist
> > >> > wrote:
> > >> >> 1. How do I create a global variable that can be accessed by all
> > >> >> classes?
> > >> >> 
> > >> >> 2. I am using `dogpile.cache` to store data in the cache [1], but if I
> > >> >> set and get the same key from different modules, I don't get the
> > >> >> value. Here is an example in [2]. The value than I get is
> > >> >> `NO_VALUE.NO_VALUE`. Why this happens?
> > >> 
> > >> >>     region = make_region().configure('dogpile.cache.memory')
> > >> 
> > >> The memory backend wraps a python dict whose contents are only available
> > >> to a single script and forgotten when that script ends.
> > >> 
> > >> My crystal ball tells me that you want to communicate between processes
> > >> rather than "modules" and need a backend that implements persistence.
> > >> "dogpile.cache.file" seems to be the one without dependencies outside the
> > >> standard library.
> > > 
> > > 
> > > No. 
> > 
> > Does "No" mean "I have run my code with another backend, and the modified 
> > script showed the same behaviour"?
> > 
> > > My problem is that I have method1() that calls method2() which calls
> > > myset(). method1() -> method2() -> myset(5). My problem is that, if I try
> > > to get the value of myset() inside method1(), I can't have it. It seems
> > > that the program has lost the value.
> > 
> > I can't make sense of that. You should be able to nest methods to your 
> > heart's content (as long as you don't reach the recursion limit).
> > 
> > Can you post minimal versions of your modules in such a way that I can 
> > easily run them over here? 
> > 
> > If you have only one process you probably have somehow managed to get two 
> > backend dicts. Unfortunately there's a blind spot on my crystal ball, and I 
> > can't see how exactly you did it...
> 
> No, I cannot get a simpler example. The simpler example works, and in my code, it doesn't. I thought that it was something related to the variable `region`, but I declare it as global. So, I think that all the sets will go to the same variable.

Strangely enough, when I put the set values in the method1(), it works ok. Is it because method2() is in a submodule of method1?



More information about the Python-list mailing list