Home

SOA的基本概念和原理

SOA是一种面相服务的软件架构模型,往往和微服务一起用来解决应用(主要是WEB应用或者服务)的复杂性,对应用进行解耦,从而便于管理和维护。一般会将大的应用根据功能模块进行拆分,拆成小的独立的服务,服务之间通过定义好的接口或者契约关联起来,从而比较好的适应scrum的敏捷软件开发过程。一般包含如下几个关键部分: 服务注册,分为自动注册和手动注册。 服务发现 服务治理 容灾 负载均衡, 根据服务发现

git使用

查看远程分支加上-a参数可以查看远程分支,远程分支会用红色表示出来(如果你开了颜色支持的话): 12345678910$ git branch -a master remote tungway v1.52* zrong remotes/origin/master remotes/origin/tungway remotes/origin/v1.52 remotes/origin/zrong 删除远程分支和tag在Git v1.7.0 之后,可以使用这种语法删除远程分支: 1$ git push origin --delete <branchName> 删除tag这么用: 1git push origin --delete tag <tagname>

Kafka为什么如此的快

Kafka是分布式的消息系统,需要处理海量的消息,Kafka的设计初衷是把所有消息都写入速度低容量大的硬盘,以此来换取更强的存储能力,但是实际上,使用硬盘并没有带来过性能的损失,这究竟为何? Kafka主要使用以下几种方式实现了超高吞吐率的 顺序读写Kafka的消息是不断追加到文件中的,这个特性使它可以充分利用磁盘的顺序读写能力。顺序读写降低了硬盘磁头的寻道时间,只需要很少的扇区旋转时间,所以速度

Kakfa Consumer使用技巧

high-level consumer一种high-level版本,比较简单不用关心offset, 会自动的读zookeeper中该Consumer group的last offset不过要注意一些注意事项,对于多个partition和多个consumer 如果consumer比partition多,是浪费,因为kafka的设计是在一个partition上是不允许并发的,所以consumer数

Linux常用命令

端口占用查看1$>netstat –apn | grep 8080 磁盘占用情况12$>df -h$>du -h --max-depth=1 / 关闭页交互空间1234567##方法1$>vim /etc/sysctl.conf$>sudo sysctl vm.swappiness=0##方法2$>vim /etc/fstab##注释掉LABEL_lswap行$

Java NIO

Java NIO是是jdk1.4里提供的新API, 为所有的原始类型提供缓存支持。几个主要概念: Channels and Buffers: 和标准的基于字节流或者字符流的标准IO API相比,NIO利用Channel和Buffer,数据直接从Channel读去到内存Buffer,或者从Buffer写入Channel, 减少了数据的拷贝。Channel维持了客户端和服务器的链接资源。也可以理解为

输出日志到web页面

发布工具中需要对应用的启动日志,输出到页面上,方便用户查看。于是写了一个简单的python应用,基于diango。 先看看效果: 定义一个django view来接收ajax请求:12345678910111213141516171819202122232425262728def index(request): return render(request, 'index.html')def pul

JVM性能调优实战

使用jstack来分析死锁问题123456789101112131415161718192021222324252627282930313233343536373839public class Application { public static void main(String[] args){ System.out.println(" start th

JVM性能调优工具

企业级Java应用中经常碰到的问题: OutOfMemoryError,内存不足 内存泄露 线程死锁 锁争用(Lock Contention) Java进程消耗CPU过高 往往大多数人的处理办法只是重启服务,者调大内存,而不会深究问题根源。其实JVM自带了很多调优监控工具,例如jps、jstack、jmap、jhat、jstat、hprof等,下面我们对这些工具做一下详细的整理,以备不时之需。

Spring Boot 性能优化

Spring 框架给企业软件开发者提供了常见问题的通用解决方案,包括那些在未来开发中没有意识到的问题。但是,它构建的 J2EE 项目变得越来越臃肿,逐渐被 Spring Boot 所替代。Spring Boot 让我们创建和运行项目变得更为迅速,现在已经有越来越多的人使用它。我们已经在几个项目中使用了 Spring Boot ,今天我们就来一起讨论一下如何改进 Spring Boot 应用的性能。