Netty入门实例-Http服务

Http服务

=====================================================================

1.需求


  1. Netty 服务器在 6668 端口监听

  2. 浏览器发出请求 "http://localhost:6668/ "

  3. 服务器可以回复消息给客户端 "Hello! 我是服务器 5 " , 并对特定请求资源进行过滤.

2.创建服务端handler


在handler中我们对浏览器提交的Http请求做出处理

package com.dpb.netty.http;

import io.netty.buffer.ByteBuf;

import io.netty.buffer.Unpooled;

import io.netty.channel.ChannelHandlerContext;

import io.netty.channel.SimpleChannelInboundHandler;

import io.netty.handler.codec.http.*;

import io.netty.util.CharsetUtil;

import java.net.URI;

/**

  • @program: netty4demo

  • @description:

  • @author: 波波烤鸭

  • @create: 2019-12-24 16:49

*/

public class TestHttpServerHandler extends SimpleChannelInboundHandler {

/**

  • 读取客户端发送的数据

  • @param context

  • @param httpObject

  • @throws Exception

*/

@Override

protected void channelRead0(ChannelHandlerContext context, HttpObject httpObject) throws Exception {

if(httpObject instanceof HttpRequest){

// 判断是否是 Http请求

System.out.println(context.pipeline().hashCode());

System.out.println(httpObject.hashCode());

System.out.println(context.channel().remoteAddress());

HttpRequest request = (HttpRequest) httpObject;

URI uri = new URI(request.uri());

if(“/favicon.ico”.equals(uri.getPath())){

System.out.println(“请求了 favicon.ico 。。”);

return ;

}

ByteBuf byteBuf = Unpooled.copiedBuffer(“hello,我是服务端…”, CharsetUtil.UTF_8);

FullHttpResponse response = new DefaultFullHttpResponse(HttpVersion.HTTP_1_1,HttpResponseStatus.OK,byteBuf);

response.headers().set(HttpHeaderNames.CONTENT_TYPE,“text/plain;charset=utf-8”);

response.headers().set(HttpHeaderNames.CONTENT_LENGTH,byteBuf.readableBytes());

context.writeAndFlush(response);

}

}

}

3.创建服务端


创建服务端程序,创建服务。

package com.dpb.netty.http;

import io.netty.bootstrap.ServerBootstrap;

import io.netty.channel.*;

import io.netty.channel.nio.NioEventLoopGroup;

import io.netty.channel.socket.ServerSocketChannel;

import io.netty.channel.socket.SocketChannel;

import io.netty.channel.socket.nio.NioServerSocketChannel;

import io.netty.handler.codec.http.HttpServerCodec;

/**

  • @program: netty4demo

  • @description:

Kafka实战笔记

关于这份笔记,为了不影响大家的阅读体验,我只能在文章中展示部分的章节内容和核心截图

image.png

  • Kafka入门
  • 为什么选择Kafka
  • Karka的安装、管理和配置

image.png

  • Kafka的集群
  • 第一个Kafka程序
  • image.png

afka的生产者

image.png

  • Kafka的消费者
  • 深入理解Kafka
  • 可靠的数据传递

image.png

image.png

  • Spring和Kalka的整合
  • Sprinboot和Kafka的整合
  • Kafka实战之削峰填谷
  • 数据管道和流式处理(了解即可)

image.png

  • Kafka实战之削峰填谷

image.png

加入社区:https://bbs.csdn.net/forums/4304bb5a486d4c3ab8389e65ecb71ac0
ka实战之削峰填谷**

  • 数据管道和流式处理(了解即可)

[外链图片转存中…(img-pfT1DKAa-1725705287085)]

  • Kafka实战之削峰填谷

[外链图片转存中…(img-nmnAW5Ur-1725705287086)]

加入社区:https://bbs.csdn.net/forums/4304bb5a486d4c3ab8389e65ecb71ac0

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值