TAP/TUN(二)


tap.c代碼
    
  1. #include<assert.h>
  2. #include<fcntl.h>
  3. #include<stdio.h>
  4. #include<string.h>
  5. #include<sys/socket.h>
  6. #include<sys/ioctl.h>
  7. #include<linux/if.h>
  8. #include<linux/if_tun.h>
  9. #include<sys/types.h>
  10. #include<errno.h>
  11. #include<net/route.h>
  12. intTap=0;
  13. intTap1=0;
  14. int interface_up(char*interface_name)
  15. {
  16. int s;
  17. if((s = socket(PF_INET,SOCK_STREAM,0))<0)
  18. {
  19. printf("Error create socket :%m/n", errno);
  20. return-1;
  21. }
  22. struct ifreq ifr;
  23. strcpy(ifr.ifr_name,interface_name);
  24. short flag;
  25. flag = IFF_UP;
  26. if(ioctl(s, SIOCGIFFLAGS,&ifr)<0)
  27. {
  28. printf("Error up %s :%m/n",interface_name, errno);
  29. return-1;
  30. }
  31. ifr.ifr_ifru.ifru_flags |= flag;
  32. if(ioctl(s, SIOCSIFFLAGS,&ifr)<0)
  33. {
  34. printf("Error up %s :%m/n",interface_name, errno);
  35. return-1;
  36. }
  37. return0;
  38. }
  39. int tun_create(char*dev,int flags)
  40. {
  41. struct ifreq ifr;
  42. int fd, err;
  43. assert(dev != NULL);
  44. if((fd = open("/dev/net/tun", O_RDWR))<0){
  45. return fd;
  46. }
  47. memset(&ifr,0,sizeof(ifr));
  48. ifr.ifr_flags |= flags;
  49. if(*dev !='\0'){
  50. strncpy(ifr.ifr_name, dev, IFNAMSIZ);
  51. }
  52. if((err=ioctl(fd,TUNSETIFF,(void*)&ifr))<0){
  53. close(fd);
  54. return err;
  55. }
  56. strcpy(dev,ifr.ifr_name);
  57. return fd;
  58. }
  59. int main(int argc,char*argv[])
  60. {
  61. char tun_name[IFNAMSIZ]="tap0";
  62. char tun_name1[IFNAMSIZ]="tap1";
  63. Tap=tun_create(tun_name, IFF_TAP | IFF_NO_PI);
  64. if(Tap<0){
  65. perror("tun_create");
  66. return1;
  67. }
  68. printf("TAP name is %s\n", tun_name);
  69. printf("Tap=%d\n",Tap);
  70. //interface_up(tun_name);
  71. system("ifconfig tap0 10.66.31.185 netmask 255.255.0.0 up");
  72. while(1);
  73. }
 

程序要一直運行,否則程序退出后創建的TAP設備會被釋放


在前面講到了TAP口的基本原理。
那么我們直接用TAP口轉發報文和TAP口綁定的虛擬網卡上用socket上發報文有什么區別呢?
    
 我上圖,我們可以看到, Virtual NIC 就是我們的虛擬網卡,那么如果從TAP口進行報文發送的時候,
我們說了,TAP的使用者就相當於遠程機器的網卡,也就是說報文會從虛擬網卡進入到協議棧,然后走內核
的轉發流程進行轉發(如果是本機就再去LocalIn點),否則就通過forward 到postRoute節點再次進入到TAP口,被
TAP接收后到應用層進行再次轉發出去。
但是如果是通過Virtual NIC的socket發送消息就不同了,會先進入到內核,然后進入到轉發面(LocalOut->forward),如果是本機發給本機的,報文就會進入到LocalIn節點,再被socket接收。
    如果是非本機的,就會通過postRoute發出去,再進入到TAP口被應用層轉發面走轉發流程。
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 





附件列表

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM