转自: https://blog.csdn.net/daqiang012/article/details/103947313?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522162848234916780357255732%2522%252C%2522scm%2522%253A%252220140713.130102334..%2522%257D&request_id=162848234916780357255732&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2~all~top_click~default-2-103947313.first_rank_v2_pc_rank_v29&utm_term=Linux%E7%B3%BB%E7%BB%9F&spm=1018.2226.3001.4449#t7
【嵌牛鼻子】Linux系统 内核的路由转发
【嵌牛提问】什么是Linux系统内核的路由转发?
【嵌牛正文】
Linux *** 作系统嵌入了 TCP /IP协议栈,协议软件具有路由转发功能。路由转发依赖作为路由器的主机中安装多块 网卡 ,当某一块网卡接收到数据包后,系统内核会根据数据包的目的IP地址,查询 路由表 ,然后根据查询结果将数据包发送到另外一块网卡,最后通过此网卡把数据包发送出去。此主机的处理过程就是路由器完成的核心功能。 [3]
通过修改Linux系统内核参数ip_forward的方式实现路由功能,系统使用sysctl命令配置与显示在/proc/sys目录中的内核参数。首先在命令行输入:cat/proc/sys/net/ipv4/ip_forwad,检查Linux内核是不是开启IP转发功能。如果结果为1,表明路由转发功能已经开启;如果结果为0,表明没有开启。出于安全考虑,Linux内核默认是禁止数据包路由转发的。在linux系统中,有临时和永久两种方法启用转发功能。 [3]
临时启用:此种方法只对当前会话起作用,系统重启后不再启用。临时开启的命令格式:sysctl–wnet.ipv4.ip_forward=1。 [3]
永久启用:此种永久性的启用IP转发功能,通过更改配置文件/etc/sysctl.conf中的语句行“net.ipv4.ip_forward=0”,修改为“net.ipv4.ip_forward=1”,保存配置文件后执行命令sysctl–p/etc/sysctl.conf,配置便立即启用。
Linux采用了段页式存储管理方式,Linux的虚拟地址空间为0~4G,如图1,Linux内核将这4G空间分为两部分,0~3G(0xC0000000~0xFFFFFFFF)的部分为用户空间,供用户进程使用,3~4G(0x00000000~0xBFFFFFFF)的部分为内核空间,专门供内核使用[4]。
八种用户空间与内核空间的数据交换方式,这八种方式各有优劣,下面就每种方式的优劣做一下对比:
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)