Oracle Study之--IPCS管理共享内存
发表于:2025-02-03 作者:千家信息网编辑
千家信息网最后更新 2025年02月03日,Oracle Study之--IPCS管理共享内存Unix/linux下的共享内存、信号量、队列信息管理在unix/linux下,经常有因为共享内存、信号量,队列等共享信息没有干净地清除而引起一些问题
千家信息网最后更新 2025年02月03日Oracle Study之--IPCS管理共享内存
Oracle Study之--IPCS管理共享内存
Unix/linux下的共享内存、信号量、队列信息管理
在unix/linux下,经常有因为共享内存、信号量,队列等共享信息没有干净地清除而引起一些问题。
查看共享信息的内存的命令是:ipcs [-m|-s|-q]。
默认会列出共享内存、信号量,队列信息
-m列出共享内存
-s列出共享信号量
-q列出共享队列
清除命令是:ipcrm [-m|-s|-q] id。
-m 删除共享内存
-s删除共享信号量
-q删除共享队列。
案例分析:
[oracle@trade_as02 ~]$ ipcs -a------ Shared Memory Segments --------key shmid owner perms bytes nattch status 0x30024289 32768 futures 777 528384 1 0xca2fd414 491521 oracle 640 1730150400 16 ------ Semaphore Arrays --------key semid owner perms nsems 0x00028009 0 futures 666 1 0x0002800c 32769 futures 666 1 0x30024003 262146 futures 777 3 0x3002428a 294915 futures 777 2 0x3002428b 327684 futures 777 2 0x3002428c 360453 futures 777 2 0x3002428d 393222 futures 777 2 0x3002428e 425991 futures 777 2 0x52dff7d0 3964936 oracle 640 151 0x52dff7d1 3997705 oracle 640 151 0x52dff7d2 4030474 oracle 640 151 0x52dff7d3 4063243 oracle 640 151 0x52dff7d4 4096012 oracle 640 151 ------ Message Queues --------key msqid owner perms used-bytes messages
共享内存段有时不能马上删除,需使用这个内存段的所有进程向OS发送detach命令时才有释放,此时可以考虑删除进程使用的信号量,帮助释放共享内存段
相关知识:信号量、资源释放、ipcs、ipcrm
信号量又称为信号灯,它是用来协调不同进程间的数据对象的,而最主要的应用是共享内存方式的进程间通信。本质上,信号量是一个计数器,它用来记录对某个资源(如共享内存)的存取状况;共享内存是运行在同一台机器上的进程间通信最快的方式,因为数据不需要在不同的进程间复制。通常由一个进程创建一块共享内存区,其余进程对这块内存区进行读写。在Linux系统下 ,常用的方式是通过shmXXX函数族来实现利用共享内存进行存储的。如Shmget,类似于 malloc函数
ipcs可用来显示当前Linux系统中的共享内存段、信号量集、消息队列等的使用情况。
命令示例:ipcs -a或ipc 显示当前系统中共享内存段、信号量集、消息队列的使用情况;ipcs -m 显示共享内存段的使用情况;ipcs -s 显示信号量集的使用情况;ipcs -q 显示消息队列的使用情况;
ipcrm可用来删除对应的共享内存段、信号量、消息队列;
命令示例:ipcrm -s semid 删除对应的信号量集ipcrm -m shmid 删除对应的共享内存段ipcrm -q msqid 删除对应的消息队列ipcrm本身只能实现单个资源的删除,利用以下命令可实现批量删除:1.ipcs -s|grep 用户名|cut -d" " -f2|xargs -n1 ipcrm -s2.ipcs -s|awk '/用户名/{print $2}'|xargs -n1 ipcrm -s3.ipcs -s|awk '/用户名/{system("ipcrm -s "$2)}'4.for i in echo `ipcs|grep 用户名|cut -d" " -f2`; do ipcrm -s $i; done
更深入的了解:
Oracle 内存段参数设定:[root@rh7 ~]# sysctl -pnet.ipv4.ip_forward = 0net.ipv4.conf.default.rp_filter = 1net.ipv4.conf.default.accept_source_route = 0kernel.sysrq = 0kernel.core_uses_pid = 1net.ipv4.tcp_syncookies = 1error: "net.bridge.bridge-nf-call-ip6tables" is an unknown keyerror: "net.bridge.bridge-nf-call-iptables" is an unknown keyerror: "net.bridge.bridge-nf-call-arptables" is an unknown keyfs.aio-max-nr = 1048576fs.file-max = 6815744kernel.shmall = 2097152kernel.shmmax = 536870912kernel.shmmni = 4096kernel.sem = 250 32000 100 128net.ipv4.ip_local_port_range = 9000 65500net.core.rmem_default = 262144net.core.rmem_max = 4194304net.core.wmem_default = 262144net.core.wmem_max = 1048586
内存
信号
信号量
队列
进程
命令
情况
消息
信息
用户
用户名
方式
系统
资源
管理
不同
函数
数据
示例
通信
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
宁畅服务器技术白皮书
数据库唯一值定义
网络安全应急处置的主要内容
数据库packages
服务器连接配置异常什么意思
金蝶与服务器失去联系
厦门国际银行软件开发经理
上海昌亿网络技术有限公司
宁波迅游游戏软件开发
2016网络安全大赛
河北工业软件开发收费报价表
snd下一代网络技术
云服务器IP地址怎么固定12位
软件开发管理相关软件
车联网和网络安全
excl怎么复制公式数据库
网络安全兆日科技
高并发数据库分离
华为历年研发费用数据库
提升数据库性能的软件
数据库18482错误处理
喜马拉雅服务器升级
web网络安全服务社团
服务器被黑龙攻击
中外文数据库
pc2服务器
残疾人自学网络技术
株洲互联网科技公司
安卓应用软件开发区网红
软件开发 长期服务