各类资料学习下载合集
链接:https://pan.quark.cn/s/770d9387db5f
当你打开浏览器访问百度时,背后发生了什么?当你登录微信时,消息是如何精准送达你的设备,而不是别人的?这一切都离不开网络通信的两个基本要素:IP 地址和端口。本文将用生动的比喻和实战代码,带你彻底搞懂它们。
一、 IP 地址:网络世界的“门牌号”
想象一下现实世界中的邮政系统,IP 地址就相当于每栋建筑的唯一门牌号。它告诉数据包该去往哪台设备。IP 地址主要分为两类:
1. 公网 IP (Public IP)
定义:全球范围内唯一,由互联网服务提供商(如中国电信、联通)分配。作用:是你的设备在茫茫互联网中的“身份证”,拥有它才能直接访问外部网络(俗称“上网”)。比喻:相当于你在全球地图上独一无二的家庭住址。
2. 局域网 IP (Private IP / LAN IP)
定义:在一个局部网络(如你家的 Wi-Fi、公司内网)内唯一,但不同局域网之间可以重复。常见的格式有 、
192.168.x.x 等。作用:用于局域网内部设备之间的通信。比喻:相当于你家小区里“A栋-101室”这样的内部地址。这个地址在你的小区是唯一的,但在隔壁小区可能也有一栋“A栋-101室”。
10.x.x.x
关键问题:局域网设备如何访问互联网?
答案是路由器。路由器就像小区的“收发室”,它拥有一个公网 IP。当你访问百度时,你的请求会先发给路由器,路由器用自己的公网 IP 帮你去访问百度,收到响应后再转发给你。这个过程称为网络地址转换(NAT)。
二、 端口:定位服务的“房间号”
如果 IP 地址是建筑的门牌号,那么端口(Port)就是这栋建筑里每个房间的房间号。一台计算机(一个 IP)上可以同时运行很多网络服务,比如 Web 服务、FTP 服务、游戏服务等。操作系统通过端口号来区分数据包应该交给哪个应用程序处理。
范围:端口是一个 16 位的数字,范围从 0 到 65535。例子:
你访问网站时,浏览器默认请求服务器的 80 端口(HTTP)或 443 端口(HTTPS)。你的微信客户端可能正在监听 8080 端口,等待接收新消息。
结论:IP 地址 + 端口号 才能唯一确定一个网络服务。 就像一个完整的收件地址:“某某大街123号(IP),80号房间(Port)”。
IP:Port
三、 实战演练:Linux 命令与代码示例
理论说完了,我们动手实践一下。
1. 常用 Linux 命令
查看本机 IP 地址:
# 现代 Linux 系统推荐使用
ip addr
运行结果示例:
2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc fq_codel state UP group default qlen 1000
link/ether 00:16:3e:0a:1b:2c brd ff:ff:ff:ff:ff:ff
inet 192.168.1.101/24 brd 192.168.1.255 scope global eth0 <-- 这是你的局域网IP
inet6 fe80::216:3eff:fe0a:1b2c/64 scope link
测试网络连通性 (ping):
# 测试到公共DNS服务器的网络是否通畅
ping 114.114.114.114
运行结果示例:
PING 114.114.114.114 (114.114.114.114) 56(84) bytes of data.
64 bytes from 114.114.114.114: icmp_seq=1 ttl=93 time=10.5 ms
64 bytes from 114.114.114.114: icmp_seq=2 ttl=91 time=10.2 ms
这表明你的设备与公网是连通的。
2. 代码案例:一个简单的 Server-Client 程序
我们将编写一个服务器程序,它在 端口监听;再编写一个客户端程序,去连接这个服务器。
9999
服务器代码 (
server.c)
server.c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <arpa/inet.h>
#define PORT 9999
int main() {
int server_fd, new_socket;
struct sockaddr_in address;
int opt = 1;
int addrlen = sizeof(address);
char buffer[1024] = {0};
// 创建 socket
server_fd = socket(AF_INET, SOCK_STREAM, 0);
// 绑定 IP 和端口
address.sin_family = AF_INET;
address.sin_addr.s_addr = INADDR_ANY; // 监听本机所有 IP
address.sin_port = htons(PORT); // 监听 9999 端口
bind(server_fd, (struct sockaddr *)&address, sizeof(address));
// 开始监听
listen(server_fd, 3);
printf("Server is listening on port %d...
", PORT);
// 接受连接
new_socket = accept(server_fd, (struct sockaddr *)&address, (socklen_t*)&addrlen);
// 读取客户端发来的消息
read(new_socket, buffer, 1024);
printf("Message from client: %s
", buffer);
// 发送回执
send(new_socket, "Message received!", 17, 0);
close(new_socket);
close(server_fd);
return 0;
}
客户端代码 (
client.c)
client.c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <arpa/inet.h>
#define PORT 9999
int main() {
int sock = 0;
struct sockaddr_in serv_addr;
char *hello = "Hello from client!";
char buffer[1024] = {0};
sock = socket(AF_INET, SOCK_STREAM, 0);
serv_addr.sin_family = AF_INET;
serv_addr.sin_port = htons(PORT); // 目标端口
// 将 IP 地址 "127.0.0.1" (本机) 转换为二进制格式
inet_pton(AF_INET, "127.0.0.1", &serv_addr.sin_addr); // 目标 IP
// 连接服务器
if (connect(sock, (struct sockaddr *)&serv_addr, sizeof(serv_addr)) < 0) {
printf("Connection Failed
");
return -1;
}
// 发送消息
send(sock, hello, strlen(hello), 0);
printf("Message sent to server.
");
// 接收回执
read(sock, buffer, 1024);
printf("Reply from server: %s
", buffer);
close(sock);
return 0;
}
运行与结果
编译代码:
gcc server.c -o server
gcc client.c -o client
启动服务器 (在第一个终端窗口):
./server
输出:
Server is listening on port 9999...
启动客户端 (在第二个终端窗口):
./client
客户端输出:
Message sent to server.
Reply from server: Message received!
此时,服务器窗口会输出:
Message from client: Hello from client!
分析:这个简单的例子完美展示了 IP 和端口的协同工作。客户端通过指定服务器的 IP () 和端口 (
127.0.0.1),成功地建立了连接并完成了数据交换。
9999
四、 职责分工:运维与开发
在实际工作中,IP 和端口的管理涉及两个角色:
开发人员:负责编写像 这样的应用程序,决定程序使用哪个端口。运维人员:负责将程序部署到服务器上,配置服务器的网络环境、防火墙规则,确保客户端可以访问到开发指定的端口。
server.c
五、 知识小结
| 知识点 | 核心内容 | 重点/易混淆点 |
|---|---|---|
| IP与端口 | 网络通信的基础标识,IP定位设备,端口区分服务。 | IP 分类(公网/局域网)、端口作用(0-65535)。 |
| 公网IP | 全球唯一,可直接访问 Internet。 | 唯一性(全球不重复)、直接上网能力。 |
| 局域网IP | 小型网络内部分配(如 )。 |
局部唯一性、需路由转发才能访问外网。 |
| 网络访问逻辑 | 局域网设备通过路由器/NAT转换访问公网。 | 路由转发机制、外网依赖公网IP。 |
| 运维与开发 | 运维管理网络配置,开发专注程序逻辑。 | 职责边界(运维不写代码,开发不部署)。 |






