osi网络7层架构

简介: osi网络7层架构

一、osi网络7层架构

ip:网络唯一标识。(internet protocol address)网络互联协议地址。分为网络地址和主机地址。

port:端口号,每一个网络应用程序都需要一个以上的端口号。(1-65535)。1000以内的不要用。

osi7层架构

物理层,数据链路层,网络层,传输层,会话层,表示层,应用层。

tcp协议(传输控制协议),保证两个应用程序之间可靠的网络通信。可靠的,低效的。

telent ftp smtp

udp协议(用户数据报文协议)。面向无连接的不可靠的,高效的。

qq snmp dns 在线视频

二、socket简介

套接字,用于描述一个ip和端口号绑定的通信会话(socket连接)。每一个网络服务都会打开一个socket连接。

serverSocket

位于java的net包下面。

此类实现服务器套接字。服务器套接字等待请求通过网络传入。它基于该请求执行某些操作,然后可能向请求者返回结果。

Socket

此类实现客户端套接字(也可以就叫“套接字”)。套接字是两台机器间通信的端点。

三、基于TCP协议的socket编程

创建一个基于tcp协议的scoket服务器

类 ServerSocket

此类实现服务器套接字。服务器套接字等待请求通过网络传入。它基于该请求执行某些操作,然后可能向请求者返回结果。

public class TalkServer {
public static void main(String[] args) throws Exception {
//创建一个serversocket在端口7000上,监听客户端请求
ServerSocket server= new ServerSocket(7000);
Socket socket = server.accept();//获取socket对象
//由Scoket对象获得输入流,并构造相应的bufferedReader对象
BufferedReader in = new BufferedReader(new InputStreamReader(socket.getInputStream()));
//由socket对象得到输出流,并构造printWrite对象
PrintWriter os = new PrintWriter(socket.getOutputStream(), true);
//由控制台输入构造BufferedReader对象
BufferedReader sin= new BufferedReader(new InputStreamReader(System.in));
System.out.println(“client:”+in.readLine());//打印客户端消息
String line = sin.readLine();//从控制台读取输入消息
while(!line.equals(“bye”)){
//把line返回给client
os.println(line);
System.out.println(“server:”+line);
System.out.println(“client:”+in.readLine());
line=sin.readLine();//读取下一条消息
}
  in.close();
  os.close();
  sin.close();
  socket.close();
}

}

使用多线程技术完成多服务对多客户端

package com.aaa.tcp;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.PrintWriter;
import java.net.Socket;
public class TalkServerThread implements Runnable {
private Socket socket;
public TalkServerThread(Socket socket) {
  super();
  this.socket = socket;
}
@Override
public void run() {
  //由Scoket对象获得输入流,并构造相应的bufferedReader对象
  BufferedReader in;
  try {
    in = new BufferedReader(new InputStreamReader(socket.getInputStream()));
    //由socket对象得到输出流,并构造printWrite对象
    PrintWriter os = new PrintWriter(socket.getOutputStream(), true);
    //由控制台输入构造BufferedReader对象
    BufferedReader sin= new BufferedReader(new InputStreamReader(System.in));
    System.out.println("client:"+in.readLine());//打印客户端消息
    String line = sin.readLine();//从控制台读取输入消息
    while(!line.equals("bye")){
      //把line返回给client
      os.println(line);
      System.out.println("server:"+line);
      System.out.println("client:"+in.readLine());
      line=sin.readLine();//读取下一条消息
    }
    in.close();
    os.close();
    sin.close();
    socket.close();
  } catch (IOException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
  }
}

}

测试类

package com.aaa.tcp;
import java.io.IOException;
import java.net.ServerSocket;
import java.net.Socket;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class MultiSocketServerTest {
/**
 * @param args
 * @throws Exception 
 */
public static void main(String[] args) throws Exception {
  //多个socket连接,但是端口号一致
  ServerSocket server=new ServerSocket(7000);
  Socket socket=null;
  while(true){
    socket = server.accept();//等待获取来自客户端的socket请求
    //一旦客户端请求到达,开启一个线程,来跟客户端交互
    new Thread(new TalkServerThread(socket)).start();
  }
}

}

四、基于UDP协议的socket编程

InetAddress
public static void main(String[] args) throws Exception {
InetAddress localHost = InetAddress.getLocalHost();
String hostName = localHost.getHostName();
System.out.println(hostName);
String hostAddress = localHost.getHostAddress();
System.out.println(hostAddress);
//获取远程网站的ip
  InetAddress baidu = InetAddress.getByName("www.baidu.com");
  System.out.println(baidu.getHostAddress());
}

使用upd模拟飞秋发送消息

