Man page - rtnetlink(7)
Packages contains this manual
- shm_overview(7)
- nss(5)
- proc_mtrr(5)
- intro(7)
- tcp(7)
- iso_8859-9(7)
- armscii-8(7)
- proc_kpagecount(5)
- initrd(4)
- mouse(4)
- proc_stat(5)
- x25(7)
- proc_interrupts(5)
- fifo(7)
- repertoiremap(5)
- icmp(7)
- futex(7)
- feature_test_macros(7)
- lp(4)
- bpf-helpers(7)
- epoll(7)
- proc_sys_dev(5)
- namespaces(7)
- proc_sysrq-trigger(5)
- proc_bus(5)
- cp1251(7)
- proc_pid_maps(5)
- proc_sys_vm(5)
- proc_pid_projid_map(5)
- st(4)
- proc_pid(5)
- issue(5)
- pid_namespaces(7)
- unicode(7)
- inode(7)
- hosts.equiv(5)
- iso-8859-13(7)
- proc_fb(5)
- proc_modules(5)
- proc_pid_autogroup(5)
- keyrings(7)
- sysvipc(7)
- proc_kmsg(5)
- cgroups(7)
- latin6(7)
- proc_pid_uid_map(5)
- unix(7)
- proc_pid_io(5)
- pts(4)
- packet(7)
- ld-linux.so(8)
- tzselect(8)
- iconv(1)
- proc_pid_syscall(5)
- proc_pid_net(5)
- proc_pid_pagemap(5)
- tty(4)
- proc_profile(5)
- standards(7)
- proc_pid_mounts(5)
- filesystems(5)
- iso-8859-15(7)
- locale(5)
- iso_8859_3(7)
- xattr(7)
- iso-8859-2(7)
- proc_uptime(5)
- persistent-keyring(7)
- credentials(7)
- proc_pid_timers(5)
- utmpx(5)
- vcsa(4)
- proc_pid_exe(5)
- proc_net(5)
- proc_timer_stats(5)
- ip(7)
- proc_pid_fd(5)
- ptmx(4)
- user_namespaces(7)
- resolv.conf(5)
- url(7)
- iso_8859_5(7)
- iso_8859-8(7)
- urn(7)
- process-keyring(7)
- proc_pid_auxv(5)
- proc_ksyms(5)
- proc_ide(5)
- veth(4)
- ldd(1)
- proc_swaps(5)
- landlock(7)
- proc_vmstat(5)
- system_data_types(7)
- cp1252(7)
- lirc(4)
- proc_kpageflags(5)
- random(7)
- precedence(7)
- cpuset(7)
- proc_pid_ns(5)
- acct(5)
- latin4(7)
- proc_pid_cgroup(5)
- proc_cpuinfo(5)
- iso_8859-2(7)
- proc_keys(5)
- charsets(7)
- pldd(1)
- proc_pid_stat(5)
- rtnetlink(7)
- netlink(7)
- ram(4)
- mem(4)
- iso-8859-6(7)
- proc_key-users(5)
- iso_8859_15(7)
- fanotify(7)
- proc_sys_net(5)
- sysfs(5)
- math_error(7)
- latin1(7)
- proc_pid_root(5)
- nptl(7)
- proc_cgroups(5)
- proc_iomem(5)
- proc_pid_statm(5)
- sem_overview(7)
- hier(7)
- full(4)
- proc_pid_status(5)
- proc_pid_cwd(5)
- proc_pid_cpuset(5)
- proc_scsi(5)
- uri(7)
- proc_diskstats(5)
- iso_8859_6(7)
- latin2(7)
- latin5(7)
- man-pages(7)
- ld.so(8)
- uts_namespaces(7)
- proc_pid_mountstats(5)
- intro(3)
- proc_pid_seccomp(5)
- proc_pid_wchan(5)
- attributes(7)
- symlink(7)
- mount_namespaces(7)
- charmap(5)
- tis-620(7)
- iso-8859-10(7)
- getent(1)
- proc_buddyinfo(5)
- ttytype(5)
- rtc(4)
- proc_malloc(5)
- suffixes(7)
- sln(8)
- signal(7)
- proc_sys_abi(5)
- signal-safety(7)
- time_namespaces(7)
- proc_pid_comm(5)
- raw(7)
- gai.conf(5)
- proc_crypto(5)
- locale(1)
- iso-8859-3(7)
- motd(5)
- proc_meminfo(5)
- iso-8859-8(7)
- protocols(5)
- proc_pid_map_files(5)
- pthreads(7)
- null(4)
- proc(5)
- zdump(8)
- socket(7)
- proc_sys_kernel(5)
- ddp(7)
- memusagestat(1)
- hd(4)
- iso-8859-14(7)
- shells(5)
- pipe(7)
- glob(7)
- proc_self(5)
- network_namespaces(7)
- utmp(5)
- proc_kcore(5)
- nsswitch.conf(5)
- sd(4)
- iso-8859-5(7)
- iso_8859_16(7)
- man(7)
- iso_8859-6(7)
- dir_colors(5)
- mq_overview(7)
- vsock(7)
- ascii(7)
- thread-keyring(7)
- fs(5)
- proc_pid_attr(5)
- proc_sys_debug(5)
- proc_sys(5)
- proc_pid_cmdline(5)
- pty(7)
- services(5)
- cgroup_namespaces(7)
- securetty(5)
- netdevice(7)
- iso_8859_13(7)
- host.conf(5)
- proc_pid_setgroups(5)
- proc_slabinfo(5)
- sock_diag(7)
- iso_8859-14(7)
- iso-8859-11(7)
- iso_8859_11(7)
- operator(7)
- regex(7)
- wavelan(4)
- proc_sys_fs(5)
- nologin(5)
- proc_pci(5)
- koi8-r(7)
- erofs(5)
- intro(2)
- utf8(7)
- proc_kallsyms(5)
- proc_sysvipc(5)
- queue(7)
- proc_sys_sunrpc(5)
- intro(5)
- latin8(7)
- mtrace(1)
- ipc_namespaces(7)
- dsp56k(4)
- iso_8859_4(7)
- proc_pid_smaps(5)
- proc_cmdline(5)
- rpc(5)
- proc_tty(5)
- proc_version(5)
- smartpqi(4)
- proc_pid_timerslack_ns(5)
- aio(7)
- session-keyring(7)
- resolver(5)
- slabinfo(5)
- wtmp(5)
- iso_8859_9(7)
- proc_locks(5)
- mailaddr(7)
- proc_pid_oom_score(5)
- kmem(4)
- iconvconfig(8)
- iso_8859-7(7)
- glibc(7)
- hostname(7)
- proc_thread-self(5)
- ipv6(7)
- iso_8859_7(7)
- proc_kpagecgroup(5)
- core(5)
- time(7)
- units(7)
- proc_dma(5)
- loop(4)
- address_families(7)
- zero(4)
- intro(4)
- procfs(5)
- iso_8859-4(7)
- vdso(7)
- tmpfs(5)
- iso-8859-16(7)
- iso_8859_10(7)
- user-session-keyring(7)
- libc(7)
- proc_fs(5)
- koi8-u(7)
- latin3(7)
- proc_tid_children(5)
- proc_pid_limits(5)
- proc_pid_coredump_filter(5)
- iso_8859-15(7)
- arp(7)
- urandom(4)
- iso_8859-10(7)
- hpsa(4)
- proc_pid_environ(5)
- boot(7)
- ftm(7)
- ld-linux(8)
- proc_driver(5)
- loop-control(4)
- iso_8859-16(7)
- proc_filesystems(5)
- tzfile(5)
- sprof(1)
- proc_pid_task(5)
- proc_pid_oom_score_adj(5)
- proc_mounts(5)
- iso-8859-4(7)
- iso_8859-1(7)
- utf-8(7)
- iso_8859-13(7)
- intro(6)
- proc_timer_list(5)
- rtld-audit(7)
- iso_8859-3(7)
- group(5)
- sched(7)
- proc_pid_clear_refs(5)
- hosts(5)
- iso_8859-11(7)
- numa(7)
- iso_8859_2(7)
- locale(7)
- iso-8859-1(7)
- fuse(4)
- proc_tid(5)
- proc_execdomains(5)
- proc_pid_mountinfo(5)
- intro(8)
- iso_8859_8(7)
- proc_loadavg(5)
- proc_pid_oom_adj(5)
- re_format(7)
- iso_8859_14(7)
- zic(8)
- bootparam(7)
- inotify(7)
- posixoptions(7)
- proc_partitions(5)
- iso-8859-9(7)
- proc_pid_mem(5)
- networks(5)
- proc_sys_user(5)
- udp(7)
- proc_zoneinfo(5)
- latin10(7)
- proc_pid_fdinfo(5)
- proc_pid_stack(5)
- memusage(1)
- spufs(7)
- pkeys(7)
- path_resolution(7)
- proc_ioports(5)
- intro(1)
- ldconfig(8)
- msr(4)
- svipc(7)
- port(4)
- proc_pid_personality(5)
- cciss(4)
- latin9(7)
- capabilities(7)
- localedef(1)
- vcs(4)
- iso_8859-5(7)
- elf(5)
- proc_sys_proc(5)
- console_codes(4)
- random(4)
- iso-8859-7(7)
- termcap(5)
- cpuid(4)
- environ(7)
- string_copying(7)
- proc_pid_gid_map(5)
- queue(3)
- termio(7)
- user-keyring(7)
- complex(7)
- latin7(7)
- proc_config.gz(5)
- udplite(7)
- kernel_lockdown(7)
- proc_devices(5)
- proc_apm(5)
- iso_8859_1(7)
- proc_pid_numa_maps(5)
apt-get install manpages
Available languages:
en fr ja ruManual
RTNETLINK
名 前書 式
説 明
ル ー テ ィ ン グ 属 性
メ ッ セ ー ジ
バ ー ジ ョ ン
バ グ
関 連 項 目
こ の 文 書 に つ い て
名 前
rtnetlink - Linux IPv4 ル ー テ ィ ン グ ソ ケ ッ ト
書 式
#include
<asm/types.h>
#include <linux/netlink.h>
#include <linux/rtnetlink.h>
#include <sys/socket.h>
rtnetlink_socket = socket(AF_NETLINK, int socket_type , NETLINK_ROUTE);
説 明
rtnetlink は カ ー ネ ル の ル ー テ ィ ン グ テ ー ブ ル を 読 ん だ り 変 更 し た り す る た め の も の で あ る 。 こ れ は カ ー ネ ル が 内 部 の サ ブ シ ス テ ム と 通 信 す る た め に も 用 い ら れ て い る が 、 そ れ は こ こ で は 記 述 し な い 。 こ の man ペ ー ジ で は ユ ー ザ ー 空 間 の プ ロ グ ラ ム と の 通 信 に 関 し て の み 述 べ る 。 ネ ッ ト ワ ー ク 経 路 ・ IP ア ド レ ス ・ リ ン ク パ ラ メ ー タ ー ・ 近 傍 設 定 (neighbor setup)・ キ ュ ー イ ン グ ル ー ル (queueing dicipline)・ ト ラ フ ィ ッ ク ク ラ ス ・ パ ケ ッ ト の ク ラ ス 分 類 な ど が 、 す べ て NETLINK_ROUTE ソ ケ ッ ト を 通 し て 制 御 で き る 。 rtnetlink は netlink メ ッ セ ー ジ を ベ ー ス に し て い る 。 詳 細 は netlink (7) を 見 る こ と 。
ル ー テ ィ ン グ 属 性
rtnetlink メ ッ セ ー ジ に は 、 初 期 ヘ ッ ダ ー の 後 に 付 加 的 な 属 性 を 持 つ も の が あ る 。
struct rtattr {
unsigned short rta_len; /* Length of option */
unsigned short rta_type; /* Type of option */
/* Data follows */
};
こ れ ら の 属 性 の 操 作 は 、 RTA_* マ ク ロ か libnetlink の み を 使 っ て 行 う べ き で あ る 。 rtnetlink (3) を 見 よ 。
メ ッ セ ー ジ
rtnetlink
は (標 準 的 な netlink
メ ッ セ ー ジ に
加 え て ) 以 下 の
メ ッ セ ー ジ タ
イ プ か ら 構 成
さ れ る 。
RTM_NEWLINK
,
RTM_DELLINK
,
RTM_GETLINK
指 定 し た ネ ッ ト ワ ー ク イ ン タ ー フ ェ ー ス の 情 報 を 、 生 成 ・ 削 除 ・ 取 得 す る 。 こ れ ら の メ ッ セ ー ジ は ifinfomsg 構 造 体 と 、 そ れ に 続 い て い く つ か の rtattr 構 造 体 を 伴 う 。
struct
ifinfomsg {
unsigned char ifi_family; /* AF_UNSPEC */
unsigned short ifi_type; /* Device type */
int ifi_index; /* Interface index */
unsigned int ifi_flags; /* Device flags */
unsigned int ifi_change; /* change mask */
};
ifi_flags は デ バ イ ス の フ ラ グ で あ る 。 netdevice (7) を 参 照 。 ifi_index は 他 と 重 な ら な い イ ン タ ー フ ェ ー ス の index で あ る (Linux 3.7 以 降 で は 、 RTMGRP_LINK メ ッ セ ー ジ で 0 以 外 の 値 を 指 定 す る こ と が で き 、 そ の た め 指 定 し た ifindex で リ ン ク を 作 成 で き る )。 ifi_change は 将 来 の 利 用 の た め に 予 約 さ れ て お り 、 常 に 0xFFFFFFFF に セ ッ ト す べ き で あ る 。
IFLA_STATS の 値 の 型 は struct rtnl_link_stats (Linux 2.4 以 前 で は struct net_device_stats ) で あ る 。
RTM_NEWADDR , RTM_DELADDR , RTM_GETADDR
イ ン タ ー フ ェ ー ス の IP ア ド レ ス の 情 報 を 追 加 ・ 削 除 ・ 取 得 す る 。 Linux 2.2 で は 、 一 つ の イ ン タ ー フ ェ ー ス に 複 数 の IP ア ド レ ス を 保 持 さ せ る こ と が で き 、 こ れ は 2.0 の 別 名 デ バ イ ス の 概 念 を 置 き 換 え る 。 Linux 2.2 で は 、 こ れ ら の メ ッ セ ー ジ は IPv4 と IPv6 の 両 方 の ア ド レ ス を サ ポ ー ト し て い る 。 こ れ ら は ifaddrmsg 構 造 体 を 伴 う 。 そ の あ と に rtattr ル ー テ ィ ン グ 属 性 が 続 く こ と も あ る 。
struct
ifaddrmsg {
unsigned char ifa_family; /* Address type */
unsigned char ifa_prefixlen; /* Prefixlength of address */
unsigned char ifa_flags; /* Address flags */
unsigned char ifa_scope; /* Address scope */
unsigned int ifa_index; /* Interface index */
};
ifa_family は ア ド レ ス フ ァ ミ リ ー の タ イ プ で あ る (現 在 は AF_INET ま た は AF_INET6 )。 ifa_prefixlen は ア ド レ ス の ア ド レ ス マ ス ク の 長 さ で あ る (IPv4 の よ う に 、 そ の フ ァ ミ リ ー で 定 義 さ れ て い る 場 合 )。 ifa_scope は ア ド レ ス の ス コ ー プ で あ る 。 ifa_index は ア ド レ ス が 関 連 づ け ら れ て い る イ ン タ ー フ ェ ー ス の index で あ る 。 ifa_flags は フ ラ グ ワ ー ド で 、 二 つ め の ア ド レ ス (古 い 別 名 イ ン タ ー フ ェ ー ス ) の 場 合 は IFA_F_SECONDARY に 、 永 続 的 な ア ド レ ス の 場 合 は IFA_F_PERMANENT に 適 用 さ れ る 。 ユ ー ザ ー に よ っ て セ ッ ト さ れ る フ ラ グ と 、 undocumented な フ ラ グ が あ る 。
RTM_NEWROUTE , RTM_DELROUTE , RTM_GETROUTE
ネ ッ ト ワ ー ク 経 路 の 情 報 を 生 成 ・ 削 除 ・ 取 得 す る 。 こ れ ら の メ ッ セ ー ジ は rtmsg 構 造 体 を 伴 う 。 そ の あ と に い く つ か の rtattr 構 造 体 を 続 け る こ と も で き る 。 RTM_GETROUTE で rtm_dst_len と rtm_src_len に 0 を セ ッ ト す る と 、 指 定 さ れ た ル ー テ ィ ン グ テ ー ブ ル の 全 て の エ ン ト リ ー を 所 得 す る 。 rtm_table と rtm_protocol 以 外 の 他 の フ ィ ー ル ド に 0 を 入 れ る と 、 ワ イ ル ド カ ー ド を 意 味 す る 。
struct rtmsg {
unsigned char rtm_family; /* Address family of route */
unsigned char rtm_dst_len; /* Length of destination */
unsigned char rtm_src_len; /* Length of source */
unsigned char rtm_tos; /* TOS filter */
unsigned char rtm_table; /* Routing table ID;
see RTA_TABLE below */
unsigned char rtm_protocol; /* Routing protocol; see below
*/
unsigned char rtm_scope; /* See below */
unsigned char rtm_type; /* See below */
unsigned int
rtm_flags;
};
RTPROT_STATIC よ り も 大 き な 値 は カ ー ネ ル に よ っ て 解 釈 さ れ な い 。 こ れ は 単 な る ユ ー ザ ー へ の 情 報 で あ る 。 こ れ ら は 経 路 情 報 の 情 報 源 を タ グ 付 け し た り 、 複 数 の ル ー テ ィ ン グ デ ー モ ン か ら の 情 報 を 区 別 す る た め に 用 い る こ と が で き る 。 既 に 割 り 当 て ら れ て い る ル ー テ ィ ン グ デ ー モ ン の 識 別 子 に つ い て は <linux/rtnetlink.h> を 見 よ 。
rtm_scope は 行 き 先 へ の 距 離 で あ る 。
ユ ー ザ ー は RT_SCOPE_UNIVERSE と RT_SCOPE_SITE の 間 の 値 を 用 い る こ と が で き る 。
rtm_flags は 以 下 の 意 味 を 持 つ :
rtm_table で は ル ー テ ィ ン グ テ ー ブ ル を 指 定 す る 。
ユ ー ザ ー は RT_TABLE_UNSPEC と RT_TABLE_DEFAULT . の 間 の 任 意 の 値 を 用 い る こ と が で き る 。
RTA_MULTIPATH contains several packed instances of struct rtnexthop together with nested RTAs ( RTA_GATEWAY ):
struct
rtnexthop {
unsigned short rtnh_len; /* Length of struct + length
of RTAs */
unsigned char rtnh_flags; /* Flags (see
linux/rtnetlink.h) */
unsigned char rtnh_hops; /* Nexthop priority */
int rtnh_ifindex; /* Interface index for this
nexthop */
}
There exist a bunch of RTNH_* macros similar to RTA_* and NLHDR_* macros useful to handle these structures.
struct rtvia {
unsigned short rtvia_family;
unsigned char rtvia_addr[0];
};
rtvia_addr is the address, rtvia_family is its family type.
RTA_PREF may contain values ICMPV6_ROUTER_PREF_LOW , ICMPV6_ROUTER_PREF_MEDIUM , and ICMPV6_ROUTER_PREF_HIGH defined incw <linux/icmpv6.h> .
RTA_ENCAP_TYPE may contain values LWTUNNEL_ENCAP_MPLS , LWTUNNEL_ENCAP_IP , LWTUNNEL_ENCAP_ILA , or LWTUNNEL_ENCAP_IP6 defined in <linux/lwtunnel.h> .
(こ れ ら の 値 を 埋 め る こ と !)
RTM_NEWNEIGH , RTM_DELNEIGH , RTM_GETNEIGH
近 傍 テ ー ブ ル (neighbor table) の エ ン ト リ ー (例 え ば ARP エ ン ト リ ー ) の 情 報 を 追 加 ・ 削 除 ・ 取 得 す る 。 こ の メ ッ セ ー ジ は ndmsg 構 造 体 を 伴 う 。
struct ndmsg {
unsigned char ndm_family;
int ndm_ifindex; /* Interface index */
__u16 ndm_state; /* State */
__u8 ndm_flags; /* Flags */
__u8 ndm_type;
};
struct
nda_cacheinfo {
__u32 ndm_confirmed;
__u32 ndm_used;
__u32 ndm_updated;
__u32 ndm_refcnt;
};
ndm_state は 以 下 の 状 態 の ビ ッ ト マ ス ク で あ る :
有 効 な ndm_flags は 以 下 の 通 り :
rtattr 構 造 体 は 、 rta_type フ ィ ー ル ド に 応 じ て そ れ ぞ れ 以 下 の 意 味 を 持 つ :
rta_type フ ィ ー ル ド が NDA_CACHEINFO の 場 合 に は 、 struct nda_cacheinfo ヘ ッ ダ ー が 続 く 。
RTM_NEWRULE , RTM_DELRULE , RTM_GETRULE
ル ー テ ィ ン グ ル ー ル を 追 加 ・ 削 除 ・ 取 得 す る 。 struct rtmsg を 伴 う 。
RTM_NEWQDISC , RTM_DELQDISC , RTM_GETQDISC
キ ュ ー イ ン グ ル ー ル を 追 加 ・ 削 除 ・ 取 得 す る 。 こ の メ ッ セ ー ジ は struct tcmsg を 伴 い 、 ま た そ の あ と に 属 性 が い く つ か 続 く こ と も あ る 。
struct tcmsg {
unsigned char tcm_family;
int tcm_ifindex; /* interface index */
__u32 tcm_handle; /* Qdisc handle */
__u32 tcm_parent; /* Parent qdisc */
__u32 tcm_info;
};
さ ら に 、 qdisc モ ジ ュ ー ル 特 有 の 様 々 な 属 性 を 指 定 で き る 。 詳 細 な 情 報 は 適 切 な イ ン ク ル ー ド フ ァ イ ル を 見 よ 。
RTM_NEWTCLASS , RTM_DELTCLASS , RTM_GETTCLASS
ト ラ フ ィ ッ ク ク ラ ス を 追 加 ・ 削 除 ・ 取 得 す る 。 こ れ ら の メ ッ セ ー ジ は 、 上 述 の struct tcmsg を 伴 う 。
RTM_NEWTFILTER , RTM_DELTFILTER , RTM_GETTFILTER
ト ラ フ ィ ッ ク フ ィ ル タ ー の 情 報 を 追 加 ・ 削 除 ・ 取 得 す る 。 こ れ ら の メ ッ セ ー ジ は 、 上 述 の struct tcmsg を 伴 う 。
バ ー ジ ョ ン
rtnetlink は Linux 2.2 の 新 機 能 で あ る 。
バ グ
こ の マ ニ ュ ア ル は 完 全 で は な い 。
関 連 項 目
cmsg (3), rtnetlink (3), ip (7), netlink (7)
こ の 文 書 に つ い て
こ の man ペ ー ジ は Linux man-pages プ ロ ジ ェ ク ト の リ リ ー ス 5.10 の 一 部 で あ る 。 プ ロ ジ ェ ク ト の 説 明 と バ グ 報 告 に 関 す る 情 報 は https://www.kernel.org/doc/man-pages/ に 書 か れ て い る 。