- zbus协议-1
晨风先生
网络协议c++网络协议
zbus协议是一种基于消息队列的通信协议,用于实现高性能、可靠的分布式消息传递。它提供了一种简单而强大的方式来实现不同系统之间的异步通信和解耦。以下是zbus协议的一些主要特点和概念:消息队列:zbus协议基于消息队列的模型,通过将消息发送到队列中,实现了消息的异步传递和解耦。消息队列可以存储和传递不同类型的消息,包括请求、响应、通知等。主题(Topic):主题是zbus协议中的一种消息分类机制,
- dpkg: 处理软件包 XXX (--configure)时出错:
SCH0
环境配置linux服务器运维
dpkg:处理软件包xxx(--configure)时出错:已安装xxx软件包post-installation脚本子进程返回错误状态127在处理时有错误发生:zbus2rosE:Sub-process/usr/bin/dpkgreturnedanerrorcode(1):~/user$sudorm/var/lib/dpkg/info/xxx.xxx.listxxx.md5sumsxxx.post
- 微服务中分布式事务Seata报错get global lock fail,获取不到全局锁的问题解惑
dearmrzhang
微服务分布式java
这几天一直在做zbus和vue的项目前后端分离项目,现有两个服务:基础服务和预告服务,现在预告服务中的订单新增要调用基础服务中的日志模块来保存操作日志。但是调用完了就报错getgloballockfail,获取不到全局锁,找遍官方和内部交流群,也不得要领。调用方代码:/***提交订单(状态变更为已生效,不可编辑删除)**@paramid*@returncom.yorma.entity.YmMsg*
- 互联网公司的RPC框架如何选择?
maikelsong
RPC框架比较语言协议服务治理社区机构Hessian多语言hessian–不活跃CauchoThrift多语言thrift–活跃ApacheFinagleJava/Scala多协议支持活跃TwitterTChannel多语言thrift支持活跃UberDubboJava支持拓展支持停滞阿里包括现在出的zbus,你们用的哪个呢?Venus框架dubbozk现在都这么选吧在面向服务架构中,一个请求可能
- Java NIO原理及分析
放牧的太阳
JavaNIO
前言:最近由于公司项目重构,需要用SOA分布式架构。在这里我采用的是比较轻量级的ZBUS总线来实现。而使用ZBUS总线最关键的就是底层socket通信问题。这里的通信问题就涉及到了java的NIO非阻塞机制,下面就参考一些别的资料,做一些简要的分析。首先来分析下阻塞IO与非阻塞IO的区别1、阻塞IO:阻塞io是指jdk1.4之前版本面向流的io,服务端需要对每个请求建立一堆线程等待请求,而客户端发
- SpringBoot优雅的全局异常处理(一)——非web项目
柠萌你个思密达
前言本篇文章主要介绍的是SpringBoot非web项目进行全局异常的处理。SpringBoot版本:2.1.9.RELEASEMybatisPlus版本:3.3.0上个项目使用的是SpringBoot+MybatisPlus+zbus,项目架构是:zbus分为客户端和服务端,两者通过RPC进行调用。主要工作:通过SpringAOP处理、捕获异常,并将异常信息记录到日志中。一.先看我的pom文件,
- 微服务整合Seata分布式事务处理
柠萌你个思密达
前言官方文档:http://seata.io/zh-cn/docs/user/microservice.html这几天开始做新项目,是基于RPC+Restful的微服务项目。前端用的Vue,后端用的比较冷门的小型轻量级框架zbus。前端和后端交互是通过restful,后端服务之间通过RPC调用,这就涉及到了分布式事务。官方文档很简洁,网上其他资源都是讲的seata与springcloud、dubb
- zbus 详细介绍
冰海之洋
小巧而极速的MQ,RPC实现,支持HTTP/TCP代理,开放易扩展,多语言支撑微服务,系统总线架构zbus核心是一个独立实现的小巧极速的消息队列(MQ),支持持久化与内存队列,支持单播、广播、组播等多种消息通信模式;在MQ之上zbus完备地支持了RPC服务,RPC支持独立伺服,基于总线两种模式;同时zbus支持代理服务,基于MQ的HttpProxy实现了类Nginx的HTTP代理服务(支持DMZ网
- Zbus学习笔记
GoldenLeafSpark
java
推荐:java学习就去人工博客https://www.94rg.comZBUS=MQ+RPC+PROXY支持消息队列,发布订阅,RPC,代理(TCP/HTTP/DMZ)亿级消息堆积能力、支持HA高可用超轻量级,单个Jar包无依赖~250K丰富的API--JAVA/C/C++/C#/Python/Node.JS多语言接入1.MQ通过ZBus的消息队列服务,连接生产者与消费者,二者可以在完全不知道对方
- 二叉树的深度优先与广度优先算法
放牧的太阳
数据结构
packageorg.zbus.test;importjava.util.ArrayDeque;publicclassBinaryTree{staticclassTreeNode{intvalue;TreeNodeleft;TreeNoderight;publicTreeNode(intvalue){this.value=value;}}TreeNoderoot;publicBinaryTree(
- Java NIO原理及分析
cgperfect
javanioSOA
前言: 最近由于公司项目重构,需要用SOA分布式架构。在这里我采用的是比较轻量级的ZBUS总线来实现。而使用ZBUS总线最关键的就是底层socket通信问题。这里的通信问题就涉及到了java的NIO非阻塞机制,下面就参考一些别的资料,做一些简要的分析。 首先来分析下阻塞IO与非阻塞IO的区别 1、阻塞IO:阻塞io是指jdk1.4之前版本面向流的io,服务端需要对每个请求建立一堆线程等待请
- 高可用消息队列框架ZBUS
1028826685
我们在日常开发中可以需要用到消息队列当然我们完全可以自己写一个生产者-消费者框架但是高可用性、实时性已经大量数据堆积时候就显得问题捉襟见肘了下面推荐的框架在我时间项目中和测试中都是非常不错那么他是什么框架呢? zbusgit地址http://git.oschina.net/rushmore/zbus ZBUS=MQ+RPC服务总线1)支持消息队列,发布订阅,RPC,交易系统队列适配2)亿级消息堆
- 高可用消息队列框架ZBUS
1028826685
阅读更多我们在日常开发中可以需要用到消息队列当然我们完全可以自己写一个生产者-消费者框架但是高可用性、实时性已经大量数据堆积时候就显得问题捉襟见肘了下面推荐的框架在我时间项目中和测试中都是非常不错那么他是什么框架呢?zbusgit地址http://git.oschina.net/rushmore/zbusZBUS=MQ+RPC服务总线1)支持消息队列,发布订阅,RPC,交易系统队列适配2)亿级消息
- 高可用消息队列框架ZBUS
1028826685
框架消息队列zbus
我们在日常开发中可以需要用到消息队列当然我们完全可以自己写一个生产者-消费者框架但是高可用性、实时性已经大量数据堆积时候就显得问题捉襟见肘了下面推荐的框架在我时间项目中和测试中都是非常不错那么他是什么框架呢? zbusgit地址http://git.oschina.net/rushmore/zbus ZBUS=MQ+RPC服务总线1)支持消息队列,发布订阅,RPC,交易系统队列适配2)亿级消息堆
- zbus消息唯一性约束增强
少帮主
zbus-6.3.0(master)增加新特性,支持对队列消息的唯一性约束,生产者可以在消息头部打标识(键名key),唯一标识决定消息是否入队列。使用示例BrokerConfig config = new BrokerConfig();
config.setServerAddress("127.0.0.1:15555");
final Broker broker = new SingleBroke
- ZBUS高可用HA介绍
少帮主
HAzbus
http://git.oschina.net/rushmore/zbus1. ZBUS 高可用设计Zbus高可用采用ZbusServer + TrackServer结合完成,相对于单机版本的zbus,客户端需要TrackServer的帮助完成实际的zbus动态选择。Zbus可以动态的增加到TrackServer组成的高可用群中,zbus节点之间无状态。加入高可用群的ZbusServer向Track
- 【zbus】framework-rpc 使用用例
jamin-liu
1.引入pom文件:
cn.bidlink.nbl
framework-rpc
0.0.1-SNAPSHOT
2.引入spring文件:framework-zbusjar文件中classpath:spring/applicationContext-framework-rpc-zbus.xml配置classpath:framework-rpc-zbus.properties3.对外提供服务:结合sp
- 基于zbus的MySQL透明代理(<100行)
少帮主
mysqlproxyzbus
项目地址 https://git.oschina.net/rushmore/zbus我们上次讲到zbus网络通讯的核心API:Dispatcher -- 负责-NIO网络事件Selector引擎的管理,对Selector引擎负载均衡IoAdaptor -- 网络事件的处理,服务器与客户端共用,负责读写,消息分包组包等Session -- 代表网络链接,可以读写消息实际的应用,我们几乎只需要做IoA
- zbus.NET网络通讯模块(一)
少帮主
项目地址 https://git.oschina.net/rushmore/zbus核心API就三个角色:Dispatcher -- 负责-NIO网络事件Selector引擎的管理,对Selector引擎负载均衡IoAdaptor -- 网络事件的处理,服务器与客户端共用,负责读写,消息分包组包等Session -- 代表网络链接,可以读写消息这三个角色大部分场景下,需要个性化处理的就只有IoAd
- ZBUS项目结构概貌
少帮主
http://git.oschina.net/rushmore/zbusZBUS项目代码概览broker -- 链接代理,解决连接池管理,链接高可用kit --工具类,包括log日志、对象池等mq --消息队列服务,提供持久化队列,发布订阅,zbus的核心入口net --网络通讯库,基本NIO引擎、HTTP协议通讯proxy -- 提供TCP,HTTP,DMZ代理服务rpc -- 提供RPC服务,
- ZBUS入门文档
少帮主
zbus
https://git.oschina.net/rushmore/zbusZBUS解决啥问题消息队列MQ消息队列重点解决系统解耦,可以让系统责任链设计更加清晰。ZBUS消息队列解决消息队列可靠传输、支持发布订阅广播模式。同类产品: RabbitMQ、ActiveMQ等 远程方法调用RPC跨语言解决远程方法调用,JAVA平台支持透明式动态接口远程代理。同类产品: dubbo,thrift等等 网络代
- zbus logo消息队列、服务总线 zbus
pyzheng
http://www.oschina.net/p/zbus轻量级服务总线/消息队列1)多种消息模式--支持生产者/消费者,发布订阅,RPC2)丰富的API--C/C++/C#/JAVA/Python/Node.JS跨平台、多语言支持3)开放协议标准--原生兼容HTTP协议(长连接),头部动态扩展4)支持TrackServer与ZbusServer高可用横向动态扩容机制ZBUS追求极度轻量级,高度可
- Zbus的JFinal插件实现第二版
玛雅牛
jFinalzbus
第一版实现:实现了Zbus的JFinal插件,JFinal里用Zbus更方便了。第二版主要实现了以下目标:1)简化设计,去掉了异步发送,仅支持同步发送。2)信息发送/接收实现了泛型支持。3)可直接发送/接收JFinal中特有的Model对象和Record对象。导入dist目录下的jfinal-zbus-2.0.0.jar同时还需要导入zbus,znet,fastjson,jfinal等jar包配置
- 实现了Zbus的JFinal插件,JFinal里用Zbus更方便了。
玛雅牛
jFinalzbus
第二版已经发布,支持泛型,代码更安全,更简单:http://my.oschina.net/myaniu/blog/486717zbushttps://git.oschina.net/rushmore/zbus轻量级服务总线/消息队列1)多种消息模式--支持生产者/消费者,发布订阅,RPC2)丰富的API--C/C++/C#/JAVA/Python/Node.JS跨平台、多语言支持3)开放协议标准-
- maven常见使用命令
kobe_gino
mvninstall:install-file-DgroupId=org.zbus-DartifactId=zbus-Dversion=5.0.0-Dpackaging=jar-Dfile=d:/zbus-5.0.0.jarpom.xml中配置忽略测试test的插件org.apache.maven.pluginsmaven-surefire-plugintruemvninstallassembly
- maven常见使用命令
chaun
mvninstall:install-file-DgroupId=org.zbus-DartifactId=zbus-Dversion=5.0.0-Dpackaging=jar-Dfile=d:/zbus-5.0.0.jarpom.xml中配置忽略测试test的插件org.apache.maven.pluginsmaven-surefire-plugintruemvninstallassembly
- 轻量级、高性能NIO网络通讯框架(around 60K)-zbus
paulwong
轻量级、高性能NIO网络通讯框架(around60K)-zbus轻量级、高性能NIO网络通讯框架(around 60K),zbus通讯基础 —— 查看更多http://git.oschina.net/rushmore/zbus为什么没有选择netty或者mina?个人观点:netty与mina过于庞大,需要学习的成本比较高,debug中的chain过长,自己不方便改写
- 使用微软MSMQ可能遇到的坑
少帮主
最近重新捣鼓回 ZBUS5.0与微软MSMQ对接,碰到了些坑,希望能对新手有所帮助。微软的MSMQ坑比较多,Win7下可能出现下面的bughttp://support.microsoft.com/kb/2554746验证方法:netstat -ano | findstr 18011801是MSMQ默认的侦听地址,如果没有侦听 0.0.0.0:1801 那么恭喜你中招了,先做上面的hotfix更新,
- 分享100个最新免费的高匿HTTP代理IP
mcj8089
代理IP代理服务器匿名代理免费代理IP最新代理IP
推荐两个代理IP网站:
1. 全网代理IP:http://proxy.goubanjia.com/
2. 敲代码免费IP:http://ip.qiaodm.com/
120.198.243.130:80,中国/广东省
58.251.78.71:8088,中国/广东省
183.207.228.22:83,中国/
- mysql高级特性之数据分区
annan211
java数据结构mongodb分区mysql
mysql高级特性
1 以存储引擎的角度分析,分区表和物理表没有区别。是按照一定的规则将数据分别存储的逻辑设计。器底层是由多个物理字表组成。
2 分区的原理
分区表由多个相关的底层表实现,这些底层表也是由句柄对象表示,所以我们可以直接访问各个分区。存储引擎管理分区的各个底层
表和管理普通表一样(所有底层表都必须使用相同的存储引擎),分区表的索引只是
- JS采用正则表达式简单获取URL地址栏参数
chiangfai
js地址栏参数获取
GetUrlParam:function GetUrlParam(param){
var reg = new RegExp("(^|&)"+ param +"=([^&]*)(&|$)");
var r = window.location.search.substr(1).match(reg);
if(r!=null
- 怎样将数据表拷贝到powerdesigner (本地数据库表)
Array_06
powerDesigner
==================================================
1、打开PowerDesigner12,在菜单中按照如下方式进行操作
file->Reverse Engineer->DataBase
点击后,弹出 New Physical Data Model 的对话框
2、在General选项卡中
Model name:模板名字,自
- logbackのhelloworld
飞翔的马甲
日志logback
一、概述
1.日志是啥?
当我是个逗比的时候我是这么理解的:log.debug()代替了system.out.print();
当我项目工作时,以为是一堆得.log文件。
这两天项目发布新版本,比较轻松,决定好好地研究下日志以及logback。
传送门1:日志的作用与方法:
http://www.infoq.com/cn/articles/why-and-how-log
上面的作
- 新浪微博爬虫模拟登陆
随意而生
新浪微博
转载自:http://hi.baidu.com/erliang20088/item/251db4b040b8ce58ba0e1235
近来由于毕设需要,重新修改了新浪微博爬虫废了不少劲,希望下边的总结能够帮助后来的同学们。
现行版的模拟登陆与以前相比,最大的改动在于cookie获取时候的模拟url的请求
- synchronized
香水浓
javathread
Java语言的关键字,可用来给对象和方法或者代码块加锁,当它锁定一个方法或者一个代码块的时候,同一时刻最多只有一个线程执行这段代码。当两个并发线程访问同一个对象object中的这个加锁同步代码块时,一个时间内只能有一个线程得到执行。另一个线程必须等待当前线程执行完这个代码块以后才能执行该代码块。然而,当一个线程访问object的一个加锁代码块时,另一个线程仍然
- maven 简单实用教程
AdyZhang
maven
1. Maven介绍 1.1. 简介 java编写的用于构建系统的自动化工具。目前版本是2.0.9,注意maven2和maven1有很大区别,阅读第三方文档时需要区分版本。 1.2. Maven资源 见官方网站;The 5 minute test,官方简易入门文档;Getting Started Tutorial,官方入门文档;Build Coo
- Android 通过 intent传值获得null
aijuans
android
我在通过intent 获得传递兑现过的时候报错,空指针,我是getMap方法进行传值,代码如下 1 2 3 4 5 6 7 8 9
public
void
getMap(View view){
Intent i =
- apache 做代理 报如下错误:The proxy server received an invalid response from an upstream
baalwolf
response
网站配置是apache+tomcat,tomcat没有报错,apache报错是:
The proxy server received an invalid response from an upstream server. The proxy server could not handle the request GET /. Reason: Error reading fr
- Tomcat6 内存和线程配置
BigBird2012
tomcat6
1、修改启动时内存参数、并指定JVM时区 (在windows server 2008 下时间少了8个小时)
在Tomcat上运行j2ee项目代码时,经常会出现内存溢出的情况,解决办法是在系统参数中增加系统参数:
window下, 在catalina.bat最前面
set JAVA_OPTS=-XX:PermSize=64M -XX:MaxPermSize=128m -Xms5
- Karam与TDD
bijian1013
KaramTDD
一.TDD
测试驱动开发(Test-Driven Development,TDD)是一种敏捷(AGILE)开发方法论,它把开发流程倒转了过来,在进行代码实现之前,首先保证编写测试用例,从而用测试来驱动开发(而不是把测试作为一项验证工具来使用)。
TDD的原则很简单:
a.只有当某个
- [Zookeeper学习笔记之七]Zookeeper源代码分析之Zookeeper.States
bit1129
zookeeper
public enum States {
CONNECTING, //Zookeeper服务器不可用,客户端处于尝试链接状态
ASSOCIATING, //???
CONNECTED, //链接建立,可以与Zookeeper服务器正常通信
CONNECTEDREADONLY, //处于只读状态的链接状态,只读模式可以在
- 【Scala十四】Scala核心八:闭包
bit1129
scala
Free variable A free variable of an expression is a variable that’s used inside the expression but not defined inside the expression. For instance, in the function literal expression (x: Int) => (x
- android发送json并解析返回json
ronin47
android
package com.http.test;
import org.apache.http.HttpResponse;
import org.apache.http.HttpStatus;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpGet;
import
- 一份IT实习生的总结
brotherlamp
PHPphp资料php教程php培训php视频
今天突然发现在不知不觉中自己已经实习了 3 个月了,现在可能不算是真正意义上的实习吧,因为现在自己才大三,在这边撸代码的同时还要考虑到学校的功课跟期末考试。让我震惊的是,我完全想不到在这 3 个月里我到底学到了什么,这是一件多么悲催的事情啊。同时我对我应该 get 到什么新技能也很迷茫。所以今晚还是总结下把,让自己在接下来的实习生活有更加明确的方向。最后感谢工作室给我们几个人这个机会让我们提前出来
- 据说是2012年10月人人网校招的一道笔试题-给出一个重物重量为X,另外提供的小砝码重量分别为1,3,9。。。3^N。 将重物放到天平左侧,问在两边如何添加砝码
bylijinnan
java
public class ScalesBalance {
/**
* 题目:
* 给出一个重物重量为X,另外提供的小砝码重量分别为1,3,9。。。3^N。 (假设N无限大,但一种重量的砝码只有一个)
* 将重物放到天平左侧,问在两边如何添加砝码使两边平衡
*
* 分析:
* 三进制
* 我们约定括号表示里面的数是三进制,例如 47=(1202
- dom4j最常用最简单的方法
chiangfai
dom4j
要使用dom4j读写XML文档,需要先下载dom4j包,dom4j官方网站在 http://www.dom4j.org/目前最新dom4j包下载地址:http://nchc.dl.sourceforge.net/sourceforge/dom4j/dom4j-1.6.1.zip
解开后有两个包,仅操作XML文档的话把dom4j-1.6.1.jar加入工程就可以了,如果需要使用XPath的话还需要
- 简单HBase笔记
chenchao051
hbase
一、Client-side write buffer 客户端缓存请求 描述:可以缓存客户端的请求,以此来减少RPC的次数,但是缓存只是被存在一个ArrayList中,所以多线程访问时不安全的。 可以使用getWriteBuffer()方法来取得客户端缓存中的数据。 默认关闭。 二、Scan的Caching 描述: next( )方法请求一行就要使用一次RPC,即使
- mysqldump导出时出现when doing LOCK TABLES
daizj
mysqlmysqdump导数据
执行 mysqldump -uxxx -pxxx -hxxx -Pxxxx database tablename > tablename.sql
导出表时,会报
mysqldump: Got error: 1044: Access denied for user 'xxx'@'xxx' to database 'xxx' when doing LOCK TABLES
解决
- CSS渲染原理
dcj3sjt126com
Web
从事Web前端开发的人都与CSS打交道很多,有的人也许不知道css是怎么去工作的,写出来的css浏览器是怎么样去解析的呢?当这个成为我们提高css水平的一个瓶颈时,是否应该多了解一下呢?
一、浏览器的发展与CSS
- 《阿甘正传》台词
dcj3sjt126com
Part Ⅰ:
《阿甘正传》Forrest Gump经典中英文对白
Forrest: Hello! My names Forrest. Forrest Gump. You wanna Chocolate? I could eat about a million and a half othese. My momma always said life was like a box ochocol
- Java处理JSON
dyy_gusi
json
Json在数据传输中很好用,原因是JSON 比 XML 更小、更快,更易解析。
在Java程序中,如何使用处理JSON,现在有很多工具可以处理,比较流行常用的是google的gson和alibaba的fastjson,具体使用如下:
1、读取json然后处理
class ReadJSON
{
public static void main(String[] args)
- win7下nginx和php的配置
geeksun
nginx
1. 安装包准备
nginx : 从nginx.org下载nginx-1.8.0.zip
php: 从php.net下载php-5.6.10-Win32-VC11-x64.zip, php是免安装文件。
RunHiddenConsole: 用于隐藏命令行窗口
2. 配置
# java用8080端口做应用服务器,nginx反向代理到这个端口即可
p
- 基于2.8版本redis配置文件中文解释
hongtoushizi
redis
转载自: http://wangwei007.blog.51cto.com/68019/1548167
在Redis中直接启动redis-server服务时, 采用的是默认的配置文件。采用redis-server xxx.conf 这样的方式可以按照指定的配置文件来运行Redis服务。下面是Redis2.8.9的配置文
- 第五章 常用Lua开发库3-模板渲染
jinnianshilongnian
nginxlua
动态web网页开发是Web开发中一个常见的场景,比如像京东商品详情页,其页面逻辑是非常复杂的,需要使用模板技术来实现。而Lua中也有许多模板引擎,如目前我在使用的lua-resty-template,可以渲染很复杂的页面,借助LuaJIT其性能也是可以接受的。
如果学习过JavaEE中的servlet和JSP的话,应该知道JSP模板最终会被翻译成Servlet来执行;而lua-r
- JZSearch大数据搜索引擎
颠覆者
JavaScript
系统简介:
大数据的特点有四个层面:第一,数据体量巨大。从TB级别,跃升到PB级别;第二,数据类型繁多。网络日志、视频、图片、地理位置信息等等。第三,价值密度低。以视频为例,连续不间断监控过程中,可能有用的数据仅仅有一两秒。第四,处理速度快。最后这一点也是和传统的数据挖掘技术有着本质的不同。业界将其归纳为4个“V”——Volume,Variety,Value,Velocity。大数据搜索引
- 10招让你成为杰出的Java程序员
pda158
java编程框架
如果你是一个热衷于技术的
Java 程序员, 那么下面的 10 个要点可以让你在众多 Java 开发人员中脱颖而出。
1. 拥有扎实的基础和深刻理解 OO 原则 对于 Java 程序员,深刻理解 Object Oriented Programming(面向对象编程)这一概念是必须的。没有 OOPS 的坚实基础,就领会不了像 Java 这些面向对象编程语言
- tomcat之oracle连接池配置
小网客
oracle
tomcat版本7.0
配置oracle连接池方式:
修改tomcat的server.xml配置文件:
<GlobalNamingResources>
<Resource name="utermdatasource" auth="Container"
type="javax.sql.DataSou
- Oracle 分页算法汇总
vipbooks
oraclesql算法.net
这是我找到的一些关于Oracle分页的算法,大家那里还有没有其他好的算法没?我们大家一起分享一下!
-- Oracle 分页算法一
select * from (
select page.*,rownum rn from (select * from help) page
-- 20 = (currentPag