我的KT库之-----缓存与配置

了解或者认识KT:

http://www.cnblogs.com/kingthy/archive/2011/08/08/2130973.html

 

在项目中如何使用KT?

KT是一个库,所以将KT的dll文件引用到您的项目上即可使用KT里的函数功能。

 

本节将介绍大家认识KT库里的缓存与配置。它们都存放在“KT.Core“下,当你已在你的项目里引用了KT库后,则写下以下代码就可以使用到KT里的缓存与配置对象了。

using KT.Core;

 

缓存

KT的缓存只是简单的对.NET的缓存Cache进行了一个简单的包装,以便更方便的使用。

1、增加一个缓存项

//增加一个长时效的缓存项
Cache.Add("key1", DateTime.Now);
//增加一个具有绝对过滤时间的缓存项
Cache.Add("key2", DateTime.Now, DateTime.Today.AddDays(1));
//增加一个与文件关联的缓存项,如果文件有更改则缓存失效
Cache.Add("key3", DateTime.Now, "c:\cache.txt");

 

2、删除缓存项

//删除对应键值的缓存项
Cache.Remove("key1");
//清空所有缓存
Cache.Clear();

 

3、获取某个缓存项

//获取对应键值的缓存项
object value = Cache.Get("key1");
//获取对应键值的缓存项,如果缓存没有数据,则调用委托获取数据并存入缓存后返回
DateTime time = Cache.GetOrAdd<DateTime>("key2", () =>
{
    return DateTime.Now;
});

 

 

配置

平时在项目开发中,参数配置都习惯在项目配置文件(app.config或web.config)的AppSettings节点中配置,比如以下示例:

  <appSettings>
    <add key="api_key" value="key-2011" />
    <add key="api_secret" value="iu5r324323423422" />
  </appSettings>

程序代码里要使用参数时,直接调用即可,如下代码:

string api_key = ConfigurationManager.AppSettings["api_key"];
string api_secret = ConfigurationManager.AppSettings["api_secret"];

 

如果我们的参数非常的多,这将会导致我们的项目配置文件非常的大。并且如果在web项目中,我们的配置参数在运行过程中需要更改,则将会导致我们的web站点应用程序的重启!对于正常运行的项目来说,程序的重启是希望不要发生的,因为这将会导致session的丢失等相关问题。虽然我们可以在appSettings节点里使用file属性采用外部文件来配置避免这问题,但在某些场合下,file属性却是无能为力了。比如需要分多个配置文件存储不同的数据,file属性是无法做到的。

 

KT的配置

1、KT的配置文件

KT的配置文件,默认存储于程序根目录下的config目录,当然,你也可以自定义配置的存储路径,比如在app.config或web.config里的AppSettings节点里配置以下设置。

  <appSettings>
    <!--方法1:设置绝对路径-->
    <add key="KT.SETTINGS.BASEPATH" value="c:\data\config\" />
    <!--方法2:设置相对路径-->
    <add key="KT.SETTINGS.BASEPATH" value="~/data/config/" />
  </appSettings>

如果未设置则默认是程序的根目录(Web应用程序则是站点根目录;Windows应用程序则是可执行文件所在的目录)下的config目录

 

KT的配置文件采用的是标准xml文件,如下示例:

<?xml version="1.0" encoding="utf-8" ?>
<settings>
  <add key="k1" value="1" />
<k2>2</k2> <k.name>aliey</k.name> <k.age>20</k.age> </settings>

 

上面配置中,共定义了4个参数。其中k1参数的定义同.net里的appSettings一样,通过<add>节点元素定义;其它的参数都是采用节点形式定义。

KT的配置文件有两个特殊的节点<add><include>节点。

1、<add>节点:如果定义此节点,并且带有“key”属性,则表示增加一个参数,参数值由“value”属性定义。如果定义此节点,但不带有任何属性,则看作普通的参数"add”对待。如下面示例:

<?xml version="1.0" encoding="utf-8" ?>
<settings>
  <add key="k1" value="1" />
  <add>action/add</add>
</settings>

共定义了“k1”与“add”两个参数。

 

2、<include>节点:如果定义此节点,并且带有“file”属性,则表示是引用相关的配置文件。否则如果不带有任何属性,则看作普通的参数“include”对待。如下面示例:

<?xml version="1.0" encoding="utf-8" ?>
<settings>
  <add key="k1" value="1" />
  <add>action/add</add>
  <include file="mysettings.xml" />
  <include file="c:\config\mysettings2.xml" />
  <include>action/include</include>
