案例1通过文件描述符控制并发数#用fifo处理shell下多进程并发:#!/bin/bash#author:vaedit#date:2017-8-15#需要执行的工作函数functionmima(){opensslrand-base6440>>ssf.txt}#判断是否存在fifo文件if[-e/tmp/$$.fifo];thenrm-rf/tmp/$$.fifofi#创建$$.fif
分类:
系统相关 时间:
2020-08-13 11:55:19
阅读次数:
82
最近看到一个前辈留下的shell,发现竟然是shell多线程,便研究了下。也许你会有疑问,Shell这么简单的脚本语言有多线程这一说吗?答案是有的。只不过它实现起来稍微有点难理解罢了,因为它借助了命名管道实现。所谓多线程就是原本由一个进程完成的事情现在由多个线程去完成。假如一个进程需要10小时完成的事情,现在分配10个线程,给他们分工,然后同时去做这件事情,最终可能就需要1小时。文件描述符:文件描
分类:
编程语言 时间:
2020-08-04 18:23:58
阅读次数:
101
一:date输出的结果,在下一次开机查看:date>date.txtFD简介:filedescriptors,FD,文件描述符,进程使用文件描述符来管理打开的文件FD是访问文件的标识,即链接文件,0是键盘只读,1,2是终端可以理解是屏幕,3+是文件,可读可写通过我们非常熟悉的VIM程序。来观察一个进程的FD信息。1.通过一个终端,打开一个文本。vim2.txt2.通过另一个终端,查询文本程序
分类:
系统相关 时间:
2020-07-31 10:22:28
阅读次数:
113
UDP 通信 UDP通信的优点 UDP无连接通信 可以探测附近的设备 减轻服务端的压力 UDP步骤 服务端 定义一个套接字s 定义文件描述符 定义缓冲字符串 申请一个套接字作用在文件描述符上 参数一:协议 → IPv4/IPv6 PF_INET/PF_INET6 参数二:套接字类型 → UDP无连接 ...
分类:
其他好文 时间:
2020-07-26 15:35:34
阅读次数:
82
efk就是目前比较受欢迎的日志管理系统。kubernetes可以实现efk的快速部署和使用,通过statefulset控制器部署elasticsearch组件,用来存储日志数据, 还可通过volumenclaimtemplate动态生成pv实现es数据的持久化。通过deployment部署kiban ...
分类:
其他好文 时间:
2020-07-19 23:41:50
阅读次数:
166
一、多线程简介1、什么是线程? 线程在操作系统原理中是这样描述的:线程是进程的一条执行路径。线程在Unix系统下,通常被称为轻量级的进程,线程虽然不是进程,但却可以看作是Unix进程的表亲,所有的线程都是在同一进程空间运行,这也意味着多条线程将共享该进程中的全部系统资源,如虚拟地址空间,文件描述符和 ...
分类:
编程语言 时间:
2020-07-13 22:00:56
阅读次数:
83
单进程 单进程模型来处理客户的请求。对读写事件的响应是通过epoll函数包装来做到的。redis的处理速度是完全依靠主进程的执行效率。 Epoll是LINUX内核为处理大批量文件描述符该做了改进的epoll,是Linux下多路复用select/poll的增强版本 它能显著提供在程序在大量并发连接中只 ...
分类:
其他好文 时间:
2020-07-13 11:55:24
阅读次数:
72
引言 最近自己在学习go项目的时候,查看别人的源码经常发现defer的使用,加上自己之前对这个关键字没怎么在意,只知道差不多是用来释放内部变量的。 查看资料可以发现,defer会在当前函数或者方法返回之前执行传入的函数,经常用于关闭文件描述符、关闭数据库连接以及解锁资源。 为了能够更形象地理解def ...
分类:
其他好文 时间:
2020-07-12 18:26:31
阅读次数:
71
##什么是IO 在Linux世界里,一切皆文件。文件就是一串二进制流,不管是socket、FIFO、管道还是终端,对我们来说一切都是文件,一切都是流。在信息交换的过程中,我们都是对这些流进行数据的收发操作,简称为I/O操作(Input and Output)。 计算机里的所有流都是通过文件描述符(F ...
分类:
其他好文 时间:
2020-07-12 14:42:06
阅读次数:
74