type Cache struct {
        Fs afero.Fs
 
-       // Max age in seconds.
-       maxAge int
+       // Max age for items in this cache. Negative duration means forever,
+       // 0 is effectively turning this cache off.
+       maxAge time.Duration
 
        nlocker *locker.Locker
 }
 }
 
 // NewCache creates a new file cache with the given filesystem and max age.
-func NewCache(fs afero.Fs, maxAge int) *Cache {
+func NewCache(fs afero.Fs, maxAge time.Duration) *Cache {
        return &Cache{
                Fs:      fs,
                nlocker: locker.NewLocker(),
                        return nil
                }
 
-               expiry := time.Now().Add(-time.Duration(c.maxAge) * time.Second)
-               expired := fi.ModTime().Before(expiry)
-               if expired {
+               if time.Now().Sub(fi.ModTime()) > c.maxAge {
                        c.Fs.Remove(id)
                        return nil
                }
 
        "path"
        "path/filepath"
        "strings"
+       "time"
 
        "github.com/gohugoio/hugo/helpers"
        "github.com/gohugoio/hugo/hugolib/paths"
 type cacheConfig struct {
        // Max age of cache entries in this cache. Any items older than this will
        // be removed and not returned from the cache.
-       // -1 means forever, 0 means cache is disabled.
-       MaxAge int
+       // a negative value means forever, 0 means cache is disabled.
+       MaxAge time.Duration
 
        // The directory where files are stored.
        Dir string
        for k, v := range m {
                cc := defaultCacheConfig
 
-               if err := mapstructure.WeakDecode(v, &cc); err != nil {
+               dc := &mapstructure.DecoderConfig{
+                       Result:           &cc,
+                       DecodeHook:       mapstructure.StringToTimeDurationHookFunc(),
+                       WeaklyTypedInput: true,
+               }
+
+               decoder, err := mapstructure.NewDecoder(dc)
+               if err != nil {
+                       return c, err
+               }
+
+               if err := decoder.Decode(v); err != nil {
                        return nil, err
                }
 
 
        "path/filepath"
        "runtime"
        "testing"
+       "time"
 
        "github.com/gohugoio/hugo/config"
        "github.com/gohugoio/hugo/hugofs"
        configStr := `
 [caches]
 [caches.getJSON]
-maxAge = 1234
+maxAge = "10m"
 dir = "/path/to/c1"
 [caches.getCSV]
-maxAge = 3456
+maxAge = "11h"
 dir = "/path/to/c2"
 [caches.images]
 dir = "/path/to/c3"
        assert.Equal(4, len(decoded))
 
        c2 := decoded["getcsv"]
-       assert.Equal(3456, c2.MaxAge)
+       assert.Equal("11h0m0s", c2.MaxAge.String())
        assert.Equal(filepath.FromSlash("/path/to/c2"), c2.Dir)
 
        c3 := decoded["images"]
-       assert.Equal(-1, c3.MaxAge)
+       assert.Equal(time.Duration(-1), c3.MaxAge)
        assert.Equal(filepath.FromSlash("/path/to/c3"), c3.Dir)
 
 }
        assert.Equal(4, len(decoded))
 
        for _, v := range decoded {
-               assert.Equal(0, v.MaxAge)
+               assert.Equal(time.Duration(0), v.MaxAge)
        }
 
 }
 
 cacheDir = "CACHEDIR"
 [caches]
 [caches.getJSON]
-maxAge = 111
+maxAge = "10h"
 dir = ":cacheDir/c"
 
 `
 
                c := caches.Get("GetJSON")
                assert.NotNil(c)
-               assert.Equal(111, c.maxAge)
+               assert.Equal("10h0m0s", c.maxAge.String())
 
                bfs, ok := c.Fs.(*afero.BasePathFs)
                assert.True(ok)
        configStr := `
 [caches]
 [caches.getjson]
-maxAge = 1
+maxAge = "1s"
 dir = "/cache/c"
 
 `
 
 : This is the value of the `resourceDir` config option.
 
 maxAge
-: This is the time in seconds before a cache entry will be evicted, -1 means forever and 0 effectively turns that particular cache off.
-
+: This is the duration before a cache entry will be evicted, -1 means forever and 0 effectively turns that particular cache off. Uses Go's `time.Duration`, so valid values are `"10s"` (10 seconds), `"10m"` (10 minutes) and `"10m"` (10 hours).
+ 
 dir
 : The absolute path to where the files for this cache will be stored. Allowed starting placeholders are `:cacheDir` and `:resourceDir` (see above).