文档章节

Castle ActiveRecord学习实践(2):构建配置信息

邓小峰
 邓小峰
发布于 2009/03/26 20:38
字数 1535
阅读 2100
收藏 0

摘要:ActiveRecord在底层封装了NHibernate,在框架启动时需要指定相关的配置信息,那么我们需要配置些什么?又该如何去配置呢?本文将会介绍在ActiveRecord中构建配置信息。

主要内容

1.需要配置什么

2.如何去配置

3.常见的配置示例

 

一.需要配置什么

在第一篇大家都已经看到了,其实我们的配置信息跟用NHibernate时的配置是一样的,这是因为ActiveRecord在底层封装了NHibernate。为了没有用过NHibernate的朋友,这里再把配置信息简单介绍一下。

1.配置NHibernate ADO.NET属性

 

属性名

 

说明

 

hibernate.connection.provider_class

 

 

定制

IConnectionProvider

的类型.

例如:

full.classname.of.ConnectionProvider

(如果提供者创建在NHibernate中), 或者

full.classname.of.ConnectionProvider, assembly

(如果使用一个自定义的IConnectionProvider接口的实现,它不属于NHibernate)。

 

hibernate.connection.driver_class

 

 

定制

IDriver

的类型.

full.classname.of.Driver

(如果驱动类创建在NHibernate中), 或者

full.classname.of.Driver, assembly

(如果使用一个自定义IDriver接口的实现,它不属于NHibernate)。

 

hibernate.connection.connection_string

 

 

用来获得连接的连接字符串。

 

hibernate.connection.isolation

 

 

设置事务隔离级别. 请检查

System.Data.IsolationLevel

来得到取值的具体意义并且查看数据库文档以确保级别是被支持的。

例如:

Chaos, ReadCommitted, ReadUncommitted, RepeatableRead, Serializable, Unspecified

 

2.可选的配置属性

除了上面的ADO.NET属性之外,我们还有如下的可选属性

 

属性名

 

说明

 

hibernate.dialect

 

 

NHibernate方言(Dialect)的类名 - 可以让NHibernate使用某些特定的数据库平台的特性

例如:

full.classname.of.Dialect

(如果方言创建在NHibernate中), 或者

full.classname.of.Dialect, assembly

(如果使用一个自定义的方言的实现,它不属于NHibernate)。

 

hibernate.default_schema

 

 

在生成的SQL中,scheml/tablespace的全限定名.

例如:

SCHEMA_NAME

 

 

hibernate.prepare_sql

 

 

是否准备sql语句

例如:

true

|

false

 

 

hibernate.session_factory_name

 

 

SessionFactory

被创建后将自动绑定这个名称.

例如:

some.name

 

 

hibernate.use_outer_join

 

 

允许使用外连接抓取。

例如:

true

|

false

 

 

hibernate.cache.provider_class

 

 

指定一个自定义的

CacheProvider

缓存提供者的类名

例如:

full.classname.of.CacheProvider

(如果ICacheProvider创建在NHibernate中), 或

full.classname.of.CacheProvider, assembly

(如果使用一个自定义的ICacheProvider,它不属于NHibernate)。

 

hibernate.query.substitutions

 

 

把NHibernate查询中的一些短语替换为SQL短语(比如说短语可能是函数或者字符)。

例如:

hqlLiteral=SQL_LITERAL, hqlFunction=SQLFUNC

 

可以数据库设置一个hibernate.dialect方言,它是NHibernate.Dialect.Dialect 的一个子类。如果不需要使用基于native或者sequence的主键自动生成算法,或者悲观锁定(使用ISession.Lock() 或者 IQuery.SetLockMode())的话,方言就可以不必指定。然而,假若你指定了一个方言,Hibernate会为上面列出的一些属性使用特殊默认值,省得我们手工指定。

NHibernate SQL 方言对照表:

 

数据库系统

 

SQL方言

 

DB2

 

NHibernate.Dialect.DB2Dialect

 

 

PostgreSQL

 

NHibernate.Dialect.PostgreSQLDialect

 

 

MySQL

 

NHibernate.Dialect.MySQLDialect

 

 

