c udp linux,linux怎么开启udp端口
大家好,今天小编来为大家解答c udp linux这个问题,linux怎么开启udp端口很多人还不知道,现在让我们一起来看看吧!
基于Linux的远程指令系统(使用udp而不是tcp)
一. Linux下UDP编程框架
使用UDP进行程序设计可以分为客户端和服务器端两部分。
1.服务器端程序包括:
?建立套接字
?将套接字地址结构进行绑定
?读写数据
?关闭套接字
2.客户端程序包括:
?建立套接字
?读写数据
?关闭套接字
3.服务器端和客户端程序之间的差别
服务器端和客户端两个流程之间的主要差别在于对地址的绑定函数(bind()函数),而客户端可以不用进行地址和端口的绑定操作。
二.Linux中UDP套接字函数
从图可知,UDP协议的服务端程序设计的流程分为套接字建立,套接字与地址结构进行绑定,收发数据,关闭套接字;客户端程序流程为套接字建立,收发数据,关闭套接字等过程。它们分别对应socket(),bind(),sendto(),recvfrom(),和close()函数。
网络程序通过调用socket()函数,会返回一个用于通信的套接字描述符。Linux应用程序在执行任何形式的I/O操作的时候,程序是在读或者写一个文件描述符。因此,可以把创建的套接字描述符看成普通的描述符来操作,并通过读写套接字描述符来实现网络之间的数据交流。
1. socket
1>函数原型:
int socket(int domain,int type,int protocol)
2>函数功能:
函数socket()用于创建一个套接字描述符。
3>形参:
? domain:用于指定创建套接字所使用的协议族,在头文件
中定义。
常见的协议族如下:
AF_UNIX:创建只在本机内进行通信的套接字。
AF_INET:使用IPv4 TCP/IP协议
AF_INET6:使用IPv6 TCP/IP协议
说明:
AF_UNIX只能用于单一的UNIX系统进程间通信,而AF_INET是针对Interne的,因而可以允许在远程主机之间通信。一般把它赋为AF_INET。
? type:指明套接的类型,对应的参数如下
SOCK_STREAM:创建TCP流套接字
SOCK_DGRAM:创建UDP数据报套接字
SOCK_RAW:创建原始套接字
? protocol:
参数protocol通常设置为0,表示通过参数domain指定的协议族和参数type指定的套接字类型来确定使用的协议。当为原始套接字时,系统无法唯一的确定协议,此时就需要使用使用该参数指定所使用的协议。
4>返回值:执行成功后返回一个新创建的套接字;若有错误发生则返回一个-1,错误代码存入errno中。
5>举例:调用socket函数创建一个UDP套接字
int sock_fd;
sock_fd= socket(AF_INET,SOCK_DGRAM,0);
if(sock_fd< 0){
perror(“socket”);
exit(1);
}
2. bind
1>函数原型:
int bind(int sockfd,struct sockaddr*my_addr,socklen_taddrlen)
2>函数功能
函数bind()的作用是将一个套接字文件描述符与一个本地地址绑定在一起。
3>形参:
? sockfd:sockfd是调用socket函数返回的文件描述符;
? addrlen是sockaddr结构的长度。
? my_addr:是一个指向sockaddr结构的指针,它保存着本地套接字的地址(即端口和IP地址)信息。不过由于系统兼容性的问题,一般不使用这个结构,而使用另外一个结构(struct sockaddr_in)来代替
4>套接字地址结构:
(1)structsockaddr:
结构struct sockaddr定义了一种通用的套接字地址,它在
Linux/socket.h中定义。
struct sockaddr{
unsigned short sa_family;/*地址类型,AF_XXX*/
char sa_data[14];/*14字节的协议地址*/
}
a. sin_family:表示地址类型,对于使用TCP/IP协议进行的网络编程,该值只能是AF_INET.
b. sa_data:存储具体的协议地址。
(2)sockaddr_in
每种协议族都有自己的协议地址格式,TCP/IP协议组的地址格式为结构体struct sockaddr_in,它在netinet/in.h头文件中定义。
struct sockaddr_in{
unsigned short sin_family;/*地址类型*/
unsigned short sin_port;/*端口号*/
struct in_addr sin_addr;/*IP地址*/
unsigned char sin_zero[8];/*填充字节,一般赋值为0*/
}
a. sin_family:表示地址类型,对于使用TCP/IP协议进行的网络编程,该值只能是AF_INET.
b. sin_port:是端口号
c. sin_addr:用来存储32位的IP地址。
d.数组sin_zero为填充字段,一般赋值为0.
e. structin_addr的定义如下:
struct in_addr{
unsignedlong s_addr;
}
结构体sockaddr的长度为16字节,结构体sockaddr_in的长度为16字节。可以将参数my_addr的sin_addr设置为INADDR_ANY而不是某个确定的IP地址就可以绑定到任何网络接口。对于只有一IP地址的计算机,INADDR_ANY对应的就是它的IP地址;对于多宿主主机(拥有多个网卡),INADDR_ANY表示本服务器程序将处理来自所有网络接口上相应端口的连接请求
5>返回值:
函数成功后返回0,当有错误发生时则返回-1,错误代码存入errno中。
6>举例:调用socket函数创建一个UDP套接字
struct sockaddr_in addr_serv,addr_client;/*本地的地址信息*/
memset(&serv_addr,0,sizeof(struct sockaddr_in));
addr_serv.sin_family= AF_INET;/*协议族*/
addr_serv.sin_port= htons(SERV_PORT);/*本地端口号*/
addr_serv.sin_addr.s_addr= htonl(INADDR_ANY);/*任意本地地址*/
/*套接字绑定*/
if(bind(sock_fd,(struct sockaddr*)&addr_serv),sizeof(structsockaddr_in))<0)
{
perror(“bind”);
exit(1);
}
3.close
1>函数原型:
int close(intfd);
2>函数功能:
函数close用来关闭一个套接字描述符。
3>函数形参:
?参数fd为一个套接字描述符。
4>返回值:
执行成功返回0,出错则返回-1.错误代码存入errno中。
说明:
以上三个函数中,前两个要包含头文件
#include
#include
后一个包含:
#include
4.sendto
1>函数原型:
#include
#include
ssize_t sendo(ints,const void*msg,size_t len,int flags,const struct sockaddr*to,socklen_ttolen);
2>函数功能:
向目标主机发送消息
3>函数形参:
? s:套接字描述符。
?*msg:发送缓冲区
? len:待发送数据的长度
? flags:控制选项,一般设置为0或取下面的值
(1)MSG_OOB:在指定的套接字上发送带外数据(out-of-band data),该类型的套接字必须支持带外数据(eg:SOCK_STREAM).
(2)MSG_DONTROUTE:通过最直接的路径发送数据,而忽略下层协议的路由设置。
? to:用于指定目的地址
? tolen:目的地址的长度。
4>函数返回值:
执行成功后返回实际发送数据的字节数,出错返回-1,错误代码存入errno中。
5>函数举例:
char send_buf[BUFFERSIZE];
struct sockaddr_in addr_client;
memset(&addr_client,0,sizeof(struct sockaddr_in));
addr_client.sin_family= AF_INET;
addr_client.sin_port= htons(DEST_PORT);
if(inet_aton(“172.17.242.131”,&addr_client.sin_addr)<0){
perror(“inet_aton”);
exit(1);
}
if(sendto(sock_fd,send_buf,len,0,(strut sockaddr*)&addr_client,sizeof(struct sockaddr_in))<0){
perror(“sendto”);
exit(1);
}
5.recvfrom
1>函数原型:
#include
#include
ssize_t recvfrom(int s,void*buf,size_t len,intflags,struct sockaddr*from,socklen_t*fromlen);
2>函数功能:接收数据
3>函数形参:
? int s:套接字描述符
? buf:指向接收缓冲区,接收到的数据将放在这个指针所指向的内存空间。
? len:指定了缓冲区的大小。
? flags:控制选项,一般设置为0或取以下值
(1)MSG_OOB:请求接收带外数据
(2)MSG_PEEK:只查看数据而不读出
(3)MSG_WAITALL:只在接收缓冲区时才返回。
?*from:保存了接收数据报的源地址。
?*fromlen:参数fromlen在调用recvfrom前为参数from的长度,调用recvfrom后将保存from的实际大小。
4>函数返回值:
执行成功后返回实际接收到数据的字节数,出错时则返回-1,错误代码存入errno中。
5>函数实例:
char recv_buf[BUFFERSIZE];
struct sockaddr_in addr_client;
int src_len;
src_len= sizeof(struct sockaddr_in);
int src_len;
src_len= sizeof(struct sockaddr_in);
if(recvfrom(sock_fd,recv_buf,sizeof(recv_buf),0,(structsockaddr*)&src_addr,&src_len)<0){
perror(“again_recvfrom”);
exit(1);
}
三.UDP编程实例
客户端向服务器发送字符串Hello tiger,服务器接收到数据后将接收到字符串发送回客户端。
1.服务器端程序
1#include
2#include
3#include
4#include
5#include
6#include
7#include
8#include
9
10#define SERV_PORT 3000
11
12 int main()
13{
14 int sock_fd;//套接子描述符号
15 int recv_num;
16 int send_num;
17 int client_len;
18 char recv_buf[20];
19 struct sockaddr_in addr_serv;
20 struct sockaddr_in addr_client;//服务器和客户端地址
21 sock_fd= socket(AF_INET,SOCK_DGRAM,0);
22 if(sock_fd< 0){
23 perror("socket");
24 exit(1);
25} else{
26
27 printf("sock sucessful\n");
28}
29//初始化服务器断地址
30 memset(&addr_serv,0,sizeof(struct sockaddr_in));
31 addr_serv.sin_family= AF_INET;//协议族
32 addr_serv.sin_port= htons(SERV_PORT);
33 addr_serv.sin_addr.s_addr= htonl(INADDR_ANY);//任意本地址
34
35 client_len= sizeof(struct sockaddr_in);
36/*绑定套接子*/
37 if(bind(sock_fd,(struct sockaddr*)&addr_serv,sizeof(struct sockaddr_in))<0){
38 perror("bind");
39 exit(1);
40} else{
41
42 printf("bind sucess\n");
43}
44 while(1){
45 printf("begin recv:\n");
46 recv_num= recvfrom(sock_fd,recv_buf,sizeof(recv_buf),0,(struct sockaddr*)&addr_client,&client_len);
47 if(recv_num< 0){
48 printf("bad\n");
49 perror("again recvfrom");
50 exit(1);
51} else{
52 recv_buf[recv_num]='\0';
53 printf("recv sucess:%s\n",recv_buf);
54}
55 printf("begin send:\n");
56 send_num= sendto(sock_fd,recv_buf,recv_num,0,(struct sockaddr*)&addr_client,client_len);
57 if(send_num< 0){
58 perror("sendto");
59 exit(1);
60} else{
61 printf("send sucessful\n");
62}
63}
64 close(sock_fd);
65 return 0;
66}
2.客户端程序
1#include
2#include
3#include
4#include
5#include
6
7#include
8#include
9#include
10
11#define DEST_PORT 3000
12#define DSET_IP_ADDRESS"192.168.1.103"
13
14 int main()
15{
16 int sock_fd;/*套接字文件描述符*/
17 int send_num;
18 int recv_num;
19 int dest_len;
20 char send_buf[20]={"hello tiger"};
21 char recv_buf[20];
22 struct sockaddr_in addr_serv;/*服务端地址,客户端地址*/
23
24 sock_fd= socket(AF_INET,SOCK_DGRAM,0);//创建套接子
25//初始化服务器端地址
26 memset(&addr_serv,0,sizeof(addr_serv));
27 addr_serv.sin_family= AF_INET;
28 addr_serv.sin_addr.s_addr= inet_addr(DSET_IP_ADDRESS);
29 addr_serv.sin_port= htons(DEST_PORT);
30
31 dest_len= sizeof(struct sockaddr_in);
32 printf("begin send:\n");
33 send_num= sendto(sock_fd,send_buf,sizeof(send_buf),0,(struct sockaddr*)&addr_serv,dest_len);
34 if(send_num< 0){
35 perror("sendto");
36 exit(1);
37} else{
38
39 printf("send sucessful:%s\n",send_buf);
40}
41 recv_num= recvfrom(sock_fd,recv_buf,sizeof(recv_buf),0,(struct sockaddr*)&addr_serv,&dest_len);
42 if(recv_num<0){
43
44 perror("recv_from");
45 exit(1);
46} else{
47 printf("recv sucessful\n");
48}
49 recv_buf[recv_num]='\0';
50 printf("the receive:%s\n",recv_buf);
51 close(sock_fd);
52 return 0;
53}
Linux C/C++ UDP socket通信
Linux C/C++进行UDP socket通信时,其Server端与Client端的主要流程各有不同。Server端流程包括初始化socket,绑定端口与地址,接收数据并处理后,发送回应至客户端。而Client端则需要创建socket,获取Server地址与端口信息,接着发送请求数据,接收Server回应。
在进行UDP通信时,需用到四个关键API,分别是socket(),bind(),sendto()与recvfrom()。掌握这四个函数,便能熟练地利用UDP进行各种数据传输。
在UDP通信中,地址与端口的配置是通过sockaddr_in结构体来完成的。该结构体包括了IP地址、端口号、网络字节序等信息,便于程序准确地设置与识别通信目标。
具体来说,消息的发送与接收主要通过sendto()与recvfrom()函数来完成。sendto()函数用于发送数据包至指定目标,而recvfrom()则用于接收从任意地址发送来的数据包。这两个函数的使用,使得UDP通信在灵活性与效率上都有了显著提升。
为了验证上述流程与函数的正确性,通常会编写测试程序。Server端程序会监听特定端口,接收客户端发送的数据,并进行处理后将回应发回。同时,Client端程序则会尝试连接Server端并发送测试数据,接收Server的回应,以此测试通信的稳定性和数据传输的正确性。
linux的tftp
Linuxtftp命令详解Linuxtftp命令怎么用?
ftp命令用在本机和tftp服务器之间使用TFTP协议传输文件。
TFTP是用来下载远程文件的最简单网络协议,它其于UDP协议而实现。嵌入式linux的tftp开发环境包括两个方面:一是linux服务器端的tftp-server支持,二是嵌入式目标系统的tftp-client支持。因为u-boot本身内置支持tftp-client,所以嵌入式目标系统端就不用配置了。下面就详细介绍一下linux服务器端tftp-server的配置。
语法tftp(选项)(参数)选项-c:指定与tftp服务器连接成功后,立即要执行的指令;-m:指定文件传输模式。可以是ASCII或者Binary;-v:显示指令详细执行过程;-V:显示指令版本信息。参数
主机:指定tftp要联机的tftp服务器的ip地址或主机名。
实例
1、安装tftp服务器
需要安装xinetd、tftp和tftp-server3个软件
如果能上网,通过yum安装:
yuminstallxinetdyuminstalltftpyuminstalltftp-server
如果不能上网,可以直接安装提供的rpm包:
rpm-ivhxinetd-2.3.14-18.fc9.i386.rpmrpm-ivhtftp-0.48-3.fc9.i386.rpmrpm-ivhtftp-server-0.48-3.fc9.i386.rpm
2、配置tftp服务器
修改/etc/xinetd.d/tftp文件,将其中的disable=yes改为disable=no。主要是设置TFTP服务器的根目录,开启服务。修改后的文件如下:
servicetftp{socket_type=dgramprotocol=udpwait=yesuser=rootserver=/usr/sbin/in.tftpdserver_args=-s/home/mike/tftpboot-cdisable=noper_source=11cps=1002flags=IPv4}
说明:修改项,其中path>处可以改为你的tftp-server的根目录,参数-s指定chroot,-c指定了可以创建文件。
3、启动tftp服务器并关闭防火墙
/etc/init.d/iptablesstop//关闭防火墙sudo/sbin/servicexinetdstart或servicexinetdrestart/etc/init.d/xinetdstart
看到启动就可以了
4、查看tftp服务是否开启
netstat-a|greptftp
显示结果为表明服务已经开启,就表明tftp配置成功了。
5、tftp使用
复制一个文件到tftp服务器目录,然后在主机启动tftp软件,进行简单测试。
tftp192.168.1.2tftp>getdownloadfile>tftp>putuploadfile>tftp>q
6、tftp命令用法如下
tftpyour-ip-address
进入TFTP操作:
connect:连接到远程tftp服务器
mode:文件传输模式
put:上传文件
get:下载文件
quit:退出
verbose:显示详细的处理信息
tarce:显示包路径
status:显示当前状态信息
binary:二进制传输模式
ascii:ascii传送模式
rexmt:设置包传输的超时时间
timeout:设置重传的超时时间
help:帮助信息
?:帮助信息
7、如果老是出现“AVCDenial,clickicontoview”的错误,并不能传输文件,需要作如下修改
修改,将SELINUX设定为disable,使用命令让selinux配置文件生效。
8、Busybox中tftp命令的用法
命令格式为:
tftp...host
如果要下载或上传文件的话是一定要用这些option的。
-g表示下载文件(get)-p表示上传文件(put)-l表示本地文件名(localfile)-r表示远程主机的文件名(remotefile)
例如,要从远程主机192.168.1.2上下载embedexpert,则应输入以下命令
tftp-g-rembedexpert192.168.1.2
用linux中做pxe安装系统的时候,出现PXE-E32:TFTPOPentimeout怎么回事?
这是对应的tftpserver没有起来,需要检查dhcp中对tftp的配置是否正确,网络是否连通,tftpserver是否运行正常。
能不能在sd卡上装linux系统?
可以实现的,你可以通过SD卡启动uboot,不过加载内核的话,可以通过tftp下载内核加载;也可以通过nand里面的内核,如果用SD卡内核是不现实的。当你uboot,kernel都启动之后,从SD卡启动系统应该很简单了。
linuxcp命令无法创建普通文件?
答方法如下
1、应该是没有配置tftp服务器,不存在/tftpboot/这个目录。如果不需要tftp服务器的话,可以忽略,也可以将拷贝内核映像。
2、要在同时拷贝多个文件,我们只需要将多个文件用空格隔开。如下示例:$cpfile_1.txtfile_2.txtfile_3.txt/home/pungki/office。
3、要拷贝一个目录的话会有点棘手。你需要添加-r或者-R选项来实现。-r或-R选项表明递归操作。无论该目录是否为空目录,这个选项都是必要的。如下示例:$cp-rdirectory_1/home/pungki/office。
需要注意的一件事,你需要移除在目录名尾部的斜杠。否则你会收到类似的错误信息cp:omittingdirectory‘directory_1/’。