文档章节

JFinal 中使用 Dubbo —— 2 部署及运行

 糊搞
发布于 2015/04/20 23:59
字数 926
阅读 2481
收藏 19

1. 部署及运行

1.1. 部署

请参见“JFinal教程1——小白的第一个JFinal程序”(http://my.oschina.net/u/1175852/blog/261235)中的相关章节,部署应用到Tomcat的步骤讲得比较详细。部署后结构如下图:

 

可以看到,ConsumerProvider都依赖Api项目。

 

1.2. 运行

ConsumerProvider无论谁先启动都可以,输入URL后,可以看到JFinal Demo原装页面了:

 

查看管制台,Provider输出了数据操作的SQLActiveRecordPlugin.setShowSql(true)),

 

页面和Provider都做出了期望的响应,整个Demo就此结束了吗!实际却不是,笔者在此处遇到好几个问题,后面将这些问题和解决方案一一道来。

 

1.3. Druid监控

通过Provider服务的“/druidaction可打开Druid监控页面:

 

即使可以通过启动类将Provider做为一般Java应用启动,但还是将其建成Web项目,原因就在于只有Web项目可以打开Druid监控。对于开发者来说,Sql的执行效率数据很有用。

 

1.4. 问题及解决方案

1.4.1. Controller.getModel(class)问题

Demo运行起来后,对Blog进行创建和修改操作时出现了“Html 500”的错误,Consumer中报错如下:

 

Blog列表功、创建和修改都没有问题,唯独保存功能出现异常。

 

通过调试,查到了问题的根源。在TableMapping中,与Blog表对应的Table数据中没有字段信息。因为字段信息是在ActiveRecordPlugin启动时通过TableBuilder从数据库中获取的。

此问题在一年前向 @JFinal 提出过,问题地址为:http://www.oschina.net/question/1175852_149042

解决方案有3种:

1. 写个APIBlog表手动添加字段信息,也就说ConsumerProvider全部采用Model交互。

2. 创建与Model对应的Java Bean,在Provider与数据库打交道时通过反射在ModelJava Bean之间转换,即采用Java Bean交互,但数据库操作还是使用ActiveRecordPlugin

3. 放弃ActiveRecordPluginConsumerProvider全部采用Java Bean交互。数据库操作采用HibernateIbatisORM

 

以上方案各有利弊,笔者为了修改量小,采用了第一种方案,即写了个API手动添加Blog表的字段信息。

  • 创建“com.jfinal.plugin.activerecord.TableInitKit.java”,名称空间是“com.jfinal.plugin.activerecord”,便于访问JFinalTableMapping的保护方法putTable()

public final class TableInitKit {

	/**
	 * 手动初始化Model对就的Table字段数据
	 * 
	 * @param tableName
	 *            表名
	 * @param modelClass
	 *            model的Class
	 * @param attrTypeMap
	 *            字段类型Map
	 */
	public static void init(String tableName, Class<? extends Model<?>> modelClass,
			Map<String, Class<?>> attrTypeMap) {
		init(tableName, "id", modelClass, attrTypeMap);
	}

	/**
	 * 手动初始化Model对就的Table字段数据
	 * 
	 * @param tableName
	 *            表名
	 * @param primaryKey
	 *            主键名
	 * @param modelClass
	 *            model的Class
	 * @param attrTypeMap
	 *            字段类型Map
	 */
	public static void init(String tableName, String primaryKey,
			Class<? extends Model<?>> modelClass, Map<String, Class<?>> attrTypeMapTypeMap) {
		Table blogTable = new Table(tableName, primaryKey, modelClass);
		blogTable.setColumnTypeMap(attrTypeMapTypeMap);

		TableMapping.me().putTable(blogTable);
	}
}
  • ConfigDemoConsumerConfig.afterJFinalStart()方法中添加如下代码:

@Override
	public void afterJFinalStart() {
		Map<String, Class<?>> blogColumnMap = new HashMap<String, Class<?>>();
		blogColumnMap.put("id", Integer.class);
		blogColumnMap.put("title", String.class);
		blogColumnMap.put("content", String.class);

		TableInitKit.init("blog", Blog.class, blogColumnMap);
		
		System.out.println("Blog表字段模拟完成。");
		
		System.out.println("Demo consumer for Dubbo启动完成。");
	}

重启Consumer之后,保存功能正常。至此,初步功能和架构已经完全能正常工作。



源码地址:

JFinalDubboDemoApi.zip

JFinalDubboDemoConsumer.zip

JFinalDubboDemoProvider.zip


Dubbo文档:

Dubbo 的文档镜像


