非阻塞IO
系统调用分为两类,“低速”系统调用和其他。
“低速”系统调用指的是可能会使进程永远阻塞的一类系统调用。
非阻塞I/O则指的是当进行诸如open, read, write
等I/O操作时,这些操作不会永远阻塞。如果操作不能完成,则调用立即出错返回,以表示继续该操作将会阻塞。
一般非阻塞I/O需要不断轮询判断是否有数据要进行读写,这种情况是比较浪费CPU时间的。避免非阻塞I/O的两种方式:I/O多路转接或多线程采用阻塞I/O。
专注于工业物联网行业数据采集,嵌入式Linux系统裁剪,5G智慧网关软件开发等
系统调用分为两类,“低速”系统调用和其他。
“低速”系统调用指的是可能会使进程永远阻塞的一类系统调用。
非阻塞I/O则指的是当进行诸如open, read, write
等I/O操作时,这些操作不会永远阻塞。如果操作不能完成,则调用立即出错返回,以表示继续该操作将会阻塞。
一般非阻塞I/O需要不断轮询判断是否有数据要进行读写,这种情况是比较浪费CPU时间的。避免非阻塞I/O的两种方式:I/O多路转接或多线程采用阻塞I/O。
本文使用OpenSSL工具生成国密算法SM2的三级CA证书,组成证书链,并使用证书链签名客户端证书和服务端证书。
可以通过证书链对生成的客户端和服务端证书进行校验。
虽然OpenSSL工具可以使用SM2算法来生成并校验证书,但是在TLS握手过程中主要支持RSA和ECC算法作为公钥加密算法,不支持SM2算法,因此无法在TLS加密连接中使用SM2证书。
SSL/TLS协议主要使用RSA和ECC(椭圆曲线密码学)算法作为公钥加密算法,而SM2算法属于ECC算法的一种。RFC8898
守护进程是生存期长的一种进程,在系统引导装入时启动,在系统关闭时终止。
守护进程没有控制终端,通常在后台运行,实际上是在后台的孤儿进程组中运行。
没有控制终端的原因在于不与用户交互,避免终端信号影响。
在孤儿进程组中运行的原因在于防止其获取控制终端(通过每次打开终端设备设置参数O_NOCTTY
的方式不太靠谱)。
多线程环境下,调用fork
函数创建子进程时,子进程完全继承了父进程的整个内存地址空间。
父进程中的互斥锁、多个线程在子进程中是如何处理的呢?
由于父子进程之间采用了写时复制技术,在子进程未改变互斥锁之前,父子进程对锁的状态是相同的,此时如何处理同步状态?
多线程环境下需要使用互斥量等数据来进行线程间数据同步,然而同时使用同步对象与信号处理很容易造成死锁,本文探索如何在多线程环境下来进行信号处理。
在多线程环境中,为了防止信号中断线程,通常把信号加到每个线程的信号屏蔽字中。然后安排专用线程来处理信号。
codebrowser能够对源码生成静态HTML网页,搭配nginx可以在WEB上浏览源码。
支持功能如下:
本文通过使用NFS Server工具在WIN11上搭建NMS Server,打通Linux开发环境到嵌入式板子之间的通路,优化Linux服务器与嵌入式板子之间的多次SCP拷贝操作。
Windows下的NFS Server工具来自于Networking Software for Windows (hanewin.net)
线程特定数据(thread-specific data),也称为线程私有数据(thread-private data),是线程单独的数据副本,存储在线程的私有存储空间,不与进程中其他线程共享。
线程键(pthread_key_t
),每个线程用其与自身特定数据地址进行关联。
析构函数用于线程退出时调用。通常使用malloc
为线程特定数据分配内存,析构函数通常用于释放已分配的内存。
可重入等价于异步信号安全。
线程安全与可重入以及异步信号安全没有必然联系。
屏障的作用是允许每个线程完成自身任务之后等待,直到所有线程都达到某一点,然后从该点继续执行。
默认情况下屏障应用于单个进程的多个线程之间。
屏障的进程共享属性允许将屏障应用于多个进程之间,前提是多个进程能够访问到同一个屏障对象。