Oracle (any version)

 

NHibernate.Dialect.OracleDialect

 

 

Oracle 9/10g

 

NHibernate.Dialect.Oracle9Dialect

 

 

Sybase

 

NHibernate.Dialect.SybaseDialect

 

 

Microsoft SQL Server 2000

 

NHibernate.Dialect.MsSql2000Dialect

 

 

Microsoft SQL Server 7

 

NHibernate.Dialect.MsSql7Dialect

 

 

Firebird

 

NHibernate.Dialect.FirebirdDialect

 

二.如何去配置

ActiveRecord为我们提供了三种方式的配置

1.XmlConfigurationSource配置

可以使用自己的XML文件来保存配置信息,例如有一个MyConfig.xml的文件

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<?xml version="1.0" encoding="utf-8" ?>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<activerecord>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客    <config>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客        <add key="hibernate.connection.driver_class" value="NHibernate.Driver.SqlClientDriver" />

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客        <add key="hibernate.dialect" value="NHibernate.Dialect.MsSql2000Dialect" />

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客        <add key="hibernate.connection.provider" value="NHibernate.Connection.DriverConnectionProvider" />

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客        <add key="hibernate.connection.connection_string" value="Data Source=.;Initial Catalog=ARDemo;UID=sa;Password=sa" />

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客    </config>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客</activerecord>

 这时候我们在框架初始化的时候就应该这样写:

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客XmlConfigurationSource source = new XmlConfigurationSource("MyConfig.xml");

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客ActiveRecordStarter.Initialize(source,typeof(ActiveRecordBase));

其中XmlConfigurationSource通过重载提供了如下三个公用的构造函数

public XmlConfigurationSource(String xmlFileName)

public XmlConfigurationSource(Stream stream)

public XmlConfigurationSource(TextReader reader)

不管是以文件名还是Stream形式或者TextReader,在XmlConfigurationSource的内部都会转换为XmlDocument。最后要注意xml文件的路径,可以用生成后事件命令拷贝.xml文件到bin目录下

copy "$(ProjectDir)\*.xml" "$(TargetDir)"

2.InPlaceConfigurationSource配置

这种实现是一种硬编码的方式,在实际的使用中并不推荐,但是有时候如果我们的配置信息是动态的获取,则这种方式就会变得非常有用。

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客InPlaceConfigurationSource source = new InPlaceConfigurationSource();

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客Hashtable properties = new Hashtable();

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客properties.Add("hibernate.connection.driver_class", "NHibernate.Driver.SqlClientDriver");

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客properties.Add("hibernate.dialect", "NHibernate.Dialect.MsSql2000Dialect");

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客properties.Add("hibernate.connection.provider", "NHibernate.Connection.DriverConnectionProvider");

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客properties.Add("hibernate.connection.connection_string", "UID=sa;Password=19811218;Initial Catalog=ARDemo;Data Source=.");

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客source.Add( typeof(ActiveRecordBase), properties );

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客ActiveRecordStarter.Initialize( source, typeof(ActiveRecordBase) );

 

3.使用应用程序配置文件

这种方式是最为常见的一种,即使用应用程序的配置文件(Web.config 或者App.config),在配置文件中

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<?xml version="1.0" encoding="utf-8" ?>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<configuration>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客    <configSections>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客        <section name="activerecord" type="Castle.ActiveRecord.Framework.Config.ActiveRecordSectionHandler, Castle.ActiveRecord" />

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客    </configSections>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客    <activerecord>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客        <config>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客            <add key="hibernate.connection.driver_class" value="NHibernate.Driver.SqlClientDriver" />

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客            <add key="hibernate.dialect" value="NHibernate.Dialect.MsSql2000Dialect" />

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客            <add key="hibernate.connection.provider" value="NHibernate.Connection.DriverConnectionProvider" />

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客            <add key="hibernate.connection.connection_string" value="UID=sa;Password=sa;Initial Catalog=ARDemo;Data Source=." />

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客        </config>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客    </activerecord>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客</configuration>

 

 

这时候我们的框架初始化代码应该这样写

