公司网站建设款计什么科目,福步外贸论坛网官网,拓客渠道有哪些,鲸影视官方网站下载前些天发现了一个巨牛的人工智能学习网站#xff0c;通俗易懂#xff0c;风趣幽默#xff0c;忍不住分享一下给大家。点击跳转到教程。
一、dubbo常用配置 dubbo:service/ 服务配置#xff0c;用于暴露一个服务#xff0c;定义服务的元信息#xff0c;一个服务可…
前些天发现了一个巨牛的人工智能学习网站通俗易懂风趣幽默忍不住分享一下给大家。点击跳转到教程。
一、dubbo常用配置 dubbo:service/ 服务配置用于暴露一个服务定义服务的元信息一个服务可以用多个协议暴露一个服务也可以注册到多个注册中心。
eg、dubbo:service refdemoService interfacecom.unj.dubbotest.provider.DemoService /dubbo:reference/ 引用服务配置用于创建一个远程服务代理一个引用可以指向多个注册中心。
eg、dubbo:reference iddemoService interfacecom.unj.dubbotest.provider.DemoService /dubbo:protocol/ 协议配置用于配置提供服务的协议信息协议由提供方指定消费方被动接受。
eg、dubbo:protocol namedubbo port20880 /dubbo:application/ 应用配置用于配置当前应用信息不管该应用是提供者还是消费者。
eg、dubbo:application namexixi_provider /dubbo:application namehehe_consumer /dubbo:module/ 模块配置用于配置当前模块信息可选。
dubbo:registry/ 注册中心配置用于配置连接注册中心相关信息。
eg、dubbo:registry addresszookeeper://192.168.2.249:2181 /dubbo:monitor/ 监控中心配置用于配置连接监控中心相关信息可选。
dubbo:provider/ 提供方的缺省值当ProtocolConfig和ServiceConfig某属性没有配置时采用此缺省值可选。
dubbo:consumer/ 消费方缺省配置当ReferenceConfig某属性没有配置时采用此缺省值可选。
dubbo:method/ 方法配置用于ServiceConfig和ReferenceConfig指定方法级的配置信息。
dubbo:argument/ 用于指定方法参数配置。 二、服务调用超时设置 上图中以timeout为例显示了配置的查找顺序其它retries, loadbalance, actives也类似。 方法级优先接口级次之全局配置再次之。 如果级别一样则消费方优先提供方次之。
其中服务提供方配置通过URL经由注册中心传递给消费方。 建议由服务提供方设置超时因为一个方法需要执行多长时间服务提供方更清楚如果一个消费方同时引用多个服务就不需要关心每个服务的超时设置。 理论上ReferenceConfig的非服务标识配置在ConsumerConfigServiceConfig, ProviderConfig均可以缺省配置。
三、启动时检查 Dubbo缺省会在启动时检查依赖的服务是否可用不可用时会抛出异常阻止Spring初始化完成以便上线时能及早发现问题默认checktrue。
如果你的Spring容器是懒加载的或者通过API编程延迟引用服务请关闭check否则服务临时不可用时会抛出异常拿到null引用如果checkfalse总是会返回引用当服务恢复时能自动连上。
可以通过checkfalse关闭检查比如测试时有些服务不关心或者出现了循环依赖必须有一方先启动。 1、关闭某个服务的启动时检查(没有提供者时报错)
dubbo:reference interfacecom.foo.BarService checkfalse /2、关闭所有服务的启动时检查(没有提供者时报错) 写在定义服务消费者一方
dubbo:consumer checkfalse /3、关闭注册中心启动时检查(注册订阅失败时报错)
dubbo:registry checkfalse / 引用缺省是延迟初始化的只有引用被注入到其它Bean或被getBean()获取才会初始化。 如果需要饥饿加载即没有人引用也立即生成动态代理可以配置 dubbo:reference interfacecom.foo.BarService inittrue / 四、订阅 1、问题 为方便开发测试经常会在线下共用一个所有服务可用的注册中心这时如果一个正在开发中的服务提供者注册可能会影响消费者不能正常运行。
2、解决方案 可以让服务提供者开发方只订阅服务(开发的服务可能依赖其它服务)而不注册正在开发的服务通过直连测试正在开发的服务。 禁用注册配置
dubbo:registry address10.20.153.10:9090 registerfalse /
或者
dubbo:registry address10.20.153.10:9090?registerfalse / 五、回声测试(测试服务是否可用) 回声测试用于检测服务是否可用回声测试按照正常请求流程执行能够测试整个调用是否通畅可用于监控。 所有服务自动实现EchoService接口只需将任意服务引用强制转型为EchoService即可使用。 eg、dubbo:reference idmemberService interfacecom.xxx.MemberService /MemberService memberService ctx.getBean(memberService); // 远程服务引用
EchoService echoService (EchoService) memberService; // 强制转型为EchoService
String status echoService.$echo(OK); // 回声测试可用性
assert(status.equals(OK)) 六、延迟连接 延迟连接用于减少长连接数当有调用发起时再创建长连接。 只对使用长连接的dubbo协议生效。 dubbo:protocol namedubbo lazytrue / 七、令牌验证 防止消费者绕过注册中心访问提供者在注册中心控制权限以决定要不要下发令牌给消费者注册中心可灵活改变授权方式而不需修改或升级提供者 1、全局设置开启令牌验证
!--随机token令牌使用UUID生成--
dubbo:provider interfacecom.foo.BarService tokentrue /!--固定token令牌相当于密码--
dubbo:provider interfacecom.foo.BarService token123456 /2、服务级别设置开启令牌验证
!--随机token令牌使用UUID生成--
dubbo:service interfacecom.foo.BarService tokentrue /!--固定token令牌相当于密码--
dubbo:service interfacecom.foo.BarService token123456 /3、协议级别设置开启令牌验证
!--随机token令牌使用UUID生成--
dubbo:protocol namedubbo tokentrue /!--固定token令牌相当于密码--
dubbo:protocol namedubbo token123456 / 八、日志适配 缺省自动查找log4j、slf4j、jcl、jdk
可以通过以下方式配置日志输出策略dubbo:application loggerlog4j/
访问日志 如果你想记录每一次请求信息可开启访问日志类似于apache的访问日志。此日志量比较大请注意磁盘容量。
将访问日志输出到当前应用的log4j日志 dubbo:protocol accesslogtrue / 将访问日志输出到指定文件 dubbo:protocol accessloghttp://10.20.160.198/wiki/display/dubbo/foo/bar.log / 九、配置Dubbo缓存文件
配置方法如下 dubbo:registryfile”${user.home}/output/dubbo.cache” / 注意 文件的路径应用可以根据需要调整保证这个文件不会在发布过程中被清除。如果有多个应用进程注意不要使用同一个文件避免内容被覆盖。
这个文件会缓存 注册中心的列表 服务提供者列表
有了这项配置后当应用重启过程中Dubbo注册中心不可用时则应用会从这个缓存文件读取服务提供者列表的信息进一步保证应用可靠性。