0
点赞
收藏
分享

微信扫一扫

Java基础 - 网络编程,三要素(IP,原理解析

莞尔小迷糊 2022-04-13 阅读 66

开头

如果Redis的读写请求量很大,那么单个实例很有可能承担不了这么大的请求量,如何提高Redis的性能呢?你也许已经想到了,可以部署多个副本节点,业务采用读写分离的方式,把读请求分担到多个副本节点上,提高访问性能。要实现读写分离,就必须部署多个副本,每个副本需要实时同步主节点的数据。

Redis也提供了完善的主从复制机制,使用非常简单的命令,就可以构建一个多副本节点的集群。

同时,当主节点故障宕机时,我们可以把一个副本节点提升为主节点,提高Redis的可用性。可见,对于故障恢复,也依赖Redis的主从复制,它们都是Redis高可用的一部分。

这篇文章我们就来介绍一下Redis主从复制流程和原理,以及在复制过程中有可能产生的各种问题。

  • 网络上具有唯一标识的IP地址和端口号组合在一起才能构成唯一能识别的标识符套接字。

  • 通信的两端都有Socket。

  • 网络通信其实就是Socket间的通信。

  • 数据在两个Socket间通过IO流传输。

  • Socket在应用程序中创建,通过一种绑定机制与驱动程序建立关系,告诉自己所对应的IP和port。

[](()6.UDP传输(了解)

用户数据报协议(User Datagram Protocol)

  • 1.发送Send

  • 创建DatagramSocket, 随机端口号

  • 创建DatagramPacket, 指定数据, 长度, 地址, 端口

  • 使用DatagramSocket发送DatagramPacket

  • 关闭DatagramSocket

  • 2.接收Receive

  • 创建DatagramSocket, 指定端口号

  • 创建DatagramPacket, 指定数组, 长度

  • 使用DatagramSocket接收DatagramPacket

  • 关闭DatagramSocket

  • 从DatagramPacket中获取数据

  • 3.接收方获取ip和端口号

  • String ip = packet.getAddress().getHostAddress();

  • int port = packet.getPort();

[](()7.UDP传输优化

  • 接收端Receive

DatagramSocket socket = new DatagramSocket(6666); //创建socket相当于创建码头

DatagramPacket packet = new DatagramPacket(new byte[1024], 1024); //创建packet相当于创建集装箱

while(true) {

socket.receive(packet); //接收货物

byte[] arr = packet.getData();

int len = packet.getLength();

String ip = packet.getAddress().getHostAddress();

System.out.println(ip + “:” + new String(arr,0,len));

}

  • 发送端Send

DatagramSocket socket = new DatagramSocket(); //创建socket相当于创建码头

Scanner sc = new Scanner(System.in);

while(true) {

String str = sc.nextLine();

if(“quit”.equals(str))

break;

DatagramPacket packet = //创建packet相当于创建集装箱

new DatagramPacket(str.getBytes(), str.getBytes().length, InetAddress.getByName(“127.0.0.1”), 6666);

socket.send(packet); //发货

}

socket.close();

[](()8.TCP协议(掌握)

传输控制协议(Transmission Control Protocol)

  • 1.客户端

  • 创建Socket连接服务端(指定ip地址,端口号)通过ip地址找对应的服务器

  • 调用Socket的getInputStream()和getOutputStream()方法获取和服务端相连的IO流

  • 输入流可以读取服务端输出流写出的数据

  • 输出流可以写出数据到服务端的输入流

  • 2.服务端

  • 创建ServerSocket(需要指定端口号)

  • 调用ServerSocket的accept()方法接收一个客户端请求,得到一个Socket

  • 调用Socket的getInputStream()和getOutputStream()方法获取和客户端相连的IO流

  • 输入流可以读取客户端输出流写出的数据

  • 输出流可以写出数据到客户端的输入流

《一线大厂Java面试真题解析+Java核心总结学习笔记+最新全套讲解视频+实战项目源码》开源

最后

现在其实从大厂招聘需求可见,在招聘要求上有高并发经验优先,包括很多朋友之前都是做传统行业或者外包项目,一直在小公司,技术搞的比较简单,没有怎么搞过分布式系统,但是现在互联网公司一般都是做分布式系统。

所以说,如果你想进大厂,想脱离传统行业,这些技术知识都是你必备的,下面自己手打了一份Java并发体系思维导图,希望对你有所帮助。

验优先,包括很多朋友之前都是做传统行业或者外包项目,一直在小公司,技术搞的比较简单,没有怎么搞过分布式系统,但是现在互联网公司一般都是做分布式系统。

所以说,如果你想进大厂,想脱离传统行业,这些技术知识都是你必备的,下面自己手打了一份Java并发体系思维导图,希望对你有所帮助。

[外链图片转存中…(img-Et2HKCo0-1649566468217)]

举报

相关推荐

0 条评论