iis服务器助手广告广告
返回顶部
首页 > 资讯 > 服务器 >Java游戏服务器系列之Netty相关知识总结
  • 347
分享到

Java游戏服务器系列之Netty相关知识总结

2024-04-02 19:04:59 347人浏览 泡泡鱼
摘要

目录一、简介二、Netty的应用场景三、异步和事件驱动性四、Netty核心组件五、总结一、简介 Java的底层api逐渐复杂,而开发者面对的开发场景需求也在逐渐增大。如果直接针对底层

一、简介

Java的底层api逐渐复杂,而开发者面对的开发场景需求也在逐渐增大。如果直接针对底层API进行编程,无疑是耗时耗力的。这时就催生了极多的编程框架,这些框架隐藏了API实现的复杂细节,以最简洁的方式给开发人员提供功能的实现接口。Netty就是一款针对于网络链接的框架,他的出现让服务器开发人员更加的集中关注于更多逻辑的实现,而不为了实现更好更多更稳定的链接而头疼。Netty的核心功能基于NIO 实现。

二、Netty的应用场景

几乎适用于所有的长短链接场景,由于Java应用的广泛性,几乎所有的互联网公司或多或少的都会使用到。博主从事游戏开发,可以说几乎所有短链接游戏服务器都是使用Netty开发,实效性要求比较高也有热修复需求的服务器一般不会使用Java,目前采用更多的是C+lua的组合方式。Java不可以热修复是很多长链服务器不考虑java 的一个重要原因。

三、异步和事件驱动性

Nio 文章中强调了,这种模型的主要特地拿就是异步和事件驱动性,异步是服务器不需要一直等待链接输入直到链接关闭。而是可以在某个特定的时候去相应链接的输入,而特定的时候就是另一个事件驱动性,链接发生变化时,会产生一个事件,而NIO模型检测到这个事件之后,会去相应这个事件的处理事件。

四、Netty核心组件

1.Channel:

Channel时Java-NIO的一个基本构造,它代表到一个实体的开放链接,如读操作和写操作,在NIO模型中也可以被理解成一个入站或者出站的数据载体,可以被关闭或者关闭。

2.回调 ChannelHandler:

一个回调就是一个方法,Netty提供了两个子类,ChannelInboundHandlerAdapter 以及 ChannelOutboundHandlerAdapter ,这两个子类分别可以应用于数据进站和出站时期,各种阶段的回调,比如入站时Active方法,表明链接刚刚被建立起,代码如下:


public class ConnectHandler extend ChannelInboundHandlerAdapter{
	@override
	public void ChannelActive(ChannelHandlerContext ctx){
		//数据入站回调子类被建立时调用,也就是链接建立时调用
		System.out.println("远程客户端 : "+ ctx.channel().remoteAddress() + '建立链接');
	}
}

不了解Netty的读者看到这里可能会有点疑惑,这个类应该怎么用。这里简单的解释一下:这种类会在Netty创建的时候注册进服务中,然后在数据进站、出站的不同阶段,调用这个类中不同的回调函数,以处理不同的开发需求。可以关注一下读者其他的文章

3.Future:

jdk-Future:Java中提供了Future的实现,这种Futrue可以看作是一个异步操作结果的占位符。我们可以通过这个Future查询到这个异步操作的结果,并进行一些处理。比如在操作失败的时候抛出异常。但是jdk内置的Future的查询只能在某个时刻手动去查询结果,或者直接阻塞这个异步操作,直到异步完成操作之后可以查询Future的成功或者失败。
ChannelFuture:Netty内部提供的Future实现类,很多异步操作在执行的时候都会返回一个ChannelFuture对象,我们可以针对这个ChannelFuture对象设置一些回调函数,比如重写operationComplete()方法,这样这个异步事件在完成的时候会自动调用这个方法,并且执行我们自己的处理逻辑。
接下来可以看一下ChannelFuture的应用实例,检测Netty服务器链接远程地址是否成功:


Channel channel = "";
//链接地址192.168.100.113 的7000端口
InetSocketAddress socketAddress = new InetSocketAddress("192.168.100.113",7000);
//管道绑定地址并返回一个ChannelFuture
ChannelFuture channelFuture = channel.connect(socketAddress);
//给ChannelFuture设置完成回调,判断这个操作是否完成
channelFuture.addListener(new ChannelFutureListener(){
		@override
		public void operationComplete(ChannelFuture future){
			if(future.isSucess()){
				//创建一个字符串,并指定所使用的字符集,下面这种写法是Netty中经常遇到的
				ByteBuf buffer = Unpooled.copiedBuffer("Hello",Charset.defaultCharset());
				//发送信息并且返回一个新的writeFuture,依旧可以根据这个writeFuture处理一些逻辑
				ChannelFuture writeFuture = future.channel().writeAndFlush(buffer);
			}else{
				//链接失败则答应出失败的消息
				Throwable cause = future.cause();
				cause.printStackTrace();
			}
		}
})

五、总结

Netty以一种异步事件驱动以及回调的方式,能帮我们快速完善服务器处理数据的进出,以及各个流程细节中的处理逻辑。极大的精简了服务器开发人员在,链接处理,数据出入方面的开发工作。是一个及其易用且稳定的网络开发框架。

