主頁 > 資料庫 > 計算機網路與Java網路編程基礎知識總結

計算機網路與Java網路編程基礎知識總結

2020-10-07 22:05:44 資料庫

關于Java網路編程

計算機網路將地理位置不同的計算機通過通信線路連接起來,實作資源的共享和資訊的傳遞,網路中的計算機通常稱之為主機,而網路編程就是通程序式來實作兩臺以上主機之間的通信,
實際的通信網路內容較多,但是Java語言提供了許多網路類,屏蔽了底層的復雜細節,是程式員可以很容易地撰寫出網路程式,

計算機網路知識基礎

在進行Java網路編程之前,需要對關于計算機網路的總體知識有一個大致的理解,

分層結構模型

眾所周知,計算機網路傳輸實際上是一個很復雜的模型,為了更方便程式開發,我們一般會簡歷網路傳輸模型,將各個不同的層次分隔開,由不同的人來設計不同的層次,這樣設計各個層次的人就不用管其他層面的具體實作,每一層都呼叫它的下一層所提供的網路來完成自己的需求,只需要呼叫別人的服務就可以了,大大提高了作業效率,除此之外,因為各層之間是獨立的,結構上可分割開,所以靈活性好,易于實作和維護,能促進標準化作業:差錯控制,流量控制,分段和重裝,復用和分用,連接建立和釋放,

常見的模型由三種:

1.OSI七層體系

在這里插入圖片描述

2.五層體系

5層只是OSI和TCP/IP的綜合,是業界產生出來的非官方協議模型,但是很多具體的應用,實際應用還是TCP/IP的四層結構,
在這里插入圖片描述

3.TCP/IP四層體系

在這里插入圖片描述
該體系將資料鏈路層和物理層合并為網路介面層,

總結

OSI總結圖
本圖來自于https://blog.csdn.net/cc1949/article/details/79063439
TCP/IP協議與其的關系()
本圖來自于https://blog.csdn.net/cc1949/article/details/79063439
這是其中有關于協議的資料報文格式:
在這里插入圖片描述

Java網路編程基礎

計算機在網路通信協議中必須遵守一定的規則,就好比車輛行駛要遵守交通規則一樣,在計算機網路協議中,這些連接和通信的規則被稱為網路通信協議,它對傳輸格式,傳輸速率,傳輸步驟做了統一的規定,通信雙方必須遵守這些協議才能進行資料交換;

網路通信協議有很多種,但是目前主要使用的還是TCP/IP、UDP、ICMP和一些其他協議;

IP地址與埠號

要想使計算機能夠通信,必須要為每臺計算機指定標識號,通過標識號來指定接識訓發送資料的計算機,在TCP/IP協議中,這個標識號就是IP地址,目前普遍使用的是4個位元組的IPV4,不過為了解決日漸枯竭的網路地址資源不足,現在16個位元組IPV6也應運而生;

IP地址一般由兩部分組成,是 網路號+主機號,網路號指定網路地址,主機號指定該網路中的主機地址,二者是主從關系;

通過IP地址可以連接到指定計算機,但是如果想要訪問計算機中某個應用程式,還需要指定埠號,在計算機中,不同的應用程式是通過埠號來區分的,埠號是用兩個位元組(16位的二進制數)來表示的,取值范圍為0到65533,但其中0到1023的埠號被系統的網路服務所占有,所以用戶的普通應用的埠號不能屬于這個范圍;

總得來說,一臺計算機可以通過IP地址來訪問到網路中的另一臺計算機,并通過埠號來訪問這個計算機中的某個應用程式;

InetAddress類

這是Java中提供的與IP地址相關的InetAddress類,該類用于封裝IP地址,并提供了一系列與IP地址相關的方法,該類的方法有以下幾個,例如:

InetAddress  getByName(String host)    得到IP地址封裝為InetAddress類

InetAddress getLocalHost()          創建一個表示本地主機的InetAddress物件

String getHostName()               得到字串格式的原始IP地址

String getHostHome()             得到確定的IP地址的主機名

boolean isReachable(int timeout)        判斷在指定的時間內地址是否可以到達

TCP和UDP

TCP和UDP是兩個傳輸層的高級協議;

UDP是用戶資料報協議,TCP是傳輸控制協議;

UDP是無連接通信協議,在資料傳輸的時候,資料的發送端和接收端并不建立邏輯連接,簡單來說,當一臺計算機向另外一臺計算機發送資料時,并不好確認接收端是否存在,就直接發送資料,接收端在接受資料的時候,也不會向發送端反饋是否收到資料,
由于UDP消耗資源小,傳輸效率高,,所以通常用于音視頻和普通資料的傳輸,比如說直播視頻,但是由于UDP的無連接性,不能保證資料傳輸的完整性,所以在傳輸重要資料的時候不建議使用UDP,

TCP是面向連接的通信協議,即在傳輸資料的時候先在發送端和接收端建立邏輯連接,然后再傳輸資料;這提供了兩臺計算機之間可靠的,無差錯的資料傳輸;
由于TCP的面向連接的特性,它可以保證資料傳輸的安全性,所以是一個被廣泛采取的協議,比如在下載壓縮包檔案的時候,就非常適合使用TCP連接,

在TCP連接程序中,必須要明確客戶端和服務器端,由客戶端來向服務器端發出連接請求;
每次連接都需要經歷三次握手協議;
三次握手協議:
第一次握手,客戶端向服務器端發出連接請求,等待服務器端的確認;
第二次握手,服務器端向客戶端回復一個回應,通知客戶端收到了連接請求;
第三次握手,客戶端向服務器端發送確認資訊,確認連接;

而在TCP斷開鏈接的時候,就需要用到四次揮手協議
第一次揮手,若A認為資料發送完成,則它需要向B發送連接釋放請求,
第二次揮手,B收到連接釋放請求后,會通知相應的應用程式,告訴它A向B這個方向的連接已經釋放,
第三次揮手,當B向A發完所有資料后,向A發送連接釋放請求
第四次揮手,A收到釋放請求后,向B發送確認應答,

TCP協議作為一個可靠的面向流的傳輸協議,其可靠性和流量控制由滑動視窗協議保證,而擁塞控制則由控制視窗結合一系列的控制演算法實作,以及快重傳和快恢復,超時重傳來確保檔案完整性,

兩者所在層次:
在這里插入圖片描述
兩者特點比較:
在這里插入圖片描述

TCP網路編程

ServerSocket

用于建立TCP連接,該類可以實作一個服務端的程式;

1、構造ServerSocket

ServerSocket()throws IOException  //ServerSocket有一個不帶引數的默認構造方法,通過該方法創建的ServerSocket不與任何埠系結,接下來還需要通過bind()方法與特定埠系結,這個默認構造方法的用途是,允許服務器在系結到特定埠之前,先設定ServerSocket的一些選項,因為一旦服務器與特定埠系結,有些選項就不能再改變了,

ServerSocket(int port) throws IOException   //使服務器與特定埠系結,該埠由引數port指定

ServerSocket(int port, int backlog) throws IOException  //引數backlog指定客戶連接請求佇列的長度

ServerSocket(int port, int backlog, InetAddress bindAddr) throws IOException  //引數bindAddr指定服務器要系結的IP地址

2.使用ServerSocket進行服務端編程

import java.io.*;
import java.net.*;
import java.util.*;

