Man page - unix(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 pl ja ru zh_TW zh_CNManual
UNIX
NAME(名 称 )SYNOPSIS(总 览 )
DESCRIPTION(描 述 )
ADDRESS FORMAT(地 址 格 式 )
SOCKET OPTIONS(套 接 字 选 项 )
ANCILLARY MESSAGES(辅 助 信 息 )
VERSIONS(版 本 )
NOTES(注 意 )
ERRORS(错 误 )
SEE ALSO(另 见 )
CREDITS(尾 注 )
[中 文 版 维 护 人 ]
[中 文 版 最 新 更 新 ]
《 中 国 linux论 坛 man手 册 页 翻 译 计 划 》 :
跋
NAME(名 称 )
unix, PF_UNIX, AF_UNIX, PF_LOCAL, AF_LOCAL - 用 于 本 地 内 部 进 程 通 讯 的 套 接 字 。
SYNOPSIS(总 览 )
#include
<sys/socket.h>
#include <sys/un.h>
unix_socket
= socket(PF_UNIX, type, 0);
error
= socketpair(PF_UNIX, type, 0, int
*
sv
);
DESCRIPTION(描 述 )
PF_UNIX (也 称 作 PF_LOCAL ) 套 接 字 族 用 来 在 同 一 机 器 上 的 提 供 有 效 的 进 程 间 通 讯 .Unix 套 接 字 可 以 是 匿 名 的 (由 socketpair (2) 创 建 ), 也 可 以 与 套 接 字 类 型 文 件 相 关 联 . Linux 还 支 持 一 种 抽 象 名 字 空 间 , 它 是 独 立 于 文 件 系 统 的 .
有 效 的 类 型 有 : SOCK_STREAM 用 于 面 向 流 的 套 接 字 , SOCK_DGRAM 用 于 面 向 数 据 报 的 套 接 字 ,其 可 以 保 存 消 息 界 限 . Unix 套 接 字 总 是 可 靠 的 ,而 且 不 会 重 组 数 据 报 .
Unix 套 接 字 支 持 把 文 件 描 述 符 或 者 进 程 的 信 用 证 明 作 为 数 据 报 的 辅 助 数 据 传 递 给 其 它 进 程 .
ADDRESS FORMAT(地 址 格 式 )
unix 地 址 定 义 为 文 件 系 统 中 的 一 个 文 件 名 或 者 抽 象 名 字 空 间 中 的 一 个 单 独 的 字 符 串 . 由 socketpair (2) 创 建 的 套 接 字 是 匿 名 的 .对 于 非 匿 名 的 套 接 字 ,目 标 地 址 可 使 用 connect (2) 设 置 . 本 地 地 址 可 使 用 bind (2) 设 置 . 当 套 接 字 连 接 上 而 且 它 没 有 一 个 本 地 地 址 时 , 会 自 动 在 抽 象 名 字 空 间 中 生 成 一 个 唯 一 的 地 址 .
#define UNIX_PATH_MAX 108
struct
sockaddr_un {
sa_family_t sun_family; /* AF_UNIX */
char sun_path[UNIX_PATH_MAX]; /* 路 径 名
*/
};
sun_family 总 是 包 含 AF_UNIX . sun_path 包 含 空 零 结 尾 的 套 接 字 在 文 件 系 统 中 的 路 径 名 . 如 果 sun_path 以 空 零 字 节 开 头 ,它 指 向 由 Unix 协 议 模 块 维 护 的 抽 象 名 字 空 间 . 该 套 接 字 在 此 名 字 空 间 中 的 地 址 由 sun_path 中 的 剩 余 字 节 给 定 . 注 意 抽 象 名 字 空 间 的 名 字 都 不 是 空 零 终 止 的 .
SOCKET OPTIONS(套 接 字 选 项 )
由 于 历 史 原 因 , 这 些 套 接 字 选 项 通 过 SOL_SOCKET 类 型 确 定 , 即 使 它 们 是 PF_UNIX 指 定 的 . 它 们 可 以 由 setsockopt (2) 设 置 . 通 过 指 定 SOL_SOCKET 作 为 套 接 字 族 用 getsockopt (2) 来 读 取 .
SO_PASSCRED 允 许 接 收 进 程 辅 助 信 息 发 送 的 信 用 证 明 . 当 设 置 了 该 选 项 且 套 接 字 尚 未 连 接 时 , 则 会 自 动 生 成 一 个 抽 象 名 字 空 间 的 唯 一 名 字 . 值 为 一 个 整 数 布 尔 标 识 .
ANCILLARY MESSAGES(辅 助 信 息 )
由
于 历 史 原 因 ,这
些 辅 助 信 息 类
型 通 过 SOL_SOCKET 类 型
确 定 , 即 使 它 们
是 PF_UNIX 指 定 的 . 要
发 送 它 们 , 可 设
置 结 构
cmsghdr
的
cmsg_level
字 段 为 SOL_SOCKET,
并 设 置
cmsg_type
字
段 为 其 类 型 . 要
获 得 更 多 信 息 ,
请 参 看
cmsg
(3).
SCM_RIGHTS
为 其 他 进 程 发 送 或 接 收 一 套 打 开 文 件 描 述 符 . 其 数 据 部 分 包 含 一 个 文 件 描 述 符 的 整 型 数 组 . 已 传 文 件 描 述 符 的 效 果 就 如 它 们 已 由 dup (2) 创 建 过 一 样 .
SCM_CREDENTIALS
发 送 或 者 接 收 unix 信 用 证 明 . 可 用 作 认 证 .信 用 证 明 传 送 以 struct ucred 辅 助 信 息 的 形 式 传 送 .
struct ucred {
pid_t pid; /* 发 送 进 程 的
进 程 标 识 */
uid_t uid; /* 发 送 进 程 的
用 户 标 识 */
gid_t gid; /* 发 送 进 程 的
组 标 识 */
};
发 送 者 确 定 的 信 用 证 明 由 内 核 检 查 . 一 个 带 有 有 效 用 户 标 识 0 的 进 程 允 许 指 定 不 与 其 自 身 值 相 匹 配 的 值 .发 送 者 必 须 确 定 其 自 身 的 进 程 标 识 (除 非 它 带 有 CAP_SYS_ADMIN ), 其 用 户 标 识 ,有 效 用 户 标 识 或 者 设 置 用 户 标 识 (除 非 它 带 有 CAP_SETUID ), 以 及 其 组 标 识 ,有 效 组 标 识 或 者 设 置 组 标 识 (除 非 它 带 有 CAP_SETGID ). 为 了 接 收 一 条 struct ucred 消 息 ,必 须 在 套 接 字 上 激 活 SO_PASSCRED 选 项 .
VERSIONS(版 本 )
SCM_CREDENTIALS 和 抽 象 名 字 空 间 是 在 Linux 2.2 中 引 入 的 ,不 应 该 在 要 求 可 移 植 的 程 序 中 使 用 .
NOTES(注 意 )
在 Linux 实 现 中 , 在 文 件 系 统 中 可 见 的 套 接 字 拥 有 它 们 所 在 目 录 的 权 限 许 可 . 它 们 的 所 有 者 ,组 和 权 限 可 以 作 修 改 . 如 果 进 程 不 拥 有 对 创 建 的 套 接 字 所 在 目 录 的 写 和 搜 索 (执 行 )权 限 , 则 创 建 一 个 新 的 套 接 字 会 失 败 . 这 种 执 行 方 式 与 许 多 由 BSD 发 展 而 来 的 系 统 不 同 , 那 些 系 统 会 忽 略 Unix 套 接 字 所 需 的 权 限 . 可 移 植 的 程 序 不 应 把 这 项 功 能 用 于 安 全 方 面 .
绑 定 文 件 名 到 套 接 字 会 在 文 件 系 统 中 创 建 一 个 套 接 字 , 这 个 套 接 字 在 它 不 再 需 要 时 必 须 由 调 用 者 删 除 (使 用 unlink (2)). 通 用 的 Unix 相 关 语 义 可 适 用 ; 套 接 字 可 在 任 何 时 候 删 除 , 而 且 当 最 后 一 个 引 用 关 闭 时 , 最 终 会 从 文 件 系 统 中 删 除 .
要 传 递 文 件 描 述 符 或 者 信 用 证 明 , 你 需 要 发 送 /读 取 至 少 一 个 字 节 .
ERRORS(错 误 )
|
ENOMEM |
内 存 溢 出 . |
ECONNREFUSED
connect (2) 调 用 了 一 个 未 在 监 听 的 套 接 字 对 象 . 这 可 能 发 生 在 远 程 套 接 字 不 存 在 或 者 文 件 名 不 是 套 接 字 的 时 候 .
|
EINVAL |
传 递 了 无 效 参 数 . 通 常 的 产 生 原 因 是 已 传 地 址 的 sun_type 字 段 的 AF_UNIX 设 置 丢 失 , 或 者 套 接 字 对 应 用 的 操 作 处 于 无 效 状 态 . |
EOPNOTSUPP
在 非 面 向 流 的 套 接 字 上 调 用 了 流 操 作 ,或 者 试 图 使 用 出 界 的 数 据 选 项 .
EPROTONOSUPPORT
传 递 的 协 议 是 非 PF_UNIX 的 .
ESOCKTNOSUPPORT
未 知 的 套 接 字 类 型 .
EPROTOTYPE
远 程 套 接 字 与 本 地 套 接 字 类 型 不 匹 配 (SOCK_DGRAM 对 SOCK_STREAM).
EADDRINUSE
选 择 的 本 地 地 址 已 经 占 用 ,或 者 文 件 系 统 套 接 字 对 象 已 经 存 在 .
EISCONN
在 一 个 已 经 连 接 的 套 接 字 上 调 用 connect (2) 或 者 指 定 的 目 标 地 址 在 一 个 已 连 接 的 套 接 字 上 .
ENOTCONN
套 接 字 操 作 需 要 一 个 目 的 地 址 ,但 是 套 接 字 尚 未 连 接 .
ECONNRESET
远 程 套 接 字 意 外 关 闭 .
|
EPIPE |
远 程 套 接 字 在 一 个 流 套 接 字 上 关 闭 了 .如 果 激 活 ,会 同 时 发 送 一 个 SIGPIPE 标 识 .这 可 以 通 过 传 递 MSG_NOSIGNAL 标 识 给 sendmsg (2) 或 者 recvmsg (2) 来 避 免 . |
||
|
EFAULT |
用 户 内 存 地 址 无 效 . |
||
|
EPERM |
发 送 者 在 struct ucred 中 传 递 无 效 的 信 用 证 明 . |
当 生 成 一 个 文 件 系 统 套 接 字 对 象 时 , 可 能 会 由 通 用 套 接 层 或 者 文 件 系 统 产 生 其 它 错 误 . 要 获 得 更 多 信 息 ,可 参 见 合 适 的 手 册 页 .
SEE ALSO(另 见 )
recvmsg (2), sendmsg (2), socket (2), socket (2), socketpair (2), cmsg (3), socket (7)
CREDITS(尾 注 )
本 man页 作 者 Andi Kleen.
[中 文 版 维 护 人 ]
riser <boomer@ccidnet.com>
[中 文 版 最 新 更 新 ]
2001/07/19
《 中 国 linux论 坛 man手 册 页 翻 译 计 划 》 :
http://cmpp.linuxforum.net
跋
本
页 面 中 文 版 由
中 文 man 手 册 页 计
划 提 供 。
中 文 man 手 册 页 计
划 :
https://github.com/man-pages-zh/manpages-zh