nodejs2java
基于 eggjs + dubbo2.js 搭建的nodejs-java后端rpc微服务框架。
开始
详细参考egg官方文档 egg docs
开发
$ npm i
$ npm run dev
$ open http://localhost:7002/
部署
$ npm start
$ npm stop
npm scripts
- Use
npm run lint to check code style.
- Use
npm test to run unit test.
- Use
npm run autod to auto detect dependencies upgrade, see autod for more detail.
dubbo
nodejs 使用原生的 dubbo 协议打通了 dubbo 的 rpc 方法调用 .
安装依赖
yarn add dubbo2.js
用法举例
import {Dubbo, java, TDubboCallResult} from 'dubbo';
interface IDemoService {
sayHello(name: string): TDubboCallResult<string>;
echo(): TDubboCallResult<string>;
test(): TDubboCallResult<void>;
getUserInfo(): TDubboCallResult<{
status: string;
info: {id: number; name: string};
}>;
}
const dubbo = new Dubbo({
application: {name: 'node-dubbo'},
register: 'localhost:2181',
dubboVersion: '2.0.0',
interfaces: ['com.alibaba.dubbo.demo.DemoService'],
});
const demoService = dubbo.proxyService<IDemoService>({
dubboInterface: 'com.alibaba.dubbo.demo.DemoService',
version: '1.0.0',
methods: {
sayHello(name) {
return [java.String(name)];
},
echo() {},
test() {},
getUserInfo() {
return [
java.combine('com.alibaba.dubbo.demo.UserRequest', {
id: 1,
name: 'nodejs',
email: 'node@qianmi.com',
}),
];
},
},
});
const result1 = await demoService.sayHello('node');
const res = await demoService.echo();
const res = await demoService.getUserInfo();
API
创建 Dubbo 对象
const dubbo = new Dubbo({
dubboVersion
application
enableHeartBeat
dubboInvokeTimeout
dubboSocketPool
logger
register
zkRoot
interfaces
});
const dubbo = Dubbo.from({
dubboVersion
application
enableHeartBeat
dubboInvokeTimeout
dubboSocketPool
logger
register
zkRoot
interfaces
})
const demoSerivce = Dubbo.proxService({
dubboInterface: 'com.alibaba.dubbo.demo.DemoService',
version: '1.0.0',
methods: {
xx(params) {
return [
params
]
}
},
})
FAQ
import {Dubbo} from 'dubbo2.js';
默认导入的 dubbo2.js 是按照 es2017 进行编译的,支持 node7.10 以上。
如果更低的 node 版本,可以使用
import {Dubbo} from 'dubbo2.js/es6';
Swagger接口文档
http://localhost:7002/swagger-ui.html
具体实现参考:https://juejin.cn/post/6974952982076981284#heading-5
Mysql
支持多数据库连接
注:项目默认的Mysql数据库使用链股开发环境的数据库,实际开发需要在config/config.{dev}.js配置文件中改成你自己项目的数据库地址及账号密码。
Sequelize
支持ORM框架Sequelize
注:项目默认的Mysql数据库使用链股开发环境的数据库,实际开发需要在config/config.{dev}.js配置文件中改成你自己项目的数据库地址及账号密码。
Redis
支持redis增删改查。
注:项目默认的redis服务器地址及账号密码使用链股开发环境的redis,实际开发需要在config/config.{dev}.js配置文件中改成你自己项目的redis服务器地址及账号密码。