Best Practices |
data:image/s3,"s3://crabby-images/82452/82452c4ad3a01bacc11fa05aba7080a5686aafdb" alt="" |
2025-02-23 |
data:image/s3,"s3://crabby-images/f5c4e/f5c4e950ae91cafaa5bd09aa2a94bc90f0ddd60e" alt="" |
data:image/s3,"s3://crabby-images/fe077/fe0773e678923fc9067b482c1ee247bb70928e2c" alt="" |
data:image/s3,"s3://crabby-images/f5c4e/f5c4e950ae91cafaa5bd09aa2a94bc90f0ddd60e" alt=""
34 |
data:image/s3,"s3://crabby-images/be055/be055520f6581389e64a9f9f18d6cf3b830142df" alt="" |
data:image/s3,"s3://crabby-images/f5c4e/f5c4e950ae91cafaa5bd09aa2a94bc90f0ddd60e" alt="" |
All Hail Valgrind!
Valgrind Tools
- • Memcheck
- • Addrcheck
- • Cachegrind
- • Helgrind
Also make sure you use an atomic file deployment mechanism like rsync or mv.
Never tar or cp files to their final destinations on a running production server.
Beware of cache slams
When a file is modified on a busy server there is a race to compile and cache the
new file. This can put a drain on your server and its resources. Because APC uses
the device+inode as the hash, you can make use of that in your file update strategy.
Write new files to a temporary filename or perhaps a temporary directory, hit it once,
then rename it to its publically visible location. mtime does not change on a rename
as long as you are not moving it from one fs to another.