[.NET1.1]

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客IConfigurationSource source = System.Configuration.ConfigurationSettings.GetConfig("activerecord") as IConfigurationSource;

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客ActiveRecordStarter.Initialize( source, typeof(ActiveRecordBase) ); 

 

[.NET2.0]

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客IConfigurationSource source = System.Configuration. ConfigurationManager.GetSection ("activerecord") as IConfigurationSource;

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客ActiveRecordStarter.Initialize( source, typeof(ActiveRecordBase) );

 

4.在Web应用程序中的配置

如果我们是在Web应用程序中使用ActiveRecord,需要指定isWeb="true",如下

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<activerecord isWeb="true">

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客    <config>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客        <add key="hibernate.connection.driver_class" value="NHibernate.Driver.SqlClientDriver" />

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客        <add key="hibernate.dialect" value="NHibernate.Dialect.MsSql2000Dialect" />Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客        <add key="hibernate.connection.provider" value="NHibernate.Connection.DriverConnectionProvider" />

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客        <add key="hibernate.connection.connection_string" value="UID=sa;Password=sa;Initial Catalog=ARDemo;Data Source=." />

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客    </config>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客</activerecord>

 

 

一般的初始化工作我们会放在Application_ Start中,示例代码

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客protected void Application_Start(Object sender, EventArgs e)

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客{

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客    IConfigurationSource source = 

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客        System.Configuration.ConfigurationSettings.GetConfig("activerecord") as IConfigurationSource;

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客    ActiveRecordStarter.Initialize( source, typeof(ActiveRecordBase));

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客}

 

三.常见的配置示例

Castle网站为我们提供的几个常见的配置示例

1.MS SQLServer

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<activerecord>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客    <config>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客        <add key="hibernate.connection.driver_class" value="NHibernate.Driver.SqlClientDriver" />

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客        <add key="hibernate.dialect" value="NHibernate.Dialect.MsSql2000Dialect" />

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客        <add key="hibernate.connection.provider" value="NHibernate.Connection.DriverConnectionProvider" />

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客        <add key="hibernate.connection.connection_string" value="Data Source=.;Initial Catalog=test;UID=sa;Password=sa" />

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客    </config>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客</activerecord>

 

2.Oracle

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<activerecord>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客    <config>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客        <add key="hibernate.connection.driver_class" value="NHibernate.Driver.OracleClientDriver" />

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客        <add key="hibernate.dialect" value="NHibernate.Dialect.OracleDialect" />

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客        <add key="hibernate.connection.provider" value="NHibernate.Connection.DriverConnectionProvider" />

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客        <add key="hibernate.connection.connection_string" value="Data Source=dm;User ID=dm;Password=dm;" />

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客    </config>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客</activerecord>

 

 

3.MySQL

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<activerecord>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客    <config>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客        <add key="hibernate.connection.driver_class" value="NHibernate.Driver.MySqlDataDriver" />

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客        <add key="hibernate.dialect" value="NHibernate.Dialect.MySQLDialect" />

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客        <add key="hibernate.connection.provider" value="NHibernate.Connection.DriverConnectionProvider" />

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客        <add key="hibernate.connection.connection_string" value="Database=test;Data Source=someip;User Id=blah;Password=blah" />

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客    </config>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客</activerecord>

4.Firebird

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<activerecord>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客    <config>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客        <add key="hibernate.connection.driver_class" value="NHibernate.Driver.FirebirdDriver" />

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客        <add key="hibernate.dialect" value="NHibernate.Dialect.FirebirdDialect" />

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客        <add key="hibernate.connection.provider" value="NHibernate.Connection.DriverConnectionProvider" />

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客        <add key="hibernate.connection.connection_string" value="Server=localhost;Database=d:\db.fdb;User=SYSDBA;password=masterkey;ServerType=1;Pooling=false" />

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客        <add key="hibernate.query.substitutions" value="true 1, false 0" />

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客    </config>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客</activerecord>