</settings>

共导入了“mysettings.xml”与“c:\config\mysettings2.xml”两个配置文件里的配置参数,并且还定义了一个“include”参数,其中file属性的值可以是相对路径或绝对路径,如果是相对路径则是“相对于当前配置文件所在的路径”。

 

所有参数的节点都可以重复定义,但参数最终的值将由最后一个定义节点决定(注:“<include file=””>”节点是例外),即最后定义的将覆盖先前定义的值。如下示例:

<?xml version="1.0" encoding="utf-8" ?>
<settings>
  <add key="k1" value="1" />
  <k1>2</k1>
</settings>

最终,“k1"的值是“2”。

 

2、配置参数的获取

参数的获取是通过KT.Core.Settings实例类获取,此类共有几个静态方法和属性。

A、BasePath : 返回存储配置文件所在的基路径。此值可以通过上面所说的方法,在appSettings里修改。默认是程序根目录下的config目录.

B、Default : 返回默认存储配置文件的所有配置参数值。此默认配置参数存储于基路径下的"settings.config"文件。

C、From : 从配置文件获取配置参数。配置文件可以是相对路径或绝对路径,如果是相对路径则相对于BasePath。

D、Get<T>: 从配置文件获取配置参数并映射为某个实体类。配置文件可以是相对路径或绝对路径,如果是相对路径则相对于BasePath。

 

假如以下配置存储在基路径下的settings.config文件

<?xml version="1.0" encoding="utf-8" ?>
<settings>
  <add key="k1" value="1" />
<k2>2</k2> <k.name>aliey</k.name> <k.age>20</k.age> </settings>

那我们可以这样获取参数“k1”、“k2”、“k.name”的值

Console.WriteLine(Settings.Default["k1"]);
Console.WriteLine(Settings.Default["k2"]);
Console.WriteLine(Settings.Default["k.name"]);
Console.WriteLine(Settings.Default["k.age"]);

 

如果我们配置文件不是默认的“settings.config”文件,那我们可以这样获取配置

var setttings = Settings.From("mysettings.xml");
Console.WriteLine(setttings["k1"]);
Console.WriteLine(setttings["k2"]);
Console.WriteLine(setttings["k.name"]);
Console.WriteLine(setttings["k.age"]);

 

如果我们的配置文件结构可以映射为某个类,比如上面的配置文件可以映射为以下类结构

public class KItem
{
    public string Name { get; set; }
    public int Age { get; set; }
}
public class AppSettings
{
    public int K1 { get; set; }
    public int K2 { get; set; }
    public KItem K { get; set; } 
}

 

那我们还可以直接通过Get<T>方法直接获取配置实体类,如下面的示例:

var app = Settings.Get<AppSettings>("mysettings.xml");
 Console.WriteLine("K1={0}", app.K1);
 Console.WriteLine("K2={0}", app.K2);
 Console.WriteLine("K.Name={0}", app.K.Name);
 Console.WriteLine("K.Age={0}", app.K.Age);

 

由于AppSettings里的属性“K”是一个“KItem”类型,所以KT将会自动将“<k.name>”和“<k.age>”这两个节点映射为“KItem”类型的值.

 

注:KT的配置都已启用缓存功能,所以不需要担心它的效率问题。

 

我们可以用KT的配置做什么?

A、各应用程序之间的配置可以互相独立存放。 比如在WEB环境下,同一个站点下有多个不同的WEB应用程序,如论坛、博客、接口服务等等,那我们可以将它们的配置分别以不同的文件名存放于“基路径”下,如“forum.config”, “blog.config”,"service.config“,再调用From或Get<T>方法读取不同的文件名即可。

 

B、各应用程序之间的配置可以共享使用。比如上面例子所说的,如果“论坛”程序要调用“博客”里的参数,则我们可以在论坛的配置参数里加入“<include file=“blog.config”>”节点引入“博客”的配置参数。

 

C、各应用程序的配置可以统一存放。比如在WEB环境下,我们有A、B、C三个站点,这三个站点都需要用到同一个数据库,于是我们分别在这三个站点下写了一个同样用户名与密码的“ConnectionString“配置参数,当某一天,我们修改了数据库的用户密码,那我们就要分别打开这三个站点的目录去修改“ConnectionString”配置参数。而如果我们将A、B、C三个站点的KT配置的基路径设置为同一个目录,那我们就只要打开一个目录就可以修改到三个站点的参数了。

posted @ 2011-08-16 11:37  Kingthy  阅读(2429)  评论(4编辑  收藏  举报