Web api 中的内存缓存

问题描述 投票:0回答:1

我在我的Web API中寻找Caching,我可以使用一个API方法的输出(每12小时更改一次)进行后续调用,然后我在SO上找到了这个解决方案,但我很难理解并使用下面的代码

private IEnumerable<TEntity> GetFromCache<TEntity>(string key, Func<IEnumerable<TEntity>> valueFactory) where TEntity : class 
{
    ObjectCache cache = MemoryCache.Default;
    var newValue = new Lazy<IEnumerable<TEntity>>(valueFactory);            
    CacheItemPolicy policy = new CacheItemPolicy { AbsoluteExpiration = DateTimeOffset.Now.AddMinutes(30) };
    //The line below returns existing item or adds the new value if it doesn't exist
    var value = cache.AddOrGetExisting(key, newValue, policy) as Lazy<IEnumerable<TEntity>>;
    return (value ?? newValue).Value; // Lazy<T> handles the locking itself
}

我不知道如何在下面的上下文中调用和使用这个方法? 我有一个方法 Get

  public IEnumerable<Employee> Get()
    {
        return repository.GetEmployees().OrderBy(c => c.EmpId);
    }

我想缓存 Get 的输出并在我的其他方法 GetEmployeeById() 或 Search() 中使用它

        public Movie GetEmployeeById(int EmpId)
        {
           //Search Employee in Cached Get
        }

        public IEnumerable<Employee> GetEmployeeBySearchString(string searchstr)
        {
          //Search in Cached Get
        }
c# asp.net-mvc asp.net-web-api asp.net-web-api2 memorycache
1个回答
11
投票

我更新了您的方法以返回类而不是

IEnumerable

private TEntity GetFromCache<TEntity>(string key, Func<TEntity> valueFactory) where TEntity : class 
{
    ObjectCache cache = MemoryCache.Default;
    // the lazy class provides lazy initializtion which will evaluate the valueFactory expression only if the item does not exist in cache
    var newValue = new Lazy<TEntity>(valueFactory);            
    CacheItemPolicy policy = new CacheItemPolicy 
                                 {
                                     AbsoluteExpiration = DateTimeOffset.Now.AddMinutes(30) 
                                 };

    // The line below returns existing item or adds the new value if it doesn't exist
    var value = cache.AddOrGetExisting(key, newValue, policy) as Lazy<TEntity>;

    return (value ?? newValue).Value; // Lazy<T> handles the locking itself
}

那么你可以像这样使用这个方法:

public Movie GetMovieById(int movieId)
{
    var cacheKey = "movie" + movieId;

    var movie = GetFromCache<Movie>(cacheKey, () => {       
        // load movie from DB
        return context.Movies.First(x => x.Id == movieId); 
    });

    return movie;
}

并搜索电影

[ActionName("Search")]
public IEnumerable<Movie> GetMovieBySearchParameter(string searchstr)
{
     var cacheKey = "movies" + searchstr;
     var movies = GetFromCache<IEnumerable<Movie>>(cacheKey, () => {               
          return repository.GetMovies().OrderBy(c => c.MovieId).ToList(); 
     });

     return movies;
}
© www.soinside.com 2019 - 2024. All rights reserved.