gpt4 book ai didi

c# - 如何访问我只需要在 Application.Start 上创建一次的变量

转载 作者:行者123 更新时间:2023-12-03 03:14:06 26 4
gpt4 key购买 nike

根据本指南: https://github.com/mspnp/azure-guidance/blob/master/Retry-Service-Specific.md

他们说:

请注意,StackExchange.Redis 客户端通过单个连接使用多路复用。建议的用法是在应用程序启动时创建客户端实例,并将该实例用于针对缓存的所有操作。因此,与缓存的连接仅建立一次,因此本节中的所有指导都与此初始连接的重试策略相关,而不是与访问缓存的每个操作相关。

现在我有这样的事情:

public static Models.UserProfile GetUserProfile(string identityname)
{
/// It needs to be cached for every user because every user can have different modules enabled.
try
{
var cachekeyname = "UserProfileInformation|" + identityname;
IDatabase cache = CacheConnectionHelper.Connection.GetDatabase();
Models.UserProfile userProfile = new Models.UserProfile();
object obj = cache.Get(cachekeyname);

我可以将连接线移至global.asax

protected void Application_Start()
{

IDatabase cache = CacheConnectionHelper.Connection.GetDatabase();

}

如果我移动该行,那么如何在需要使用它的其他方法上获取该实例?

这是缓存连接助手

public class CacheConnectionHelper
{
private static Lazy<ConnectionMultiplexer> lazyConnection = new Lazy<ConnectionMultiplexer>(() =>
{
return ConnectionMultiplexer.Connect(SettingsHelper.AzureRedisCache);
});

public static ConnectionMultiplexer Connection
{
get
{
return lazyConnection.Value;
}
}
}

最佳答案

您可以在 global.asax 文件中将其设为静态

public class Global : HttpApplication {
public static IDatabase Cache = CacheConnectionHelper.Connection.GetDatabase();
void Application_Start(object sender, EventArgs e) {

}
.....
}

现在,您只需访问 Global.Cache(数据库的单个实例)即可访问任何类中的数据库对象。

关于c# - 如何访问我只需要在 Application.Start 上创建一次的变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31328511/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com