public class qwe {
    public static void main(String[] args) {
        ServerSocket server = null;  //創建服務器Socket物件
        Socket socket = null;  //創建Socket物件,用于接收另一端socket的連接

        DataInputStream in = null;
        DataOutputStream out = null;  //準備好IO流

        int port = 5050;//設定埠號

        try{
            server = new ServerSocket(port);
        }
        catch (IOException e){
            System.out.println(e);
        }//創建ServerSocket物件,系結5050埠

        try{
            System.out.println("服務器啟動");
            socket = server.accept();//準備監聽Socket連接并接收

            in = new DataInputStream(socket.getInputStream());//回傳一個輸入流物件
            out = new DataOutputStream(socket.getOutputStream());//回傳一個輸出流物件

            //socket之間是通過IO流來互動資訊的

            String str = in.readUTF();
            System.out.println("收到資訊為:"+str);
            out.writeUTF("你好");
            
        }catch(Exception e){
            System.out.println(e);
        }
        
        finally {
        //準備關閉連接
            try{
                out.close();
                in.close();
                socket.close();//Socket物件的關閉連接方法
                server.close();
            }catch (Exception e){
                System.out.println(e);
            }
        }
        
    }
}
      

Socket(客戶端)

import java.io.*;
import java.net.*;

public class qwe {
    public static void main(String[] args){
        Socket client = null;
        DataInputStream in = null;
        DataOutputStream out = null;
        
        String ip = "127.0.0.1";
        int port = 5050;
        
        try
        {
            client = new Socket(ip,port);//客戶端socket系結埠和ip地址
            
            in = new DataInputStream(client.getInputStream());
            out = new DataOutputStream(client.getOutputStream());
            
            out.writeUTF("這里是客戶端");
            String str = ((DataInputStream) in).readUTF();
            System.out.println(str);
        }catch (Exception e){
            System.out.println(e);
        }finally {
            try{
                in.close();
                out.close();
                client.close();
            }catch (Exception e){
                System.out.println(e);
            }
        }
    }
}

UDP網路編程

UDP是一種無連接的不可靠傳輸協議,在使用UDP進行網路連接通信的時候,不需要建立連接,所以速度塊,發送的時候需要封裝成資料包,就像把信件裝入信封,

DatagramPacket

UDP通信程序中并不建立連接,就像是兩個貨運公司在兩個碼頭之間運送貨物一樣,在碼頭發送和接受貨物都需要使用集裝箱來裝載貨物,UDP通信也是一樣,我們需要使用DatagramPacket類,該類的實體物件就相當與一個集裝箱,也可以說是一個信封,我們就利用這個東西對我們需要發送的檔案進行打包發送,總之,這個類是用來發送的,

構造方法:

DatagramPacket(byte[] data, int length)  //指定了封裝資訊的位元組陣列大小,以及陣列的長蘇

DatagramPacket(byte[] data, int offset, int length)  //在上面的基礎上,增加了offset,用于指定資料的緩沖位置

DatagramPacket(byte[ ] data, int length, InetAddress  address, int port)  //增加了指定的目標IP地址address和目的埠號port

DatagramPacket(byte[] data, int offset, int length,  InetAddress address, int port) //完整版

常用方法:
InetAddress getAddress()    //回傳IP地址

int getPort()  //回傳埠號

byte[] getData()    //回傳打包的資料

int getLength()  //回傳資料位元組陣列的長度

DatagramSocket

如果說DatagramPacket相當于一個集裝箱,然而,兩個貨運公司之間的傳輸僅僅使用集裝箱是不夠的,我們還需要一個碼頭進行接收集裝箱,在Java中,我們使用DatagramSocket來當作“碼頭”,使用該類的實體物件就可以接識訓發送DatagramPacket資料包,總之,這個類是用來接收的,

構造方法:

DatagramSocket()   //用于創建一個DatagramSocket物件,如果沒有給埠號,系統會從其他應用自動分配一個

DatagramSocket(int port)   //指定了埠號,這樣物件可以監聽指定的埠

DatagramSocket(int port,InetAddress addr)   //指定了埠號和IP地址,該物件適用與計算機上有多塊網卡的情況,因為計算機針對不同的網卡會分配不同的IP地址,所以指定IP地址就可以確定你到底要使用哪塊網卡來通信

void  receive(DatagramPacket p) //接收包

void send(DatagramPacket p)  //發送包

void close //關閉

UDP編程實體

import java.io.*;
import java.net.*;

public class qwe {
    public static void main(String[] args) {
        DatagramSocket socket = null;//碼頭,利用其的send和receive方法來進行發送和接收
        DatagramPacket packet_send = null;//集裝箱,用于發送
        DatagramPacket packet_receive = null;//集裝箱,用于接收

        int port = 5050;
        String ipAddress = "127.0.0.1";

        try{
            socket = new DatagramSocket(port);//建立好連接

            byte[] r = bew byte[1024];
            packet_receive = new DatagramPacket(r,r.length);
            socket.receive(packet_receive);//接受從另一端發送過來的資料

            InetAddress address = InetAddress.getByName(ipAddress);//封裝好InetAddress
            String str = "服務端發送資料";
            byte[] r = str.getBytes();//開始打包
            packet_send = new DatagramPacket(r,r.length,address,port);//打包好資料

            socket.send(packet_send);//將資料包發送到另一端
        }
        catch (Exception e)
        {
            System.out.println(e);
        }
        finally {
            socket.close();//關閉連接
        }

    }
}

轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/161928.html

標籤:其他

上一篇:【人工智能】從梯度下降演算法到人工神經網路

下一篇:視頻編碼

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • GPU虛擬機創建時間深度優化

    **?桔妹導讀:**GPU虛擬機實體創建速度慢是公有云面臨的普遍問題,由于通常情況下創建虛擬機屬于低頻操作而未引起業界的重視,實際生產中還是存在對GPU實體創建時間有苛刻要求的業務場景。本文將介紹滴滴云在解決該問題時的思路、方法、并展示最終的優化成果。 從公有云服務商那里購買過虛擬主機的資深用戶,一 ......

    uj5u.com 2020-09-10 06:09:13 more
  • 可編程網卡芯片在滴滴云網路的應用實踐

    **?桔妹導讀:**隨著云規模不斷擴大以及業務層面對延遲、帶寬的要求越來越高,采用DPDK 加速網路報文處理的方式在橫向縱向擴展都出現了局限性。可編程芯片成為業界熱點。本文主要講述了可編程網卡芯片在滴滴云網路中的應用實踐,遇到的問題、帶來的收益以及開源社區貢獻。 #1. 資料中心面臨的問題 隨著滴滴 ......

    uj5u.com 2020-09-10 06:10:21 more
  • 滴滴資料通道服務演進之路

    **?桔妹導讀:**滴滴資料通道引擎承載著全公司的資料同步,為下游實時和離線場景提供了必不可少的源資料。隨著任務量的不斷增加,資料通道的整體架構也隨之發生改變。本文介紹了滴滴資料通道的發展歷程,遇到的問題以及今后的規劃。 #1. 背景 資料,對于任何一家互聯網公司來說都是非常重要的資產,公司的大資料 ......

    uj5u.com 2020-09-10 06:11:05 more
  • 滴滴AI Labs斬獲國際機器翻譯大賽中譯英方向世界第三

    **桔妹導讀:**深耕人工智能領域,致力于探索AI讓出行更美好的滴滴AI Labs再次斬獲國際大獎,這次獲獎的專案是什么呢?一起來看看詳細報道吧! 近日,由國際計算語言學協會ACL(The Association for Computational Linguistics)舉辦的世界最具影響力的機器 ......

    uj5u.com 2020-09-10 06:11:29 more
  • MPP (Massively Parallel Processing)大規模并行處理

    1、什么是mpp? MPP (Massively Parallel Processing),即大規模并行處理,在資料庫非共享集群中,每個節點都有獨立的磁盤存盤系統和記憶體系統,業務資料根據資料庫模型和應用特點劃分到各個節點上,每臺資料節點通過專用網路或者商業通用網路互相連接,彼此協同計算,作為整體提供 ......

    uj5u.com 2020-09-10 06:11:41 more
  • 滴滴資料倉庫指標體系建設實踐

    **桔妹導讀:**指標體系是什么?如何使用OSM模型和AARRR模型搭建指標體系?如何統一流程、規范化、工具化管理指標體系?本文會對建設的方法論結合滴滴資料指標體系建設實踐進行解答分析。 #1. 什么是指標體系 ##1.1 指標體系定義 指標體系是將零散單點的具有相互聯系的指標,系統化的組織起來,通 ......

    uj5u.com 2020-09-10 06:12:52 more
  • 單表千萬行資料庫 LIKE 搜索優化手記

    我們經常在資料庫中使用 LIKE 運算子來完成對資料的模糊搜索,LIKE 運算子用于在 WHERE 子句中搜索列中的指定模式。 如果需要查找客戶表中所有姓氏是“張”的資料,可以使用下面的 SQL 陳述句: SELECT * FROM Customer WHERE Name LIKE '張%' 如果需要 ......

    uj5u.com 2020-09-10 06:13:25 more
  • 滴滴Ceph分布式存盤系統優化之鎖優化

    **桔妹導讀:**Ceph是國際知名的開源分布式存盤系統,在工業界和學術界都有著重要的影響。Ceph的架構和演算法設計發表在國際系統領域頂級會議OSDI、SOSP、SC等上。Ceph社區得到Red Hat、SUSE、Intel等大公司的大力支持。Ceph是國際云計算領域應用最廣泛的開源分布式存盤系統, ......

    uj5u.com 2020-09-10 06:14:51 more
  • es~通過ElasticsearchTemplate進行聚合~嵌套聚合

    之前寫過《es~通過ElasticsearchTemplate進行聚合操作》的文章,這一次主要寫一個嵌套的聚合,例如先對sex集合,再對desc聚合,最后再對age求和,共三層嵌套。 Aggregations的部分特性類似于SQL語言中的group by,avg,sum等函式,Aggregation ......

    uj5u.com 2020-09-10 06:14:59 more
  • 爬蟲日志監控 -- Elastc Stack(ELK)部署

    傻瓜式部署,只需替換IP與用戶 導讀: 現ELK四大組件分別為:Elasticsearch(核心)、logstash(處理)、filebeat(采集)、kibana(可視化) 下載均在https://www.elastic.co/cn/downloads/下tar包,各組件版本最好一致,配合fdm會 ......

    uj5u.com 2020-09-10 06:15:05 more
