开头
如果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)]