Netty学习——protoc的新手使用流程 关于学习的内容笔记,记下来的东西等于又过了一次脑子,记录的更深刻一些. 1. 使用IDEA创建.proto文件,软件会提示你安装相应的语法插件 安装成功之后,proto文件的显示图标是这个样子的 2. 编写Proto文件 syntax ="proto2"; package com.dawa.protobuf; option optimize_for = SPEED; option java_package ="com.dawa.p…
Netty简单使用 1.本文先介绍一下 server 的 demo 2.(重点是这个)根据代码跟踪一下 Netty 的一些执行流程 和 事件传递的 pipeline. 首先到官网看一下Netty Server 和 Client的demo, https://netty.io/wiki/user-guide-for-4.x.html, 我用的是4.1.xx,一般来说不是大版本变更, 变化不会很大.下面是 Netty Server 的demo,跟官网的是一样的. // 下面是一个接收线程, 3个wor…
前言 本文主要从 select 和 epoll 系统调用入手,来打开 Netty 的大门,从认识 Netty 的基础原理 —— I/O 多路复用模型开始.   Netty 的通信原理 Netty 底层的通信机制是基于I/O多路复用模型构建的,简单一句话概括就是多路网络连接可以复用一个I/O线程,在 Java 层面也就是封装了其 NIO API,但是 JDK 底层基于 Linux 的 epoll 机制实现(其实是三个函数).注意在老旧的 Linux 上,可能还是 select,没考证过,但是时下主…
Netty学习——Thrift的入门使用 希望你能够,了解并使用它.因为它是一个效率很高的框架 官网地址:http://thrift.apache.org/ 1.Thrift数据类型 一门技术如果需要支持多门语言,那么这门技术的字符类型肯定会很少,因为数据类型需要是多门语言的交集.Thrift 不支持无符号类型,因为很多编程语言不存在无符号类型,如java byte:有符号字节 i16:16位有符号整数 i32:32位有符号整数 i64:64位有符号整数 doubule: 64位的浮点数 str…
Netty学习——Netty和Protobuf的整合(二) 这程序是有瑕疵的,解码器那里不通用,耦合性太强,有两个很明显的问题,但是要怎么解决呢?如:再加一个内部类型 Person2,之前的代码就不能用了. 问题1:客户端和服务器端 分别 这里解码器都不能写死吧 问题2:客户端和服务器端Handler里面的泛型,也都不能写死吧 Stack Overflow , 善用搜索引擎解决此问题 在Stack Overflow上面搜的结果https://stackoverflow.com/questions…
Netty学习——Netty和Protobuf的整合 Protobuf作为序列化的工具,将序列化后的数据,通过Netty来进行在网络上的传输 1.将proto文件里的java包的位置修改一下,然后再执行一下protoc 异常捕获:启动服务器端正常,在启动客户端的时候,发送消息,报错 警告: An exceptionCaught() event was fired, and it reached at the tail of the pipeline. It usually means the l…
目录 Netty学习笔记 前言 什么是Netty IO基础 概念说明 IO简单介绍 用户空间与内核空间 进程(Process) 线程(thread) 程序和进程 进程切换 进程阻塞 文件描述符 文件句柄 缓存IO Linux 网络I/O模型 同步.异步.阻塞.非阻塞的概念 同步 异步 阻塞 非阻塞 总结 举个例子 I/O模型 阻塞 I/O(blocking IO) 非阻塞 I/O(nonblocking IO) 信号驱动I/O( signal driven IO ) I/O 多路复用( IO m…
Netty 学习(四):ChannelHandler 的事件传播和生命周期 作者: Grey 原文地址: 博客园:Netty 学习(四):ChannelHandler 的事件传播和生命周期 CSDN:Netty 学习(四):ChannelHandler 的事件传播和生命周期 ChannelHandler 的事件传播 在通信客户端和服务端,处理的流程大致有如下步骤 输入---> 解码 ---> 根据不同的消息指令解析数据包 ---> 编码 ---> 输出 在『根据不同的消息指令解析数…
Netty 学习(五):服务端启动核心流程源码说明 作者: Grey 原文地址: 博客园:Netty 学习(五):服务端启动核心流程源码说明 CSDN:Netty 学习(五):服务端启动核心流程源码说明 说明 本文使用的 Netty 版本是 4.1.82.Final, <dependency> <groupId>io.netty</groupId> <artifactId>netty-all</artifactId> <version>…
Netty 学习(七):NioEventLoop 对应线程的创建和启动源码说明 作者: Grey 原文地址: 博客园:Netty 学习(七):NioEventLoop 对应线程的创建和启动源码说明 CSDN:Netty 学习(七):NioEventLoop 对应线程的创建和启动源码说明 说明 在 Netty 服务端代码中,我们一般会创建了两个 NioEventLoopGroup:bossGroup 和 workerGroup 其中: bossGroup用于监听端口,接收新连接的线程组:worke…