客户端
- 发送请求给服务端
- 接受服务端的响应
服务端实现
启动类:Server.java
public class Server {
public static void main(String[] args) throws Exception{
//创建两个组,分别用来接受客户端情求和处理客户端消息的
NioEventLoopGroup bossGroup = new NioEventLoopGroup();
NioEventLoopGroup workGroup = new NioEventLoopGroup();
ServerBootstrap b = new ServerBootstrap();
//配置服务端
ChannelFuture cf = b.group(bossGroup,workGroup).channel(NioServerSocketChannel.class)
//1)
.childHandler(new ServerChannelInit())
.bind(8899)
.sync();
System.out.println(“服务端初始化完成!!!”);
//最后关闭服务端资源
cf.channel().closeFuture().sync();
bossGroup.shutdownGracefully();
workGroup.shutdownGracefully();
System.out.println(“服务端停止服务!!!”);
}
}
1)、在这里将业逻辑注入,这样就很好的将业务和IO操作分离开了
通道初始化类:ServerChannelInit.java
public class ServerChannelInit extends ChannelInitializer {
@Override
protected void initChannel(NioSocketChannel ch) throws Exception {
//对服务端管道进行配置,编解码,Handler的处理顺序等等
ch.pipeline()
.addLast(new StringEncoder())
.addLast(new StringDecoder())
.addLast(new ServerHandler());
}
}
通道数据处理类:ServerHandler.java
public class ServerHandler extends SimpleChannelInboundHandler {
@Override
public void channelRead0(ChannelHandlerContext ctx, String msg) throws Exception {
System.out.println(“接受到数据是:”+msg);
//返回响应
ctx.writeAndFlush(“服务端已经接受数据!!”);
}
@Override
public void channelActive(ChannelHandlerContext ctx) throws Exception {
System.out.println(“=test通道激活”);
super.channelActive(ctx);
}
@Override
public void channelInactive(ChannelHandlerContext ctx) throws Exception {
System.out.println(“=test通道激活ing”);
super.channelInactive(ctx);
}
@Override
public void channelReadComplete(ChannelHandlerContext ctx) throws Exception {
System.out.println(“=test通道数据读取完毕!!”);
super.channelReadComplete(ctx);
}
@Override
public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception {
System.out.println(“=test通道激活出现异常”);
super.exceptionCaught(ctx, cause);
ctx.close();
}
}
客户端实现
启动类:Client.java
public class Client {
public static void main(String[] args) throws Exception{
NioEventLoopGroup workGroup = new NioEventLoopGroup();
Bootstrap b = new Bootstrap();
ChannelFuture cf = b.group(workGroup)
.channel(NioSocketChannel.class)
.handler(new ClientChannelInit())
.connect(“127.0.0.1”, 8899)
.sync();
server",CharsetUtil.UTF_8));
System.out.println(“客户端初始化完成!!!”);
cf.channel().closeFuture().sync();
}
}
通道初始化类:ClientChannelInit.java
public class ClientChannelInit extends ChannelInitializer {
@Override
protected void initChannel(NioSocketChannel ch) throws Exception {
ch.pipeline()
.addLast(new StringEncoder())
.addLast(new StringDecoder())
.addLast(new ClientHandler());
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Go语言工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Go语言全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Golang知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Go)
一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
(备注Go)**
[外链图片转存中…(img-b64uPdKl-1712904135537)]
一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!