千里之行,始于足下
作为模块化比较明显的开源软件,根据初始化过程可以很清晰的区别其结构。
模块初始化概况

详细参数探究
下面我们就默认配置以及传参配置两个方面进行总结:
默认配置
|
|
传入参数含义
A是否运行客户端使用 shutdown 命令,默认是不允许的,该选项将允许客户端的 shutdown 命令将 memcached 进程杀死。该选项会将settings.shutdown_command赋值为falsea:unix socket 的权限位信息(访问掩码)。该选项的参数赋值给settings.accessU:大写U,memcached 监听的 UDP 端口值,默认端口为 0。该选项的参数赋值给settings.udpportp:小写p,memcached 监听的 TCP 端口,默认端口为 11211。该选项的参数赋值给settings.ports:小写S,unix socket 监听的 socket 路径。该选项的参数赋值给settings.socketpathm:小写m,memcached 能够使用的最大内存值,默认是64MB,参数单位为MB。该参数赋值给settings.maxbytesM大写M,默认情况下,当 memcached 的内存使用完后,将进行 LRU机制 淘汰 item 以腾出空间,如果使用本选项那么将关闭 LRU 功能,当然关闭 LRU 不代表不能存储新数据,如果 memcached 里面存有过期失效的 item,那么就可以存储新数据,否则将无法存储。该选项将settings.evict_to_free赋值为0。c:小写c,最多允许多少个客户端同时在线(这个值不等价于 listen 函数的第二个参数),该选项和后面的 b选项 有所不同,默认值为 1024 个。该选项参数赋值给settings.maxconnsh显示帮助信息i显示 memcached 和 libevent 的版权信息k小写k,将 memcached 使用到的内存锁定在内存中,不准 OS 把 memcached 的内存移动到虚拟内存,因为当 OS 把memcached 的内存移动到虚拟内存可能会导致页错误,降低 memcached 的响应时间v小写v,输出 memcached 运行时的一些信息。-v -vv -vvv输出的信息依次增加。该选项会增加settings.verbose的值l:小写L,memcached 绑定的 ip 地址,如果不设置这个选项,那么memcached将使用INADDR_ANY,如果想指定多个IP地址,那么该选项的参数可以由多个ip组成,ip之间用逗号分隔,也可以多次使用这个选项,此时端口应该尾随ip而不是单独用 -p选项 指定。例如-l 127.0.0.1:8888,192.168.1.112:9999或者-l 127.0.0.1:8888 -l 192.168.1.112:9999该选项参数将赋值给settings.interd以守护进程的形式运行 memcachedr将 core 文件大小设置为不受限制R:worker 线程连续为某个客户端执行命令的最大命令数。该选项的参数赋值给settings.reqs_per_eventu:小写u,当以root用户启动 memcached 的时候需要指定memcached的所属用户,其他用户启动 memcached 不需要此选项P:大写p,该选项的参数指明 memcached 的pid保存文件。要和 -d选项 配合使用,注意运行的用户是否有权限写对应的文件f:item的扩容因子,默认值为1.25。该选项的参数值可以是小数但必须大于 1.0。该选项参数将赋值给settings.factorn:设置最小的 item 能存储多少字节的数据。该选项参数赋值给settings.chunk_sizet:该选项的参数用于指定 worker 线程的个数,不建议超过 64个,如果不设置该选项默认有4个线程。该参数会赋值给settings.num_threadsD:参数字符作为前缀和 ID 的分隔符,使用了该选项才会自动收集状态信息,也可以在启动memcached后,客户端使用stats detail on命令开启,此时默认的分隔符为冒号":"。该选项参数会赋值为settings.prefix_delimiter,并将settings.detail_enabled 赋值为 1L如果OS允许的话,那么向OS申请更大的内存页,OS的默认内存页为4KB,大的内存页可以有效降低页表的大小,提高效率,此选项会使得 memcached 预先先 OS 全部所需的申请内存,当然这些内存尽量是用大内存页分配的C:大写C,memcached 默认是使用 CAS 的,本选项是禁用 CAS。本选项会将settings.use_cas 赋值为falseb:listen 函数的第二个参数,该选项的参数赋值给settings.backlog。如果不设置该选项,那么默认为 1024。该选项和前面的 c选项 有所不同B:memcached 支持文本协议和二进制协议。该选项的参数用于指定使用的协议,默认情况下是根据客户端的命令而自动判断(也叫协商),参数只能取auto、binary、ascii这三个字符串值。将参数将赋值给settings.binding_protocolI:大写i,slab 分配器中每一个页的大小,这个选项的参数是一个数值表示页的大小,默认单位是 B 也可以在数值后面带 K或者 M(大小写都行),表示 KB 和 MB,页的大小 小于 1KB 或者 大于 128MB 都是不允许的。不推荐使用该选项,本选项参数会赋值给settings.item_size_maxS大写S,打开 sasl 安全协议。会将settings.sasl 赋值为 trueF禁止客户端的 flush_all命令。默认是允许客户端的 flush_all 命令的。该选项将settings.flush_enabled 赋值为 falseo:小写o,有下面几个子选项可以设置,这个选项是用来优化的maxconns_fast如果连接数超过了最大同时在线数(=(由 -c选项 指定),立即关闭新连接上的客户端。该选项将settings.maxconns_fast 赋值为truehashpower哈希表的长度是2^n。可以通过选项hashpower设置指数 n 的初始值。如果不设置将取默认值 16。该选项必须有参数,参数取值范围只能为[12, 64]。本选项参数值赋值给settings.hashpower_initslab_reassign该选项没有参数,用于调节不同类型的 item 所占的内存,不同类型是指大小不同,某一类 item 已经很少使用了,但仍占用着内存。可以通过开启slab_reassign调度内存,减少这一类 item 的内存。如果使用了本选项,settings.slab_reassign 赋值为 trueslab_automove依赖于slab_reassign,用于主动检测是否需要进行内存调度。该选项的参数是可选的,参数的取值范围只能为0、1、2,参数 2 是不建议的。本选项参数赋值给settings.slab_automove。如果本选项没有参数,那么settings.slab_automove 赋值为 1hash_algorithm用于指定哈希算法,该选项必须带有参数。并且参数只能是字符串jenkins或者murmur3tail_repair_time用于检测是否有item被已死线程所引用,一般不会出现这种情况,所以默认不开启这种检测。如果需要开启这种检测,那么需要使用本选项,本选项需要一个参数,参数值必须不小于10。该参数赋值给settings.tail_repair_timelru_crawler本选项用于启动 LRU 爬虫线程。该选项不需要参数,会导致settings.lru_crawler 赋值为 truelru_crawler_sleepLRU爬虫线程工作时的休眠间隔,本选项需要一个参数作为休眠时间,单位为微秒,取值范围是[0, 1000000]。该参数赋值给settings.lru_crawler_sleeplru_crawler_tocrawlLRU爬虫检查每条LRU队列中的多少个 item。该选项带有一个参数,参数会赋值给settings.lru_crawler_tocrawl
本文作者: wettper
本文链接: http://www.web-lovers.com/memcached-source-params-init.html
版权声明: 本博客所有文章除特别声明外,均采用 CC BY-NC-SA 3.0 许可协议。转载请注明出处!