到此这篇关于Java游戏服务器系列之Netty相关知识总结的文章就介绍到这了,更多相关Java Netty内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Java游戏服务器系列之Netty相关知识总结

本文链接: http://www.lsjlt.com/news/126714.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Java游戏服务器系列之Netty相关知识总结
    目录一、简介二、Netty的应用场景三、异步和事件驱动性四、Netty核心组件五、总结一、简介 Java的底层API逐渐复杂,而开发者面对的开发场景需求也在逐渐增大。如果直接针对底层...
    99+
    2024-04-02
  • Java基础之并发相关知识总结
    目录一、Java并发是什么?二、怎么做?三、分工四、同步五、互斥六、总结一、Java并发是什么? 用学术定义来说就是 并发:同一时间段,多个任务都在执行 (单位时间内不一定同时执行...
    99+
    2024-04-02
  • Java基础之引用相关知识总结
    目录一、引用的定义二、问题三、引用的分类四、应用场景五、源码六、总结一、引用的定义 在JDK 1.2以前,Java中的引用定义很传统:如果reference类型的数据存储的数值代表的...
    99+
    2024-04-02
  • Java数据结构之链表相关知识总结
    一、链表 1.1 概述 链表是真正动态的数据结构,最简单的动态数据结构,基本用于辅助组成其他数据结构。 数据存储在“节点”(Node)中 优点:真正的动态,不需要处理固定容量的问题...
    99+
    2024-04-02
  • 云服务器相关知识点总结
    云服务器是一种虚拟的、服务器化的服务,可以提供按需使用、按量计费的服务,可以实现弹性扩展、自动负载均衡、快速响应、高可靠性等一系列功能,是许多企业和开发者的重要选择。以下是一些云服务器相关的知识点总结: 什么是云服务器:云服务器是一种通...
    99+
    2023-10-26
    知识点 服务器
  • Java并发容器相关知识总结
    目录一、并发容器1.1 JDK 提供的并发容器总结1.2 ConcurrentHashMap1.3 CopyOnWriteArrayList1.3.1 CopyOnWriteArra...
    99+
    2024-04-02
  • Java基础之线程锁相关知识总结
    一、 synchronized关键字 1.对象锁 a.当使用对象锁的时候,注意要是相同的对象,并且当有线程正在访问对象锁内部的代码的时候,其他线程无法访问。(注意无法访问的范围)。 ...
    99+
    2024-04-02
  • Java基础之反射技术相关知识总结
    目录一、反射概念二、反射应用场景三、反射更多细节一、反射概念 Java的反射(reflection)机制是指在程序的运行状态中,可以构造任意一个类的对象,可以了解任意一个对象所属的类...
    99+
    2024-04-02
  • SpringBoot任务之定时任务相关知识总结
    01: 异步任务 03: 邮件任务 一、SpringBoot--任务:定时任务 项目开发中经常需要执行一些定时任务,比如需要在每天凌晨的时候, 分析一次前一天的日志信息,Spri...
    99+
    2024-04-02
  • 云服务器相关知识点总结报告
    一、云服务器的基本概念 云服务器是一种常见的计算资源,通常由大型企业或云服务提供商提供。云服务器是一种虚拟化技术,可以将多个计算资源组合成一个虚拟服务器,并通过互联网连接在一起。用户可以通过云服务器访问和管理各种云服务,包括云存储、云数据...
    99+
    2023-10-27
    知识点 总结报告 服务器
  • Java基础学习之运算符相关知识总结
    1.算术运算符 +表示加法运算符 -表示减法运算符 *表示乘法运算符 /表示除法运算符 %表示取模/取余运算符 package com...
    99+
    2024-04-02
  • Java非阻塞I/O模型之NIO相关知识总结
    组件说明 (1)Channel:NIO模型中的管道,管道是链接建立和通信的重要组件,我们可以理解管道是一个容器环境,我们所有的I/O的建立读取都可以在这个容器中进行 (2)Selec...
    99+
    2024-04-02
  • Java内存模型之重排序的相关知识总结
    目录一、数据依赖性二、as-if-serial语义三、程序顺序规则四、重排序对多线程的影响一、数据依赖性 如果两个操作访问同一个变量,而且这两个操作中有一个操作为写操作,此时这两个操...
    99+
    2024-04-02
  • 云服务器相关知识点汇总
    云服务器是一种虚拟的、共享的、高可用的计算资源,通常用于远程服务器环境。作为云计算的重要组成部分之一,云服务器的管理、运维和性能优化是非常重要的。以下是一些常见的云服务器相关知识点: 数据备份和恢复:云服务器提供数据备份和恢复的功能,可...
    99+
    2023-10-26
    知识点 服务器
  • Java IO流之节点流与字符流的相关知识总结
    一、File file是文件和目录路径名的抽象表示 1.1 File的用法 用法: File file = new File("路径名"); //如 File file =...
    99+
    2024-04-02
  • 云服务器相关知识点汇总表
    一、云服务器的技术特点 高可用性:云服务器采用高可用技术,能够在不同的物理节点之间实现快速的数据同步和故障切换,确保服务器的正常运行。 弹性扩展:云服务器可以按需扩展存储和计算资源,根据用户需求动态调整计算能力和存储容量,实现弹性扩展。...
    99+
    2023-10-28
    知识点 汇总表 服务器
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作