最新发布
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:33:24 more
  • MySQL中binlog備份腳本分享

    關于MySQL的二進制日志(binlog),我們都知道二進制日志(binlog)非常重要,尤其當你需要point to point災難恢復的時侯,所以我們要對其進行備份。關于二進制日志(binlog)的備份,可以基于flush logs方式先切換binlog,然后拷貝&壓縮到到遠程服務器或本地服務器 ......

    uj5u.com 2023-04-20 08:28:06 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:27:27 more
  • 快取與資料庫雙寫一致性幾種策略分析

    本文將對幾種快取與資料庫保證資料一致性的使用方式進行分析。為保證高并發性能,以下分析場景不考慮執行的原子性及加鎖等強一致性要求的場景,僅追求最終一致性。 ......

    uj5u.com 2023-04-20 08:26:48 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:26:35 more
  • 云時代,MySQL到ClickHouse資料同步產品對比推薦

    ClickHouse 在執行分析查詢時的速度優勢很好的彌補了MySQL的不足,但是對于很多開發者和DBA來說,如何將MySQL穩定、高效、簡單的同步到 ClickHouse 卻很困難。本文對比了 NineData、MaterializeMySQL(ClickHouse自帶)、Bifrost 三款產品... ......

    uj5u.com 2023-04-20 08:26:29 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:25:13 more
  • Redis 報”OutOfDirectMemoryError“(堆外記憶體溢位)

    Redis 報錯“OutOfDirectMemoryError(堆外記憶體溢位) ”問題如下: 一、報錯資訊: 使用 Redis 的業務介面 ,產生 OutOfDirectMemoryError(堆外記憶體溢位),如圖: 格式化后的報錯資訊: { "timestamp": "2023-04-17 22: ......

    uj5u.com 2023-04-20 08:24:54 more
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:24:03 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:23:11 more