socket编程connect提示Permission denied

socket编程,客户端通过connect连接server时报错“Permission denied”,原因是server端创建的监听设备的可读写执行的权限问题,将监听设备的可读写执行权限修改至最高权限问题解决。

例如:server端有一个这样的监听设备:

unix  2      [ ACC ]     SEQPACKET  LISTENING     369828353 10625/./xxx          /var/unix_socket/xxx/xxx/4316

实际上 /var/unix_socket/xxx/xxx/4316这个监听设备的权限是:

srwxr-xr-x 1 root root 0 Mar 26 08:09 /var/unix_socket/xxx/xxx/4316

这样的权限导致客户端在连接时,报“Permission denied”的错误,连接失败。

修改权限:chmod 777 /var/unix_socket/xxx/xxx/4316

然后客户端再连接时,便可连接成功。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
这个错误通常是由于 Elasticsearch 无法将标准输出连接到 journal socket 引起的。journal socket 是 Systemd Journal 的一部分,用于日志记录和跟踪系统服务。 出现 "Failed to connect stdout to the journal socket, ignoring: Permission denied" 错误的原因可能是 Elasticsearch 进程没有足够的权限来连接 journal socket。解决这个问题的一种方法是为 Elasticsearch 进程提供足够的权限。 你可以尝试以下方法: 1. 使用 root 权限运行 Elasticsearch 进程,或者在运行 Elasticsearch 命令时使用 sudo。例如:`sudo systemctl start elasticsearch`。 2. 检查 journal socket 的权限设置。确保 Elasticsearch 进程具有读取和写入 journal socket 的权限。你可以通过运行 `ls -l /run/systemd/journal/stdout` 来查看 journal socket 的权限设置。 如果权限设置不正确,可以使用以下命令更改权限: ``` sudo chown elasticsearch:elasticsearch /run/systemd/journal/stdout sudo chmod 660 /run/systemd/journal/stdout ``` 3. 如果你仍然遇到权限问题,可以尝试禁用 journal 输出。在 Elasticsearch 的配置文件中(elasticsearch.yml),将以下行注释掉: ``` logger: org.elasticsearch.bootstrap ``` 然后重新启动 Elasticsearch。 请注意,这些方法可能因操作系统和具体环境而异。如果以上方法无效,请提供更多关于你的系统配置和错误日志的详细信息,以便我能够更好地帮助你解决问题。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值