“进程球”通过数据库来通信------好美的一幅图!

2024-02-06 14:32

本文主要是介绍“进程球”通过数据库来通信------好美的一幅图!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

       拿着一支笔, 随便画画, 然后在纸上画了三个球, 哦, 这不就是一个个的进程么? 本来想上传亲笔画的图, 但晚上拍照效果不太好, 所以还是用鼠标来画吧。  先睹为快偷笑

 

         

         图还是挺好看的大笑

 

         下面, 我们来闲聊一下这幅图的一些东东。

 

         什么是进程呢? 笔试面试总会被问到这个讨厌的问题, 要我说, 进程就是个球啊, 看看上面的图, 难道不是么? 对, 进程就是个球。   那一年, 我还不太懂什么是进程通信, 但我居然不知不觉地用文件实现了两个进程的通信(非常粗糙的通信模式), 并解决了当时的重要问题。

 

         说到利用文件实现进程通信, 肯定会被很多人鄙视, 但无疑, 这种思路是很好的, 只是, 要注意线程同步、进程同步等, 但在实际项目中, 几乎没有这种用法。 既然利用文件实现进程间的通信很粗糙, 那利用数据库呢(图中test.db数据库的本质就是一个文件)? 也可以考虑。 实际上, 很多数据库自身已经考虑了线程同步和进程同步问题, 所以, 不用太担心多个进程间的写冲突问题。 经常会遇到这种情况:很多进程需要读写某一字段, 而这一字段经常放在数据库中。 显然,可以考虑数据库, 实际上, 很多重要的字段就是放在数据库中的, 很多场景, 很多人就是这么搞的。

 

        好, 既然进程是个球, 也说了数据库帮助进程球进行了通信, 那我们要说一下内存数据库了, 所谓内存数据库, 我理解(非官方定义), 实际上就是内存中的一种数据结构, 与数据库test.db(外存数据库)形成映射, 你要知道的是, 内存数据库中的值与外存数据库test.db的值总是一致的(需要有机制保证才行)。 看到没, 图中那个蓝色的圈圈就是内存数据库(数据结构), 像一张网一样, 网住多少岁月, 网住多少年华。

 

        我们先说说引入内存数据库的好处:

 

       1. 写的时候, 如果待写的字段值与外存数据库test.db中的字段值相同, 则直接在内存中就判断了, 实际并未与外存数据库test.db打交道。 效率高。

       2. 读的时候, 根本不需要从外存数据库test.db中读取, 直接读取内存数据库的值即可, 因为内存数据库和外存数据库有等价映射关系啊。效率高。

       现在假设外存数据库test.db中user字段的值是taoge, 那么进程1, 2, 3中内存数据库的值都是taoge. 我们以进程1为例, 现在进程1要把变量user的值变为meinv, 那是怎样的一个过程呢? 首先, 进程1用mvi和taoge进程对比, 发现这两个串不一致(如果一致, 则没有后续的过程, 自然提高了效率), 于是将进程1的内存数据库中user的值更改为meinv, 然后把meinv写到数据库test.db中。

      别忘了, 我们说过, 内存数据库里面的值要和外存数据库test.db里面的值一致, 现在进程1满足条件了, 但是进程2和进程3不满足条件啊, 所以这个时候, 会通过8和12这两条线来更新进程2和进程3中的内存数据库(需要有机制保证才行), 将内存数据库中user的值更新为meinv。 此时, 如果进程2和进程3如果想读取user的值, 那也可以,直接从内存数据库读取, 值是meinv, 在读取过程中, 并没有和外存数据库test.db打交道, 这样效率就高了。

       

       ok, 应该大致说清楚了, 内存数据库颇有点网的感觉, 也有点缓冲的感觉。

       最后, 我要说, 我挺喜欢这个图的大笑

 

       睡觉, 明天周六, 睡到自然醒。

 

 

 

 

 

 

 

 

这篇关于“进程球”通过数据库来通信------好美的一幅图!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/684603

相关文章

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

SQL Server数据库死锁处理超详细攻略

《SQLServer数据库死锁处理超详细攻略》SQLServer作为主流数据库管理系统,在高并发场景下可能面临死锁问题,影响系统性能和稳定性,这篇文章主要给大家介绍了关于SQLServer数据库死... 目录一、引言二、查询 Sqlserver 中造成死锁的 SPID三、用内置函数查询执行信息1. sp_w

Windows的CMD窗口如何查看并杀死nginx进程

《Windows的CMD窗口如何查看并杀死nginx进程》:本文主要介绍Windows的CMD窗口如何查看并杀死nginx进程问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录Windows的CMD窗口查看并杀死nginx进程开启nginx查看nginx进程停止nginx服务

Java进程CPU使用率过高排查步骤详细讲解

《Java进程CPU使用率过高排查步骤详细讲解》:本文主要介绍Java进程CPU使用率过高排查的相关资料,针对Java进程CPU使用率高的问题,我们可以遵循以下步骤进行排查和优化,文中通过代码介绍... 目录前言一、初步定位问题1.1 确认进程状态1.2 确定Java进程ID1.3 快速生成线程堆栈二、分析

RabbitMQ工作模式中的RPC通信模式详解

《RabbitMQ工作模式中的RPC通信模式详解》在RabbitMQ中,RPC模式通过消息队列实现远程调用功能,这篇文章给大家介绍RabbitMQ工作模式之RPC通信模式,感兴趣的朋友一起看看吧... 目录RPC通信模式概述工作流程代码案例引入依赖常量类编写客户端代码编写服务端代码RPC通信模式概述在R

在Spring Boot中实现HTTPS加密通信及常见问题排查

《在SpringBoot中实现HTTPS加密通信及常见问题排查》HTTPS是HTTP的安全版本,通过SSL/TLS协议为通讯提供加密、身份验证和数据完整性保护,下面通过本文给大家介绍在SpringB... 目录一、HTTPS核心原理1.加密流程概述2.加密技术组合二、证书体系详解1、证书类型对比2. 证书获

Druid连接池实现自定义数据库密码加解密功能

《Druid连接池实现自定义数据库密码加解密功能》在现代应用开发中,数据安全是至关重要的,本文将介绍如何在​​Druid​​连接池中实现自定义的数据库密码加解密功能,有需要的小伙伴可以参考一下... 目录1. 环境准备2. 密码加密算法的选择3. 自定义 ​​DruidDataSource​​ 的密码解密3

Maven项目中集成数据库文档生成工具的操作步骤

《Maven项目中集成数据库文档生成工具的操作步骤》在Maven项目中,可以通过集成数据库文档生成工具来自动生成数据库文档,本文为大家整理了使用screw-maven-plugin(推荐)的完... 目录1. 添加插件配置到 pom.XML2. 配置数据库信息3. 执行生成命令4. 高级配置选项5. 注意事

在Java中基于Geotools对PostGIS数据库的空间查询实践教程

《在Java中基于Geotools对PostGIS数据库的空间查询实践教程》本文将深入探讨这一实践,从连接配置到复杂空间查询操作,包括点查询、区域范围查询以及空间关系判断等,全方位展示如何在Java环... 目录前言一、相关技术背景介绍1、评价对象AOI2、数据处理流程二、对AOI空间范围查询实践1、空间查

Python+PyQt5实现MySQL数据库备份神器

《Python+PyQt5实现MySQL数据库备份神器》在数据库管理工作中,定期备份是确保数据安全的重要措施,本文将介绍如何使用Python+PyQt5开发一个高颜值,多功能的MySQL数据库备份工具... 目录概述功能特性核心功能矩阵特色功能界面展示主界面设计动态效果演示使用教程环境准备操作流程代码深度解