Sometime I will implement changes locally and they work fine, I copy them to my remote webserver and the changed are ignored. (The code is identical.)
I go into core.php, change debugging to 3, check again… it works!
I have a feeling it’s something to do with cache but I don’t know what exactly to change.
CakePHP has a cache located in
/app/tmp/cache. The directory structure looks like this:The main issue usually experienced is with the model cache. When debug is off (ie. in production) and you cause CakePHP to dispatch, it introspects the schema of all your database tables and stores these in flat files in the
modelsfolder above. If you do not delete the files in this folder, CakePHP will start to say models/tables/fields don’t exist when they clearly do in your database.If you enable view caching in your application, when views are rendered for the first time CakePHP will compile flat files to the
viewsfolder to prevent having to render these views again on the next request.During CakePHP’s bootstrap process it has to determine the directory structure you are using in your installation before it can access important files (like
database.php). As such, CakePHP will generate cache files to thepersistentdirectory with the absolute paths to each and every important directory and file, any plugins you are using and even any localisations you have created so it can quickly translate your application between languages without reparsing.potfiles.So, simply put, you have to remember to delete all of the files in these directories whenever you make code changes to an application that is in production, or add this as part of your deployment mechanism. You must not delete any of the directories however.
The reason changing debug to 3 works for you is because when debug mode is turned on (at any value greater zero) the cache is cleared and regenerated on every request, but – while this works – it is not easy to automate.
There are a number of ways to do this programmatically – including shell commands, CakePHP plugins, Capistrano configs, Ant files – but one can also just do so manually.