Gibt es eine Möglichkeit, eine Schnittstellen-MTU mithilfe von C unter Linux programmgesteuert festzulegen?
-
21-12-2019 - |
Frage
Im Moment macht mein Programm eine system()
Ruf an ifconfig
um dies zu tun.
Es scheint ein bisschen chaotisch zu sein – vielleicht ifconfig
liegt nicht auf dem Weg oder an einem nicht standardmäßigen Ort.Und dann müsste ich nachsehen iproute2 gleichwertig im Fehlerfall.
Gibt es eine Möglichkeit, dies programmgesteuert mit C festzulegen?
Vielen Dank!
Lösung
Sie können das SIOCSIFMTU-Feld in einem ioctl-Aufruf festlegen, etwa so:
struct ifreq ifr;
ifr.ifr_addr.sa_family = AF_INET;//address family
strncpy(ifr.ifr_name, "eth0", sizeof(ifr.ifr_name));//interface name where you want to set the MTU
ifr.ifr_mtu = 9100; //your MTU size here
if (ioctl(sockfd, SIOCSIFMTU, (caddr_t)&ifr) < 0)
//failed to set MTU. handle error.
Der obige Code legt die MTU eines Geräts (wie in ifr.name) mithilfe des Felds ifr_mtu in der ifreq-Struktur fest.
Verweisen: http://linux.die.net/man/7/netdevice
Andere Tipps
Sie können auch verwenden Netzlink.Das vollständige Beispiel:
#include <stdio.h>
#include <string.h>
#include <net/if.h>
#include <sys/socket.h>
#include <linux/rtnetlink.h>
#define IFACE_NAME "enp5s0"
int main(void) {
int ret, nl_sock;
unsigned int mtu = 8000;
struct rtattr *rta;
struct {
struct nlmsghdr nh;
struct ifinfomsg ifinfo;
char attrbuf[512];
} req;
nl_sock = socket(AF_NETLINK, SOCK_DGRAM, NETLINK_ROUTE);
if(nl_sock < 0) {
perror("socket():");
return -1;
}
memset(&req, 0, sizeof req);
req.nh.nlmsg_len = NLMSG_LENGTH(sizeof(struct ifinfomsg));
req.nh.nlmsg_flags = NLM_F_REQUEST;
req.nh.nlmsg_type = RTM_NEWLINK; // RTM_SETLINK
req.ifinfo.ifi_family = AF_UNSPEC;
req.ifinfo.ifi_index = if_nametoindex(IFACE_NAME);
if(!req.ifinfo.ifi_index) {
perror("if_nametoindex():");
return -1;
}
printf("%s index: %d\n", IFACE_NAME, req.ifinfo.ifi_index);
req.ifinfo.ifi_change = 0xffffffff;
rta = (struct rtattr *)(((char *) &req) + NLMSG_ALIGN(req.nh.nlmsg_len));
rta->rta_type = IFLA_MTU;
rta->rta_len = RTA_LENGTH(sizeof(unsigned int));
req.nh.nlmsg_len = NLMSG_ALIGN(req.nh.nlmsg_len) + RTA_LENGTH(sizeof mtu);
memcpy(RTA_DATA(rta), &mtu, sizeof mtu);
ret = send(nl_sock, &req, req.nh.nlmsg_len, 0);
if(ret < 0) {
perror("send():");
return -1;
}
return 0;
}
Lesen Sie auch: rtnetlink(3), rtnetlink(7)
Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit StackOverflow