zabbix_agentd重装后启动时IPC和共享内存段问题
zabbix_agentd不知为啥被干掉后重装了zabbix,zabbix用户组id也变了。
重装zabbix后导致zabbix_agentd无法启动,两个问题
问题1:
zabbix_agentd [4796]: cannot attach to existing shared memory: [13] Permission denied
4796:20190213:172151.185 cannot allocate shared memory for collector
查看共享内存段:
[root@10.0.3.122 ~]# ipcs -m
------ Shared Memory Segments --------
key shmid owner perms bytes nattch status
0x6c01c2b4 327680 498 600 292944 0
0x00000000 32769 root 600 134217728 129 dest
以上几个字段的意思是:键 shmid 拥有者 权限 字节 nattch 状态
其中key为0x6c01c2b4的内存段owner为498,是zabbix用户旧的uid
删除该共享内存即可:
[root@10.0.3.122 ~]# ipcrm -m 327680 #删除共享内存(注意,这里对共享内存段的操作要使用shmid值)
[root@10.0.3.122 ~]# ipcs -m
------ Shared Memory Segments --------
key shmid owner perms bytes nattch status
0x00000000 32769 root 600 134217728 129 dest
重启zabbix即可
问题2:
zabbix_agentd [13265]: cannot recreate Zabbix semaphores for IPC key 0x7a02188f Semaphore ID 4294967295: [22] Invalid argument
报错提示了key 0x7a02188f
查看KEY为0x7a02188f的信号队列:
[root@10.0.3.122 ~]# ipcs 0x7a02188f
------ Shared Memory Segments --------
key shmid owner perms bytes nattch status
------ Semaphore Arrays --------
key semid owner perms nsems
0x00000000 0 root 600 1
0x00000000 32769 root 600 1
0x7a02188f 196610 498 600 14 #问题在这里,owner的uid是旧zabbix用户id
0x7a020002 294915 zabbix 600 14
------ Message Queues --------
key msqid owner perms used-bytes messages
删除KEY为0x7a02188fde信号量数组
[root@10.0.3.122 ~]# ipcrm -S 0x7a02188f
[root@10.0.3.122 ~]# ipcs 0x7a02188f
------ Shared Memory Segments --------
key shmid owner perms bytes nattch status
------ Semaphore Arrays --------
key semid owner perms nsems
0x00000000 0 root 600 1
0x00000000 32769 root 600 1
0x7a020002 294915 zabbix 600 14
------ Message Queues --------
key msqid owner perms used-bytes messages
重启zabbix即可
以上两个问题原因:
zabbix_agentd异常关闭导致信号量数组和共享内存段的属主还是旧uid,但是每个进程启动的时候其key值是固定的,所以重装zabbix后,它没有权限删除和重新创建信号量数组和共享内存段,从而出现了无法启动的问题
以上问题的解决也是参考网上的博客文档,可能存在不足,后续完善。
问题3:
zabbix_agentd [13172]: cannot create IPC key for path [/etc/zabbix/zabbix_agentd.conf] id [l]: [13] Permission denied
13172:20190214:103932.147 cannot create IPC key for collector
这个问题是zabbx 配置文件的目录没权限导致的,还是之前重装zabbix导致zabbix用户组id改变了
[root@10.0.3.122 ~]# ll /etc/zabbix/
total 32
drwxr-xr-x 2 498 499 4096 Feb 11 15:40 plugins
drwxrwxr-x 2 498 499 4096 Feb 1 11:00 plugins_conf
-rw-r--r-- 1 498 499 5832 Nov 13 05:41 zabbix_agentd.conf
-rw-r--r-- 1 498 499 10423 Jan 28 18:48 zabbix_agentd.conf.rpmnew
drwxr-xr-x 2 498 499 4096 Feb 11 15:40 zabbix_agentd.d
[root@10.0.3.122 ~]# ll /etc/zabbix/ -d
drwxr-x---. 5 498 499 4096 Feb 14 09:42 /etc/zabbix/
[root@10.0.3.122 ~]# chown zabbix:zabbix /etc/zabbix/ -R
[root@10.0.3.122 ~]# ll /etc/zabbix/ -d
drwxr-x---. 5 zabbix zabbix 4096 Feb 14 09:42 /etc/zabbix/
[root@10.0.3.122 ~]# ll /etc/zabbix/
total 32
drwxr-xr-x 2 zabbix zabbix 4096 Feb 11 15:40 plugins
drwxrwxr-x 2 zabbix zabbix 4096 Feb 1 11:00 plugins_conf
-rw-r--r-- 1 zabbix zabbix 5832 Nov 13 05:41 zabbix_agentd.conf
-rw-r--r-- 1 zabbix zabbix 10423 Jan 28 18:48 zabbix_agentd.conf.rpmnew
drwxr-xr-x 2 zabbix zabbix 4096 Feb 11 15:40 zabbix_agentd.d
[root@10.0.3.122 ~]# /etc/init.d/zabbix-agent restart
Shutting down Zabbix agent: [FAILED]
Starting Zabbix agent: [ OK ]
zabbix_agentd重装后启动时IPC和共享内存段问题的更多相关文章
- 进程间通信——IPC之共享内存
共享内存是三个IPC机制中的一个.它允许两个不相关的进程访问同一个逻辑内存.共享内存是在两个正在进行的进程之间传递数据的一种非常有效的方式. 大多数的共享内存的实现,都把由不同进程之间共享 ...
- Linux IPC之共享内存
System V共享内存机制: shmget shmat shmdt shmctl 原理及实现: system V IPC机制下的共享内存本质是一段特殊的内存区域,进程间需要共享的数据被放在该共 ...
- IPC进程间通信---共享内存
共享内存 共享内存:共享内存就是分配一块能被其它进程访问的内存.每个共享内存段在内核中维护着一个内部结构shmid_ds, 该结构定义在头文件linux/shm.h中,其结构如下: struct sh ...
- Linux IPC之共享内存C 事例
Linux IPC之共享内存 标签: linuxrandomnull工作 2011-08-25 11:52 4123人阅读 评论(0) 收藏 举报 分类: Linux(3) 读书札记(3) 版权 ...
- 【Linux 应用编程】进程管理 - 进程间通信IPC之共享内存 mmap
IPC(InterProcess Communication,进程间通信)是进程中的重要概念.Linux 进程之间常用的通信方式有: 文件:简单,低效,需要代码控制同步 管道:使用简单,默认阻塞 匿名 ...
- 进程间通信IPC之--共享内存
每个进程各自有不同的用户地址空间,任何一个进 程的全局变量在另一个进程中都看不到,所以进程之间要交换数据必须通过内核,在内核中开辟一块缓冲 区,进程1把数据从用户空间拷到内核缓冲区,进程2再从内核缓冲 ...
- 五十、进程间通信——System V IPC 之共享内存
50.1 共享内存 50.1.1 共享内存的概念 共享内存区域是被多个进程共享的一部分物理内存 多个进程都可把该共享内存映射到自己的虚拟内存空间.所有用户空间的进程若要操作共享内存,都要将其映射到自己 ...
- [20191220]关于共享内存段相关问题.txt
[20191220]关于共享内存段相关问题.txt --//我一直很好奇如果设置内核参数kernel.shmmax = 68719476736足够大,为什么我的测试实例还是建立3个共享内存段.--// ...
- 在Oracle 11g中用看Oracle的共享内存段---------IPCS
很早之前,在一次讲课了,用了命令ipcs,发现oracle的共享内段好小,如下: oracle@mydb ~]$ ipcs -a ------ Shared Memory Segments ----- ...
随机推荐
- 已知一个正整数m,编写一个程序求m的反序数(待消化)
import java.util.Scanner; /** * @author:(LiberHome) * @date:Created in 2019/3/5 21:08 * @description ...
- reference to 'map' is ambiguous|
reference to 'map' is ambiguous| c++编译出现此错误 表明定义的变量名字map和库函数map冲突而产生歧义
- css学习_css布局案例
1.中间栏先加载 !!!(若不是这个条件的话 ,那可以用 calc 或者flex布局来实现 中间栏自适应,左右栏定宽) 2.中间栏自适应 width:100% 3.左右栏固定宽 左中右 ...
- Web Api使用Swagger提供在线文档
1.添加Swashbuckle引用 2.生成XML文件 3.添加XML解析,在接口添加注释信息 4.运行项目输入地址 http://localhost:58254/swagger
- C# string contains 不区分大小写
一种方法是把字符串转成小写/大写,然后包含的字符串也写成小写 /大写 另一种方法是: 1 string title = "STRING"; 2 bool contains = ti ...
- windows slaver 脚本执行xcopy 报错无效驱动器规格
jenkins上配置的windows slaver机器如下: 我用这台windows 机器作为slaver机器来编译pc的exe包,但是在最后归档包倒ftp上时报错,如下: 但是我直接在windows ...
- 利用MathType为公式编号并引用
序言 在理工科的论文撰写过程中, 公式编辑.编号以及引用非常普遍, 但是笔者没有发现word本身对公式编号和引用有比较好的支持, 所以只好求助于第三方插件. MathType在公式编辑方面表现比较出色 ...
- python3.6安装docx模块
1.下载 python_docx-0.8.6-py2.py3-none-any.whl 地址: http://www.lfd.uci.edu/~gohlke/pythonlibs/2.在这个网页的最下 ...
- cygwin 安装 apt-cyg
apt-cyg apt-cyg is a Cygwin package manager. It includes a command-line installer for Cygwin which c ...
- 【ASP.NET Core】在CentOS上安装.NET Core运行时、部署到CentOS
第一步:Add the dotnet product feed sudo rpm --import https://packages.microsoft.com/keys/microsoft.asc ...