在EF Core 2.0中,可以把上下文放在池中,以提高性能。连接已经放在池中好长时间了。应在需要连接之前打开它们,使用之后立即关闭它们。在EF Core中,这个行为已经在框架中实现了。关闭连接时,对数据库服务器的连接并没有真正关闭,而是把连接返回连接池,以便在打开下一个连接时重用。连接池用连接字符串配置。
DbContext的用法规则与连接类似。它们也应在需要之前创建,在使用之后立即关闭(销毁)。其开销没有我们想象的那么大。模型不是在调用每个新上下文时初始化,而是重用模型。在Entity Framework和XML文件映射中,创建上下文的开销比目前的EF Core大许多。但是,如果上下文比较大,创建它的开销仍可能比较客观。此时就可以使用上下文池来提高性能。
为了使用上下文池,必需使用依赖注入。要激活上下文池,只需要把EF Core注册从AddDbContext改为AddDbContextPool。这样,注入的上下文(示例代码中是BooksContext)就可以从上下文池中检索出来:
private static void InitializeServices()
{
const string ConnectionString =
@"server=(localdb)\MSSQLLocalDB;database=WXGBooks;trusted_connection=true";
var services = new ServiceCollection();
services.AddTransient<BooksService>()
.AddEntityFrameworkSqlServer()
.AddDbContextPool<BooksContext>(options =>
options.UseSqlServer(ConnectionString));
services.AddLogging();
Container = services.BuildServiceProvider();
}