package com.aaa.network;
import java.io.IOException;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress;
import java.net.SocketException;
import java.net.UnknownHostException;
import java.util.Date;
/**
  • @author sunshaoshan
  • @description java 模拟飞秋发送消息
  • @company AAA软件
  • 2018-11-5下午4:45:53
*/
public class FeiQiuTest {
/**
*TODO
*@param args
*2018-11-5下午4:45:45
*/
public static void main(String[] args) {
DatagramSocket ds= null;
DatagramPacket dp = null;
InetAddress localHost;
String Version=“1_lbt4_0#128#000C29D68D8F#0#0#0#2.5a”;
Long id=new Date().getTime();//获取当前系统毫秒
String user=“孙韶山”;
String host=“sunshaoshan”;
//long IPMSG_SENDMSG = 0x00000020;//发消息
long IPMSG_SENDMSG = 209;//发消息
String msg=“I kill you!”;
while(true){
try {
    ds=new DatagramSocket();
    //localHost = InetAddress.getByName("DESKTOP-H5URIFQ");
    localHost=InetAddress.getLocalHost();
    String message=Version+":"+id+":"+user+":"+host+":"+IPMSG_SENDMSG+":"+msg;
    //封装数据报文,2425是飞秋的端口号
    ///1version(IPMSG版本):no(消息编号,可以用系统时间):user(发送消息的用户名):host(发送消息的主机名):command(上述Command常量,可以用|组合多个值):msg(消息内容) 
    byte[] buff= message.getBytes("gbk");
    dp = new DatagramPacket(buff, buff.length,localHost,2425);
    //发送报文
    ds.send(dp);
  } catch (UnknownHostException e) {
    e.printStackTrace();
  } catch (SocketException e) {
    e.printStackTrace();
  } catch (IOException e) {
    e.printStackTrace();
  }
  }
  • }

}


目录
相关文章
|
2月前
|
人工智能 运维 安全
配置驱动的动态 Agent 架构网络:实现高效编排、动态更新与智能治理
本文所阐述的配置驱动智能 Agent 架构,其核心价值在于为 Agent 开发领域提供了一套通用的、可落地的标准化范式。
625 49
|
1月前
|
运维 监控 数据可视化
Python 网络请求架构——统一 SOCKS5 接入与配置管理
通过统一接入端点与标准化认证,集中管理配置、连接策略及监控,实现跨技术栈的一致性网络出口,提升系统稳定性、可维护性与可观测性。
|
2月前
|
人工智能 安全 数据可视化
配置驱动的动态Agent架构网络:实现高效编排、动态更新与智能治理
本文系统性地提出并阐述了一种配置驱动的独立运行时Agent架构,旨在解决当前低代码/平台化Agent方案在企业级落地时面临困难,为Agent开发领域提供了一套通用的、可落地的标准化范式。
375 18
配置驱动的动态Agent架构网络:实现高效编排、动态更新与智能治理
|
6月前
|
小程序 前端开发
2025商业版拓展校园圈子论坛网络的创新解决方案:校园跑腿小程序系统架构
校园跑腿小程序系统是一款创新解决方案,旨在满足校园配送需求并拓展校友网络。跑腿员可接单配送,用户能实时跟踪订单并评价服务。系统包含用户、客服、物流、跑腿员及订单模块,功能完善。此外,小程序增设信息咨询发布、校园社区建设和活动组织等功能,助力校友互动、经验分享及感情联络,构建紧密的校友网络。
268 1
2025商业版拓展校园圈子论坛网络的创新解决方案:校园跑腿小程序系统架构
|
6月前
|
人工智能 监控 安全
NTP网络子钟的技术架构与行业应用解析
在数字化与智能化时代,时间同步精度至关重要。西安同步电子科技有限公司专注时间频率领域,以“同步天下”品牌提供可靠解决方案。其明星产品SYN6109型NTP网络子钟基于网络时间协议,实现高精度时间同步,广泛应用于考场、医院、智慧场景等领域。公司坚持技术创新,产品通过权威认证,未来将结合5G、物联网等技术推动行业进步,引领精准时间管理新时代。
|
6月前
|
网络协议 中间件 网络安全
计算机网络OSI七层模型
OSI模型分为七层,各层功能明确:物理层传输比特流,数据链路层负责帧传输,网络层处理数据包路由,传输层确保端到端可靠传输,会话层管理会话,表示层负责数据格式转换与加密,应用层提供网络服务。数据在传输中经过封装与解封装过程。OSI模型优点包括标准化、模块化和互操作性,但也存在复杂性高、效率较低及实用性不足的问题,在实际中TCP/IP模型更常用。
937 10
|
9月前
|
机器学习/深度学习 计算机视觉 iOS开发
RT-DETR改进策略【模型轻量化】| 替换骨干网络 CVPR-2024 RepViT 轻量级的Vision Transformers架构
RT-DETR改进策略【模型轻量化】| 替换骨干网络 CVPR-2024 RepViT 轻量级的Vision Transformers架构
502 0
RT-DETR改进策略【模型轻量化】| 替换骨干网络 CVPR-2024 RepViT 轻量级的Vision Transformers架构
|
7月前
|
人工智能 供应链 调度
|
6月前
|
机器学习/深度学习 算法 测试技术
图神经网络在信息检索重排序中的应用:原理、架构与Python代码解析
本文探讨了基于图的重排序方法在信息检索领域的应用与前景。传统两阶段检索架构中,初始检索速度快但结果可能含噪声,重排序阶段通过强大语言模型提升精度,但仍面临复杂需求挑战
223 0
图神经网络在信息检索重排序中的应用:原理、架构与Python代码解析
|
6月前
|
Cloud Native 区块链 数据中心
Arista CloudEOS 4.32.2F - 云网络基础架构即代码
Arista CloudEOS 4.32.2F - 云网络基础架构即代码
143 1