5.PostgreSQL

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<activerecord>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客    <config>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客        <add key="hibernate.connection.driver_class" value="NHibernate.Driver.NpgsqlDriver" />

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客        <add key="hibernate.dialect" value="NHibernate.Dialect.PostgreSQLDialect" />

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客        <add key="hibernate.connection.provider" value="NHibernate.Connection.DriverConnectionProvider" />

        <add key="hibernate.connection.connection_string" value="Server=localhost;initial catalog=nhibernate;User ID=nhibernate;Password=nhibernate;" />

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客    </config>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客</activerecord>

 

关于ActiveRecord构建配置信息的介绍就这么多了,内容比较简单。下篇文章中我会详细介绍ActiveRecord中的映射,希望研究过Castle的朋友不吝赐教。

© 著作权归作者所有

邓小峰
粉丝 27
博文 38
码字总数 17272
作品 0
广州
高级程序员
私信 提问
Castle ActiveRecord学习实践(1):快速入门指南

单表使用 建立一下表 CREATE TABLE [dbo].[Employees] ( [Employeesid] [int] IDENTITY (1, 1) NOT NULL , [LogonName] [varchar] (40) COLLATE Chinese_PRC_CI_AS NULL , [LastLogon] [dat......

邓小峰
2009/03/26
3K
0
Castle Active Record for .NET2.0快速入门示例

单表使用 建立一下表 CREATE TABLE [dbo].[Employees] ( [Employeesid] [int] IDENTITY (1, 1) NOT NULL , [LogonName] [varchar] (40) COLLATE Chinese_PRC_CI_AS NULL , [LastLogon] [dat......

邓小峰
2009/03/26
1K
0
ActiveRecord 不要把它当DTO 为什么

@JFinal 你好,想跟你请教个问题: 我是初学jfinal,这些天都在研究这个框架,感觉非常不错,这里有个疑问希望你能帮忙.下面是我在网上查看资料找到的 JFinal采用ActiveRecord实现数据库操作支持...

愤怒的大菠萝
2012/12/11
359
4
脱离Rails使用ActiveRecord

ActiveRecord是Ruby的对象-关系映射(ORM)框架,它几乎总是被视为Rails框架的一部分,但其自身也是一个实体,可通过gem单独安装和使用。本文以访问Sqlite3为例,介绍如何在Rails框架之外使用...

redraiment
2014/02/11
0
2
Ruby缺失的define_class

Ruby默认提供了等工具用于动态定义实例方法,但貌似没提供动态定义类的方法。 所谓动态定义类,不是指动态创建类,而是指类名是用字符串或符号动态给定的。看完《Ruby元编程》后,我尝试着自...

redraiment
2014/02/20
0
1

没有更多内容

加载失败,请刷新页面

加载更多

springmvc java对象转json,上传下载(未完)拦截器Interceptor以及源码解析(未完待续)

package com.atguigu.my.controller;import java.util.Collection;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Contr......

architect刘源源
38分钟前
22
0
[日更-2019.5.24、25、26] Android系统中的Binder通信机制分析(一)--servicemanager

声明 其实对于Android系统Binder通信的机制早就有分析的想法,记得去年6、7月份Mr.Deng离职期间约定一起对其进行研究的,但因为我个人问题没能实施这个计划,留下些许遗憾... 最近,刚好在做...

Captain_小馬佩德罗
昨天
19
0
聊聊dubbo的DataStore

序 本文主要研究一下dubbo的DataStore DataStore dubbo-2.7.2/dubbo-common/src/main/java/org/apache/dubbo/common/store/DataStore.java @SPI("simple")public interface DataStore { ......

go4it
昨天
2
0
17.windows上安装kafka并简单应用

1.单机版 1.1 安装jdk 略 1.2 安装zookeeper https://my.oschina.net/springMVCAndspring/blog/3045210 1.3 安装window上安装kafka 1.3.1 下载 http://kafka.apache.org/downloads 1.3.2 解压......

20190513
昨天
2
0
缓存雪崩

缓存雪崩原因:大批次的缓存数据,同一时刻过期 解决方案: 1、尽可能避免所有缓存在同一时刻过期,即:合理调整过期策略 2、对条件加锁 伪代码: public ProductselectProduct(String id){ ...

少年已不再年少
昨天
10
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部