Man page - mq_overview(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
MQ_OVERVIEW
名 前説 明
ラ イ ブ ラ リ イ ン タ ー フ ェ ー ス と シ ス テ ム コ ー ル
バ ー ジ ョ ン
カ ー ネ ル の 設 定
持 続 性
リ ン ク
/proc イ ン タ ー フ ェ ー ス
リ ソ ー ス 制 限
メ ッ セ ー ジ キ ュ ー フ ァ イ ル シ ス テ ム の マ ウ ン ト
Linux で の メ ッ セ ー ジ キ ュ ー 記 述 子 の 実 装
IPC 名 前 空 間
注 意
バ グ
例
関 連 項 目
こ の 文 書 に つ い て
名 前
mq_overview - POSIX メ ッ セ ー ジ キ ュ ー の 概 要
説 明
POSIX メ ッ セ ー ジ キ ュ ー を 使 用 す る と 、 プ ロ セ ス 間 で メ ッ セ ー ジ の 形 で の デ ー タ の や り 取 り を 行 う こ と が で き る 。 こ の API は System V メ ッ セ ー ジ キ ュ ー の API ( msgget (2), msgsnd (2), msgrcv (2) な ど ) と は 異 な る も の だ が 、 同 様 の 機 能 を 提 供 す る 。
メ ッ セ ー ジ キ ュ ー の 作 成 と オ ー プ ン は mq_open (3) を 使 っ て 行 う 。 こ の 関 数 は メ ッ セ ー ジ キ ュ ー 記 述 子 (message queue descriptor) ( mqd_t ) を 返 す 。 こ れ 以 降 の コ ー ル で は 、 オ ー プ ン さ れ た メ ッ セ ー ジ キ ュ ー は メ ッ セ ー ジ キ ュ ー 記 述 子 を 使 っ て 参 照 さ れ る 。 各 メ ッ セ ー ジ キ ュ ー は /somename の 形 の 名 前 で 区 別 す る こ と が で き る 。 そ の 名 前 は 、 最 大 で NAME_MAX (す な わ ち 255) 文 字 の ヌ ル 終 端 さ れ た 文 字 列 で 、 ス ラ ッ シ ュ で 始 ま り 、 ス ラ ッ シ ュ 以 外 の 文 字 が 1 文 字 以 上 続 く 形 式 で あ る 。 mq_open (3) に 同 じ 名 前 を 渡 す こ と で 、 2つ の プ ロ セ ス で 同 一 の キ ュ ー を 操 作 す る こ と が で き る 。
メ ッ セ ー ジ の キ ュ ー へ の 送 受 信 は mq_send (3) と mq_receive (3) を 使 っ て 行 う 。 プ ロ セ ス が キ ュ ー の 使 用 を 終 え る と き に は 、 mq_close (3) を 使 っ て キ ュ ー を ク ロ ー ズ す る 。 キ ュ ー が も は や 不 要 と な っ た 場 合 に は 、 mq_unlink (3) を 使 っ て キ ュ ー を 削 除 で き る 。 キ ュ ー の 属 性 は mq_getattr (3) で 取 得 で き 、 (制 限 は あ る が ) mq_setattr (3) で 変 更 で き る 。 mq_notify (3) を 使 う こ と で 、 空 の キ ュ ー へ の メ ッ セ ー ジ 到 着 を 非 同 期 で 通 知 す る よ う に 要 求 す る こ と も で き る 。
メ ッ セ ー ジ キ ュ ー 記 述 子 は オ ー プ ン メ ッ セ ー ジ キ ュ ー 記 述 (open message queue description) へ の 参 照 で あ る ( open (2) も 参 照 )。 fork (2) 実 行 後 は 、 子 プ ロ セ ス は 親 プ ロ セ ス の メ ッ セ ー ジ キ ュ ー 記 述 子 の コ ピ ー を 継 承 す る 。 こ れ ら の 記 述 子 は 、 親 プ ロ セ ス の 対 応 す る メ ッ セ ー ジ キ ュ ー 記 述 子 と 同 じ オ ー プ ン メ ッ セ ー ジ キ ュ ー 記 述 を 参 照 し て い る 。 親 プ ロ セ ス と 子 プ ロ セ ス の 対 応 す る メ ッ セ ー ジ キ ュ ー 記 述 子 は 、 フ ラ グ ( mq_flags ) を 共 有 す る 。 な ぜ な ら 、 フ ラ グ は オ ー プ ン メ ッ セ ー ジ キ ュ ー 記 述 に 関 連 付 け ら れ て い る か ら で あ る 。
各 メ ッ セ ー ジ に は そ れ ぞ れ 優 先 度 (priority) が あ り 、 メ ッ セ ー ジ の 受 信 プ ロ セ ス へ の 配 送 は 常 に 優 先 度 の 高 い メ ッ セ ー ジ か ら 順 に 行 わ れ る 。 メ ッ セ ー ジ の 優 先 度 は 0 (低 優 先 ) か ら sysconf(_SC_MQ_PRIO_MAX) - 1 (高 優 先 ) の 値 を 持 つ 。 Linux で は 、 sysconf(_SC_MQ_PRIO_MAX) は 32768 を 返 す が 、 POSIX.1 で 要 求 さ れ て い る の は 最 低 限 0 か ら 31 ま で の 優 先 度 を 実 装 す る こ と だ け で あ り 、 実 装 に よ っ て は こ の 範 囲 の 優 先 度 し か サ ポ ー ト さ れ て い な い 。
こ の 節 の 残 り で は 、 POSIX メ ッ セ ー ジ キ ュ ー の Linux の 実 装 の 詳 細 に つ い て 説 明 す る 。
ラ イ ブ ラ リ イ ン タ ー フ ェ ー ス と シ ス テ ム コ ー ル
ほ と ん ど の 場 合 、 上 記 の mq_* () ラ イ ブ ラ リ イ ン タ ー フ ェ ー ス は 、 同 じ 名 前 の 下 位 層 の シ ス テ ム コ ー ル を 使 っ て 実 装 さ れ て い る 。 こ の 枠 組 み に あ て は ま ら な い も の を 以 下 の 表 に 示 す 。
バ ー ジ ョ ン
Linux で は POSIX メ ッ セ ー ジ キ ュ ー は カ ー ネ ル 2.6.6 以 降 で サ ポ ー ト さ れ て い る 。 glibc で は バ ー ジ ョ ン 2.3.4 以 降 で サ ポ ー ト さ れ て い る 。
カ ー ネ ル の 設 定
POSIX メ ッ セ ー ジ キ ュ ー の サ ポ ー ト は 、 カ ー ネ ル の 設 定 (configuration) オ プ シ ョ ン CONFIG_POSIX_MQUEUE で 設 定 可 能 で あ る 。 こ の オ プ シ ョ ン は デ フ ォ ル ト で は 有 効 で あ る 。
持 続 性
POSIX メ ッ セ ー ジ キ ュ ー は カ ー ネ ル 内 で 保 持 さ れ る 。 mq_unlink (3) で 削 除 さ れ な け れ ば 、 メ ッ セ ー ジ キ ュ ー は シ ス テ ム が シ ャ ッ ト ダ ウ ン さ れ る ま で 存 在 し 続 け る 。
リ ン ク
POSIX メ ッ セ ー ジ キ ュ ー API を 使 用 し た プ ロ グ ラ ム は cc -lrt で コ ン パ イ ル し 、 リ ア ル タ イ ム ラ イ ブ ラ リ librt と リ ン ク し な け れ ば な ら な い 。
/proc イ ン タ ー フ ェ ー ス
以
下 の イ ン タ ー
フ ェ ー ス を 使
っ て 、 POSIX メ ッ セ
ー ジ キ ュ ー が
消 費 す る カ ー
ネ ル メ モ リ ー
の 量 を 制 限 し
た り 、 新 規 の
メ ッ セ ー ジ キ
ュ ー の デ フ ォ
ル ト 属 性 を 設
定 し た り す る
こ と が で き る
。
/proc/sys/fs/mqueue/msg_default
(Linux 3.5 以
降 )
こ の フ ァ イ ル は 、 attr に NULL を 指 定 し て mq_open (3) を 呼 び 出 し て キ ュ ー が 作 成 さ れ た 際 に 、 そ の 新 規 キ ュ ー の mq_maxmsg 設 定 に 使 用 さ れ る 値 を 定 め て い る 。 こ の フ ァ イ ル の デ フ ォ ル ト 値 は 10 で あ る 。 最 小 値 と 最 大 値 は /proc/sys/fs/mqueue/msg_max と 同 様 で あ る 。 新 規 キ ュ ー の デ フ ォ ル ト の mq_maxmsg 値 は msg_default と msg_max の 小 さ い 方 と な る 。 Linux 2.6.28 よ り 前 は 、 デ フ ォ ル ト の mq_maxmsg は 10 で あ っ た 。 Linux 2.6.28 か ら Linux 3.4 ま で は 、 デ フ ォ ル ト 値 は msg_max 上 限 で 規 定 さ れ る 値 で あ っ た 。
/proc/sys/fs/mqueue/msg_max
こ の フ ァ イ ル を 使 っ て 、 一 つ の キ ュ ー に 入 れ ら れ る メ ッ セ ー ジ の 最 大 数 の 上 限 値 を 参 照 し た り 変 更 し た り で き る 。 こ の 値 は 、 mq_open (3) に 渡 す attr->mq_maxmsg 引 数 に 対 す る 上 限 値 と し て 機 能 す る 。 msg_max の デ フ ォ ル ト 値 は 10 で 、 最 小 値 は 1 (2.6.28 よ り 前 の カ ー ネ ル で は 10) で あ る 。 msg_max に 指 定 で き る 上 限 値 は HARD_MSGMAX で あ る 。 msg_max 上 限 は 特 権 プ ロ セ ス ( CAP_SYS_RESOURCE ) で は 無 視 さ れ る が 、 上 限 値 HARD_MSGMAX は ど ん な 場 合 に で も 適 用 さ れ る 。
HARD_MSGMAX の 定 義 は カ ー ネ ル の バ ー ジ ョ ン に よ り 異 な る 。
|
* |
Linux 2.6.32 以 前 : 131072 / sizeof(void *) |
|||
|
* |
Linux 2.6.33 以 上 3.4 以 下 : (32768 * sizeof(void *) / 4) |
|||
|
* |
Linux 3.5 以 降 : 65,536 |
/proc/sys/fs/mqueue/msgsize_default (Linux 3.5 以 降 )
こ の フ ァ イ ル は 、 attr に NULL を 指 定 し て mq_open (3) を 呼 び 出 し て キ ュ ー が 作 成 さ れ た 際 に 、 そ の 新 規 キ ュ ー の mq_msgsize 設 定 に 使 用 さ れ る 値 を 定 め て い る 。 こ の フ ァ イ ル の デ フ ォ ル ト 値 は 8192 バ イ ト で あ る 。 最 小 値 と 最 大 値 は /proc/sys/fs/mqueue/msgsize_max と 同 様 で あ る 。 msgsize_default が msgsize_max よ り 大 き い 場 合 は 、 新 規 キ ュ ー の デ フ ォ ル ト の mq_msgsize 値 は msgsize_max 上 限 と な る 。 Linux 2.6.28 よ り 前 は 、 デ フ ォ ル ト の mq_msgsize は 8192 で あ っ た 。 Linux 2.6.28 か ら Linux 3.4 ま で は 、 デ フ ォ ル ト 値 は msgsize_max 上 限 で 規 定 さ れ る 値 で あ っ た 。
/proc/sys/fs/mqueue/msgsize_max
こ の フ ァ イ ル を 使 っ て 、 メ ッ セ ー ジ の 最 大 サ イ ズ の 上 限 値 を 参 照 し た り 変 更 し た り で き る 。 こ の 値 は 、 mq_open (3) に 渡 す attr->mq_msgsize 引 数 に 対 す る 上 限 値 と し て 機 能 す る 。 msgsize_max の デ フ ォ ル ト 値 は 8192 バ イ ト で 、 最 小 値 は 128 (2.6.28 よ り 前 の カ ー ネ ル で は 8192) で あ る 。 msgsize_max の 上 限 は カ ー ネ ル の バ ー ジ ョ ン に よ り 異 な る 。
|
* |
Linux 2.6.28 よ り 前 の バ ー ジ ョ ン で は 、 上 限 は INT_MAX で あ る 。 |
||
|
* |
Linux 2.6.28 か ら 3.4 で は 、 上 限 は 1,048,576 で あ る 。 |
||
|
* |
Linux 3.5 以 降 で は 、 上 限 は 16,777,216 ( HARD_MSGSIZEMAX ) で あ る 。 |
msgsize_max 上 限 は 特 権 プ ロ セ ス ( CAP_SYS_RESOURCE ) で は 無 視 さ れ る が 、 Linux 3.5 以 降 で は 特 権 プ ロ セ ス に も HARD_MSGSIZEMAX と い う 上 限 が 適 用 さ れ る 。
/proc/sys/fs/mqueue/queues_max
こ の フ ァ イ ル を 使 っ て 、 作 成 可 能 な メ ッ セ ー ジ キ ュ ー 数 の シ ス テ ム 全 体 で の 制 限 を 参 照 し た り 変 更 し た り で き る 。 queues_max の デ フ ォ ル ト 値 は 256 で あ る 。 queues_max に 課 さ れ る 上 限 値 は な い 。 特 権 プ ロ セ ス ( CAP_SYS_RESOURCE ) は こ の 上 限 値 を 超 え て メ ッ セ ー ジ キ ュ ー を 作 成 で き る 。
リ ソ ー ス 制 限
リ ソ ー ス 上 限 RLIMIT_MSGQUEUE は 、 プ ロ セ ス の 実 UID に 対 応 す る 全 メ ッ セ ー ジ キ ュ ー が 消 費 す る メ モ リ ー 空 間 の 量 に 対 し て 上 限 を 設 定 す る 。 getrlimit (2) を 参 照 。
メ ッ セ ー ジ キ ュ ー フ ァ イ ル シ ス テ ム の マ ウ ン ト
Linux で は 、 メ ッ セ ー ジ キ ュ ー は 仮 想 フ ァ イ ル シ ス テ ム 内 に 作 成 さ れ る (他 の 実 装 で も 同 様 の 機 能 が 提 供 さ れ て い る も の も あ る が 、 詳 細 は 違 っ て い る だ ろ う )。 以 下 の コ マ ン ド を 使 う こ と で (ス ー パ ー ユ ー ザ ー は ) こ の フ ァ イ ル シ ス テ ム を マ ウ ン ト で き る :
#
mkdir
/dev/mqueue
#
mount -t mqueue none /dev/mqueue
マ ウ ン ト し た デ ィ レ ク ト リ の ス テ ィ ッ キ ー ビ ッ ト (sticky bit) は 自 動 的 に オ ン と な る 。
メ ッ セ ー ジ キ ュ ー フ ァ イ ル シ ス テ ム の マ ウ ン ト 後 は 、 フ ァ イ ル に 対 し て 通 常 使 う コ マ ン ド (例 え ば ls (1) や rm (1)) を 使 っ て 、 シ ス テ ム 上 の メ ッ セ ー ジ キ ュ ー を 表 示 し た り 操 作 し た り で き る 。
デ ィ レ ク ト リ 内 の 各 フ ァ イ ル の 内 容 は 1行 で あ り 、 キ ュ ー に 関 す る 情 報 が 表 示 さ れ る 。
$
cat
/dev/mqueue/mymq
QSIZE:129 NOTIFY:2 SIGNO:0 NOTIFY_PID:8260
各 フ ィ ー ル ド の 詳 細 は 以 下 の 通 り で あ る :
|
QSIZE |
キ ュ ー に 入 っ て い る 全 メ ッ セ ー ジ の 合 計 バ イ ト 数 (た だ し 「 バ グ 」 を 参 照 )。 |
NOTIFY_PID
こ の 値 が 0 以 外 の 場 合 、 こ の 値 の PID を 持 つ プ ロ セ ス が mq_notify (3) を 使 っ て 、 非 同 期 の メ ッ セ ー ジ 通 知 を 行 う よ う に 設 定 し た こ と を 示 す 。 ど の よ う に 通 知 が 行 わ れ る か は 、 以 下 の フ ィ ー ル ド に よ り 決 定 さ れ る 。
|
NOTIFY |
通 知 方 法 : 0 は SIGEV_SIGNAL ; 1 は SIGEV_NONE ; 2 は SIGEV_THREAD |
|||
|
SIGNO |
SIGEV_SIGNAL に 使 用 さ れ る シ グ ナ ル 番 号 。 |
Linux で の メ ッ セ ー ジ キ ュ ー 記 述 子 の 実 装
On Linux, a message queue descriptor is actually a file descriptor. (POSIX does not require such an implementation.) This means that a message queue descriptor can be monitored using select (2), poll (2), or epoll (7). This is not portable.
The close-on-exec flag (see open (2)) is automatically set on the file descriptor returned by mq_open (2).
IPC 名 前 空 間
POSIX メ ッ セ ー ジ キ ュ ー オ ブ ジ ェ ク ト と IPC 名 前 空 間 の 相 互 の 影 響 に 関 す る 議 論 は ipc_namespaces (7) を 参 照 。
注 意
System V メ ッ セ ー ジ キ ュ ー ( msgget (2), msgsnd (2), msgrcv (2) な ど ) は プ ロ セ ス 間 で メ ッ セ ー ジ を や り 取 り す る た め の 古 い API で あ る 。 POSIX メ ッ セ ー ジ キ ュ ー は System V メ ッ セ ー ジ キ ュ ー よ り も う ま く 設 計 さ れ た イ ン タ ー フ ェ ー ス を 提 供 し て い る 。 一 方 で 、 POSIX メ ッ セ ー ジ キ ュ ー は System V メ ッ セ ー ジ キ ュ ー と 比 べ る と 利 用 で き る シ ス テ ム が 少 な い (特 に 、 古 い シ ス テ ム で は 少 な い )。
現 在 の こ と ろ (バ ー ジ ョ ン 2.6.26 時 点 )、 Linux は POSIX メ ッ セ ー ジ キ ュ ー に 対 す る ア ク セ ス 制 御 リ ス ト (ACL) に 対 応 し て い な い 。
バ グ
バ ー ジ ョ ン 3.5 以 降 3.14 未 満 の Linux で は 、 queues_max 上 限 を 増 や す こ と が で き る 最 大 値 と し て 1024 ( HARD_QUEUESMAX ) と い う 最 大 上 限 値 が カ ー ネ ル に よ り 適 用 さ れ て い た 。 こ の 最 大 上 限 値 は 特 権 プ ロ セ ス に も 適 用 さ れ て い た 。 こ の 最 大 上 限 値 は Linux 3.14 で 削 除 さ れ 、 パ ッ チ で 安 定 版 カ ー ネ ル 3.5.x か ら 3.13.x か ら も こ の 最 大 上 限 値 は 削 除 さ れ た 。
As originally implemented (and documented), the QSIZE field displayed the total number of (user-supplied) bytes in all messages in the message queue. Some changes in Linux 3.5 inadvertently changed the behavior, so that this field also included a count of kernel overhead bytes used to store the messages in the queue. This behavioral regression was rectified in Linux 4.2 (and earlier stable kernel series), so that the count once more included just the bytes of user data in messages in the queue.
例
各 種 の メ ッ セ ー ジ キ ュ ー 関 数 を 使 用 し た 例 が mq_notify (3) に 記 載 さ れ て い る 。
関 連 項 目
getrlimit (2), mq_getsetattr (2), poll (2), select (2), mq_close (3), mq_getattr (3), mq_notify (3), mq_open (3), mq_receive (3), mq_send (3), mq_unlink (3), epoll (7), namespaces (7)
こ の 文 書 に つ い て
こ の man ペ ー ジ は Linux man-pages プ ロ ジ ェ ク ト の リ リ ー ス 5.10 の 一 部 で あ る 。 プ ロ ジ ェ ク ト の 説 明 と バ グ 報 告 に 関 す る 情 報 は https://www.kernel.org/doc/man-pages/ に 書 か れ て い る 。