memcached-1.4.20 主要启动流程笔记
以下笔记主要是关注tcp模式下memcached的启动过程。
main()
设置信号处理函数为sig_handler()
初始化系统设置,保存在全局变量settings里面
settings_init();
解析启动参数,使用settings局变量保存配置
根据启动参数初始化系统具体使用的hash函数,默认为jenkins_hash()哈希函数
hash_init() ;
根据tcp_specified的值设置网络监听模式,默认为tcp模式
之后设置可使用的cpu核的数量以及最大链接数量
限制启动的权限,通常需要root权限启动应用
设置是否以守护进程方式启动
调用libevent库获得一个事件监听实例,libevent基本使用方法event_init() => evtimer_set() => event_add() =>event_dispatch()
event_init();
初始化系统全局状态信息变量
stats_init();
初始化哈希表,参数为哈希表buckets的级数,即buckets = ((unsigned long int)1<<(n))
assoc_init(int hashpower_init);
设置并初始化链接数组,用于保存每个链接的fd, 默认为最大fd不大于max_conn + 10
conn_init();
内存管理的初始化,参数为:总申请内存的大小,默认为64m, 块大小变化因子,是否预划分内存
factor的使用主要是在每一个内存page中划分chunck时使用,每个page最大为1m, 例如slab_class1每一个chunck 为80bytes, 则slab_class2每一 个chunck大小为80*factor
factor的值在1.4.20版本默认为1.25,chunck的默认最小为48byte
preallocate默认为false,若为true则系统默认将为每一种slab_class申请一个实例,但是有可能有些始终不会被用到,因此默认启动时为false
slabs_init(maxbytes, factor, preallocate);
启动并初始化worker线程
num_threads表示worker线程的数量,主线程负责接受并创建链接,而worker线程则负责链接命令的I/O操作
初始化各种多线程同步锁,创建主线程与worker线程通信的pipe通道,主要用于分配新链接,分配过程负载均衡使用round-robin轮询调度算法
使用pthread库创建线程并使用同步锁确保worker线程都启动完成才结束函数
thread_init(settings.num_threads, main_base);
启动哈希表的维护线程,主要负责哈希表的扩容
start_assoc_maintenance_thread();
根据启动参数决定是否启动内存模块的管理线程,主要是考虑数据存储的value值比较极端的情况,例如可能某一种chunck分配之后很久没有被访问,而其他经常被访问的则申请存储不成功,根据LRU算法策略可考虑将最近最少访问的内存块重新划分,slab_maintenance_thread主要做这些工作
if (settings.slab_reassign &&
start_slab_maintenance_thread() == -1)
init_lru_crawler();
启动定时器,用一个全局变量维持一个当前时间的记录,这样多线程都访问全局变量获得当前时间,减少获取时间系统调用
clock_handler();
启动socket监听
server_sockets();
启动事件循环监听
eventevent_base_loop();
memcached-1.4.20 主要启动流程笔记的更多相关文章
- 鸟哥的linux私房菜——第20章 启动流程、模块管理与loader
20.1 Linux启动流程分析 Linux启动过程: 按下开机电源后计算机硬件主动读取BIOS来加载硬件信息以及硬件系统的自我测试,之后系统会主动读取第一个可启动的设备(由BIOS设置),此时就可以 ...
- 别人的Linux私房菜(20)启动流程、模块管理与Loader
系统启动时,首先加载BIOS,通过BOIS读取COMS的硬件信息,进行自我检测,取得第一个可启动的设备(多个根据设置有关). 读取并执行设备内的MBR启动引导程序,引导程序调用boot sector中 ...
- 20、linux启动流程和救援模式
1.Linux启动流程 2.Linux运行级别 1.什么是运行级别,运行级别就是操作系统当前正在运行的功能级别 System V init运行级别 systemd目标名称 作用 0 runlevel0 ...
- [国嵌笔记][029][ARM处理器启动流程分析v2]
2440启动流程 启动方式:nor flash启动.nand flash启动 地址布局: 选择nor flash启动时,SROM(nor flash)地址为0x00000000 选择nand flas ...
- Tomcat8源码笔记(九)组件StandardContext启动流程--未完待续
StandardContext代表的是webapps下项目,一个项目就是一个StandardContext,作为Tomcat组件的一部分,就会实现Lifecycle接口,被Tomcat管理着生命周期, ...
- Vue笔记:webpack项目vue启动流程
VUE启动流程 1. package.json 在执行npm run dev的时候,会在当前目录中寻找 package.json 文件, 有点类似 Maven 的 pom.xml 文件,包含项目的名称 ...
- shell脚本编程学习笔记(二)linux服务器启动流程
一.linux服务器启动流程 1.bios找到磁盘上的mbr主引导扇区 2.进入grub洁面选择相应的启动内核 3.读取kernel内核文件-/boot/vmlinuz-* 4.读取init的镜像文件 ...
- linux启动流程梳理【转】
接触linux系统运维已经好几年了,常常被问到linux系统启动流程问题,刚好今天有空来梳理下这个过程:一般来说,所有的操作系统的启动流程基本就是: 总的来说,linux系统启动流程可以简单总结为以下 ...
- Linux操作系统-CentOS7启动流程和服务管理
Linux操作系统-CentOS7启动流程和服务管理 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.systemd POST --> Boot Sequence --&g ...
随机推荐
- 机器学习、深度学习以及人工智能正在快速演进(ML、DL、AI)
机器学习.深度学习以及人工智能正在快速演进 机器学习.深度学习和人工智能(ML.DL和AI)是彼此相关的概念,他们正在改变不知多少行业,改变其自身管理模式,同时改变做出决策的方式.显然,ML.DL和A ...
- thinkphp相关
thinkphp相关1.thinkphp调试sql方法:echo M("table_name")->getLastSql(); 2. 条件查询设置多个条件参数的写法:(1). ...
- JCTools, 场景特化的并发工具
同上一篇一样,在jmap -histo中发现MpscChunkedArrayQueue类的实例比较多,javadoc看了下,其原来是出自JC Tools,https://github.com/JCTo ...
- 20145206邹京儒 EXP7网络欺诈技术防范
20145206邹京儒 EXP7网络欺诈技术防范 一.实践过程记录 URL攻击实验前准备 1.在终端中输入命令:netstat -tupln |grep 80,查看80端口是否被占用,如下图所示 2. ...
- 20145317彭垚《网络对抗》Exp2 后门原理与实践
20145317彭垚<网络对抗>Exp2 后门原理与实践 基础问题回答 例举你能想到的一个后门进入到你系统中的可能方式? 在网上下载软件的时候,后门很有可能被捆绑在下载的软件当中: 例举你 ...
- SRLTE,SGLTE,SVLTE,CSFB,VoLTE的区别【转】
本文转载自:https://blog.csdn.net/dangbochang/article/details/43851979 SRLTE——Single Radio LTE,俗称单待LTE. SG ...
- win10 字体渲染优化 色彩调整
最近烧包买了个2k显示器,发现跟win10使用,一堆问题,最大的就是字体,其实应该买4k,那样正好设置200%字体,现在设置的124% 字体: 以前使用的是mactype这个软件 https://pa ...
- Wireshark 捕捉本地数据 --WinPcap切换NPcap
Wireshark默认匹配安装的是WinPcap,但是WinPcap有个缺点,不能抓取本地回环数据 NPcap是在WinPcap的基础上进行优化开发的,可以抓取本地数据 如果已安装WinPcap的请卸 ...
- 论文笔记——MobileNets(Efficient Convolutional Neural Networks for Mobile Vision Applications)
论文地址:MobileNets: Efficient Convolutional Neural Networks for Mobile Vision Applications MobileNet由Go ...
- POJ 2728 Desert King(最优比率生成树 01分数规划)
http://poj.org/problem?id=2728 题意: 在这么一个图中求一棵生成树,这棵树的单位长度的花费最小是多少? 思路: 最优比率生成树,也就是01分数规划,二分答案即可,题目很简 ...