系列文章:

JFinal 中使用 Dubbo —— 1 改造JFinal Demo

JFinal 中使用 Dubbo —— 3 集群


     

© 著作权归作者所有

共有 人打赏支持
粉丝 82
博文 5
码字总数 10741
作品 0
深圳
程序员
私信 提问
加载中

评论(4)

h
hypocrite11
JFinal 2.2应该不用这么麻烦做的吧。能做个2.2的demo吗
糊搞

引用来自“唐阳”的评论

比如说仍然用dubbo将service 端的table 信息传入consumer 端?
真实业务下不现实,因为它会暴露服务端机密。 其实Model就不适合当成Dto,还是用Java Bean靠谱。。。后端用Model转Java Bean,性能也还可以的。
五杀联盟
五杀联盟
比如说仍然用dubbo将service 端的table 信息传入consumer 端?
五杀联盟
五杀联盟
能不能自动注册?
JFinal 中使用 Dubbo —— 1 改造JFinal Demo

Dubbo Demo概述 此Demo实际在2014年上半年就已经完成了,只是到最近才有时间和心情写完此文。同时,将JFinal升级到了1.9,并采用Maven构建项目。 另外,仔细想了想,Provider其实可以不依托T...

糊搞
2015/04/20
0
16
JFinal 中使用 Dubbo —— 3 集群

集群 1.1. 部署结构 下面是一个简单的Cunsumer端服务器和Provider端服务器分别集群的部署图: 在个人开发机上,实现Cunsumer端服务器集群难以实现,所以此Demo中只实现Provider端服务器集群,...

糊搞
2015/04/21
0
25
JFinal-Beetl-Shiro(JdbcRealm)-例子

JFinal-Shiro-JDBC-Demo http://git.oschina.net/yinjun622/JFinal-Shiro-JDBC-Demo 简单实现@JFinal与Shiro整合例子 1、工程通过Eclipse直接导入,部署到tomcat中; 2、新建jfinalshiro数据......

leon_rock
2014/02/27
0
12
RSF 1.0.1 分布式服务框架,新增 Spring/JFinal 支持

RSF 1.0.1 分布式服务框架,新增 Spring/JFinal 支持。 Hasor-RSF是一个高可用、高性能、轻量级的分布式服务框架。支持容灾、负载均衡、集群。一个典型的应用场景是,将同一个服务部署在多个...

哈库纳
2016/11/08
2.2K
8
JFinal可以与阿里的dubbo,负载均衡的nginx对接么?Jfinal适合用来做大型项目么?

@JFinal 你好,想跟你请教个问题: JFinal开发效率挺不错的。我们的应用将来的访问量会很大,肯定要考虑软负载、缓存、分布式服务等技术架构,JFinal可以与阿里的dubbo, nginx,redis对接么...

jason9988
2014/11/12
5.6K
6

没有更多内容

加载失败,请刷新页面

加载更多

阿里大规模数据中心性能分析

郭健美,阿里巴巴高级技术专家,目前主要从事数据中心的性能分析和软硬件结合的性能优化。CCF 系统软件专委和软件工程专委的委员。曾主持国家自然科学基金面上项目、入选上海市浦江人才计划A...

阿里云官方博客
25分钟前
0
0
Coding and Paper Letter(四十四)

资源整理。 1 Coding: 1.Rstudio2019年会“机器学习应用”的幻灯片,代码和数据 rstudio conf 2019 2.R语言包sparkxgb,Spark上XGBoost的R接口。 sparkxgb 3.自动SQL注入和数据库接管工具。 ...

胖胖雕
27分钟前
0
0
Ubuntu最新的主要操作系统放弃32位支持?

现在是2018年,2019年即将到来——64位处理器已经成为主流很长一段时间了。如果你仍然使用32位的电脑,那么是时候把它扔进垃圾箱了。 我为所有基于Linux的操作系统维护者感到自豪,他们有勇气...

Linux就该这么学
29分钟前
0
0
Fundebug发布Vue插件,简化BUG监控接入代码

摘要: 代码越短越好! 我们发布了fundebug-vue插件,可以简化Vue框架接入Fundebug的代码。 Vue如何接入Fundebug 1. 安装fundebug-javascript与fundebug-vue npm install fundebug-javascrip...

Fundebug
36分钟前
0
0
MySQL学习笔记之二

数据库的操作总结就是:增删改查(CURD),今天记录一下基础的检索查询工作。 检索MySQL 1.查询表中所有的记录 mysql> select * from apps;+----+------------+-----------------------+------...

凌宇之蓝
46分钟前
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部