草庐IT

cgo_unix

全部标签

linux - UNIX 域套接字不能跨用户访问?

我在RedHatEnterprise上运行客户端/服务器应用程序,使用ZMQ进行消息传递。用于将客户端与服务器相关联的IPC套接字是使用Unix域套接字实现的。如果用户A启动服务器进程,似乎只有用户A启动的客户端才能连接到该套接字并通过该套接字进行通信。我们的项目要求客户端能够由不同的用户运行,所以这是一个主要的症结所在。套接字位于/tmp/ipc_assoc,默认权限为755。chmod777没有解决问题。chownuserB允许用户B访问套接字,但用户A然后失去访问权限。甚至root也不能​​访问套接字。机器上没有使用ACL或SeLinux。这是Unix域套接字的典型行为吗?有没有

linux - UNIX 域套接字不能跨用户访问?

我在RedHatEnterprise上运行客户端/服务器应用程序,使用ZMQ进行消息传递。用于将客户端与服务器相关联的IPC套接字是使用Unix域套接字实现的。如果用户A启动服务器进程,似乎只有用户A启动的客户端才能连接到该套接字并通过该套接字进行通信。我们的项目要求客户端能够由不同的用户运行,所以这是一个主要的症结所在。套接字位于/tmp/ipc_assoc,默认权限为755。chmod777没有解决问题。chownuserB允许用户B访问套接字,但用户A然后失去访问权限。甚至root也不能​​访问套接字。机器上没有使用ACL或SeLinux。这是Unix域套接字的典型行为吗?有没有

linux - 帮助 Unix 中的文件描述符

每个进程都有一个文件描述符表(FDT),每个文件都有一个文件描述符。stdin、stdout和stderr的文件描述符是0,1和2。这些值对于所有进程都是相同的。我相信FDT包含对这些文件的INODE条目的引用。文件描述符在进程之间重复使用,即它们不是全局唯一的。是否有一个由内核维护的全局FDT,每个进程的FDT都引用该全局FDT?FDTforstdin,stdout,stderr分别对应什么?这些特殊文件是否链接到键盘、显示器等?请提供文章、书籍等的链接。 最佳答案 文章"AsmalltrailthroughtheLinuxker

linux - 帮助 Unix 中的文件描述符

每个进程都有一个文件描述符表(FDT),每个文件都有一个文件描述符。stdin、stdout和stderr的文件描述符是0,1和2。这些值对于所有进程都是相同的。我相信FDT包含对这些文件的INODE条目的引用。文件描述符在进程之间重复使用,即它们不是全局唯一的。是否有一个由内核维护的全局FDT,每个进程的FDT都引用该全局FDT?FDTforstdin,stdout,stderr分别对应什么?这些特殊文件是否链接到键盘、显示器等?请提供文章、书籍等的链接。 最佳答案 文章"AsmalltrailthroughtheLinuxker

linux - AF_UNIX 套接字的默认协议(protocol)

我很好奇AF_UNIXSOCK_STREAM套接字的默认协议(protocol)是什么。我正在尝试准确追踪数据包开销应该是多少,但我无法弄清楚默认情况下使用的是什么协议(protocol)。我怀疑它不是IPPROTO_TCP因为:socketpair(AF_UNIX,SOCK_STREAM,0,sfd)工作时,这个:socketpair(AF_UNIX,SOCK_STREAM,IPPROTO_TCP,sfd)给出“协议(protocol)不受支持的错误”。 最佳答案 由于AF_UNIXunix套接字是本地事物,因此在这种情况下不会增

linux - AF_UNIX 套接字的默认协议(protocol)

我很好奇AF_UNIXSOCK_STREAM套接字的默认协议(protocol)是什么。我正在尝试准确追踪数据包开销应该是多少,但我无法弄清楚默认情况下使用的是什么协议(protocol)。我怀疑它不是IPPROTO_TCP因为:socketpair(AF_UNIX,SOCK_STREAM,0,sfd)工作时,这个:socketpair(AF_UNIX,SOCK_STREAM,IPPROTO_TCP,sfd)给出“协议(protocol)不受支持的错误”。 最佳答案 由于AF_UNIXunix套接字是本地事物,因此在这种情况下不会增

linux - 如何确定 unix 信号队列中挂起的信号数 (Linux)

我需要在Linux中的一个线程的信号队列中找到未决信号的数量。Linux是否提供任何API?此API需要从线程调用,而不是我们正在查询的线程。sigpending给出调用线程的API。是否有任何API将线程ID作为参数,并提供有关队列中未决信号的一些信息。感谢任何帮助。 最佳答案 sigpending()返回线程等待传递的一组信号。您可以迭代该sigset_t并使用sigismember()来测试成员资格。传统上,UNIX不会对一个信号的多个实例进行排队(从这个意义上说,它们仍然是“不可靠的”)。有时您可以通过实时信号获得这种效果。

linux - 如何确定 unix 信号队列中挂起的信号数 (Linux)

我需要在Linux中的一个线程的信号队列中找到未决信号的数量。Linux是否提供任何API?此API需要从线程调用,而不是我们正在查询的线程。sigpending给出调用线程的API。是否有任何API将线程ID作为参数,并提供有关队列中未决信号的一些信息。感谢任何帮助。 最佳答案 sigpending()返回线程等待传递的一组信号。您可以迭代该sigset_t并使用sigismember()来测试成员资格。传统上,UNIX不会对一个信号的多个实例进行排队(从这个意义上说,它们仍然是“不可靠的”)。有时您可以通过实时信号获得这种效果。

Linux/UNIX 安装数据文件

据我所知,在Linux/UNIX上安装C++命令行程序时,通常不会将其留在其原始目录中,而是将其移动到路径上已有的目录中,因此我有一个makeinstall条目:mvayane/usr/local/bin再往前看,我将得到一个或两个充满配置、数据和脚本文件的目录,程序需要读取这些文件,一些在启动时读取,一些稍后按需读取,在某些情况下随后再次修改并保存。这就引出了程序如何知道其数据文件所在位置的问题。在我的UbuntuLinux虚拟机上查看/bin,它似乎名副其实地只包含二进制文件,因此数据文件通常不会与程序放在同一目录中。将数据文件放在程序可以识别的位置的常用解决方案是什么?

Linux/UNIX 安装数据文件

据我所知,在Linux/UNIX上安装C++命令行程序时,通常不会将其留在其原始目录中,而是将其移动到路径上已有的目录中,因此我有一个makeinstall条目:mvayane/usr/local/bin再往前看,我将得到一个或两个充满配置、数据和脚本文件的目录,程序需要读取这些文件,一些在启动时读取,一些稍后按需读取,在某些情况下随后再次修改并保存。这就引出了程序如何知道其数据文件所在位置的问题。在我的UbuntuLinux虚拟机上查看/bin,它似乎名副其实地只包含二进制文件,因此数据文件通常不会与程序放在同一目录中。将数据文件放在程序可以识别的位置的常用解决方案是什么?