介绍:

yconsole是yhd用于管理缓存的工具(python实现),它的主要功能是为各个应用分配和管理缓存,以及错误修复。和它配合使用的还有ycache-client、yagent、zookeeper。参见:ycache分布式缓存框架

当应用需要缓存时,仅需要说需要多少空间的缓存,然后yconsole会从缓存系统中按照一定策略分配缓存空间给这个应用。这个缓存空间用一个"cache-id"表示,应用仅需要在ycache-client中配置这个cacheid,就能使用这些缓存。应用不需要知道缓存在哪里,ip是什么,它只知道自己拥有这么多的缓存空间并总是能使用的。

依赖:主要是zk的client:kazoo



import os, sys, subprocess,time
import threading
from kazoo.client import KazooClient
from kazoo.exceptions import *
 
定制参数:

#指定是memcached或者redis,同时也是zk上的对应的目录名称。
YCONSOLED_MODE           = "ycache"     #It should be "redis" for redis, while "ycache" for memcached. 
#对外显示的程序名字,没什么用。
YCONSOLED_NAME           = "yconsole"  #Program name for log.
#操作缓存的粒度(或者说单位)。也就是在命令行指定1,对应的缓存大小。
CACHE_GRANULAR           = 1024  #defautl granularity for cache size (to Mb).
#是否允许指定已经被其他cacheid分配的实例,然后将其分配给另一个cachid;
ALLOW_USE_ASSIGNED       = False       #Whether allow to assigned an instance to different cache id when the instance is specified by command. 
是否允许使用状态为deactive的实例
ALLOW_USE_DEACTIVE       = False       #Whether allow to assigned a deactive instance  when the instance is specified by command. 
是否打印颜色。不支持打印颜色的可以设置为fasle,否则会有乱码。颜色就是特殊字符。
PRINT_PRETTY             = True        #Print with color.
 
#默认的读取配置中心的url。仅用于读取zk的地址。读取优先级为:
  #1 当前目录的yconsole.conf配置文件(例如:zoo_svr=127.0.0.1:2181)
  #2 这个路径配置文件:/etc/ycache/yagent/yagent.conf
  #3 到下面的配置文件找配置中心的zk服务器。
DEFAULT_ENV_INI_FILE     = "/var/www/config/env.ini"   #for getting zk server address.
#重试次数,基本上没用
OPERATION_RETRY          = 3
 
配置说明:

  yconsole [ ls    | list-cacheid   ]

# 显示所有的cacheid对应的cache实例,以及实际占用的cache总空间,以及当前可用空间。如果有任何一个实例为deactive,则高亮;如果所有实例都deactive,则标红加粗;
 

 
   yconsole [ lspc  | list-machine   ]

# 显示所有的server的状态、信息、对应的cache实例,以及每个实例对应的cacheid。

   yconsole [ lsser | list-server    ]

# 显示所有的server的状态、信息(包括实例总数,yagent版本,cache版本,cache实例大小,分组,优先级,服务器位置),如果这个server为down,则标红加粗。
 
 
  yconsole [ rmid  | remove-cacheid ] cacheid

参数:

  cacheid: string, 要删除的cacheid

#删除一个cachid。其实就是把zk上对应的节点删除。

   yconsole [ rmser | remove-server  ] ServerIP

参数:

ServerIP   : string, 要删除的服务器ip

#删除一台服务器。

其实就是把zk上对应的节点删除。注意:只有在这台服务器上的实例没有被使用,才能被删除;


   yconsole [ add   | add-cacheid    ] cacheid size(int,Gb) [min(0) max(4) [group(default) [priority(100) ] ] ]

#添加一个cacheid。
参数:

cacheid : string,cacheid的名字,应该以pool名字为前缀,方便管理;

   size: int,指定要分配cache的大小(以CACHE_GRANULAR为单位)  
   min(0) max(4):指定要分配的单个cache实例大小的范围。默认为[0,4]
   group(default):指定要从那个分组的服务器分配cache实例,默认是default分组
   priority(100) :指定要从大于某个优先级的服务器上分配实例,默认是100.
 
如果存在很多满足上面参数要求的实例,在选择每一个实例时,则按照以下偏好分配:
分配优先级:
   Cache instances are assigned bias on a cache server as following:
     1. Least number of instance have been assigned; or   优先这个cachid使用最少cache实例的服务器的实例;否则
     2. Largest priority; or  优先使用优先级高的服务器的实例;否则
     3. Largest number of available instance  优先使用可用实例最多的实例; 否则
     4. Largest cache size 优先使用cache空间大的实例;否则
     5. use the cache with smaller ip address.   使用ip地址小的cache实例

   yconsole [ mod   | mod-cacheid    ] cacheid instance1,instance2...

#修改一个cacheid对应的cache实例
参数:

  cacheid: string, 要删除的cacheid
  cacheid instance1,instance2... :string, 新的cache实例,例如192.1.1.1:8888,192.2.2.2:9999

   yconsole [ app   | append-cacheid ] cacheid {instance1,...| size(int, Gb)} [min(0) max(4) [group(default) [priority(100) ] ] ] 

   #向一个cacheid添加cache实例。

参数:
   cacheid : string,cacheid的名字,应该以pool名字为前缀,方便管理;
   size: int,指定要分配cache的大小(以CACHE_GRANULAR为单位)  
   cacheid instance1,instance2... :string, 新的cache实例,例如192.1.1.1:8888,192.2.2.2:9999   
   min(0) max(4):指定要分配的单个cache实例大小的范围。默认为[0,4]
   group(default):指定要从那个分组的服务器分配cache实例,默认是default分组
   priority(100) :指定要从大于某个优先级的服务器上分配实例,默认是100.


    yconsole [ cop   | copy-cacheid   ] fCacheid toCacheid...

#用一个旧的cacheid对应的内容创建一个新的cacheid
参数:

fCacheid    : string, 源cacheid

   toCacheid    : string, 新cacheid   

   yconsole [ fix   | fix-cacheid    ] [Cacheid | all] [fix-size(int, Gb,0)]

#快速修复命令。检测一个(或所有)cacheid是否至少存在一个活跃的实例,如果没有,就分配fix-size大小的空间给它;如果一个cacheid仅有一个实例,则高亮这个cacheid
参数: 
    Cacheid | all: string,指定cacheid,当为all时,代表所有cacheid。
    fix-size(int, Gb,0): int,指定分配多少可用空间给那些有故障的cacheid。当为0时,只检测状态,不分配空间。

 
yconsole [ test  | test-cacheid   ] [Cacheid | all] [set-delay(int,ms,10),get-delay(int,ms,10)]

参数: 
    Cacheid | all: string,指定cacheid,当为all时,代表所有cacheid;
    set-delay(int,ms,10): set操作延时的阈值,超过了会认为是warning
    get-delay(int,ms,10):get操作延时的阈值,超过了会认为是warning


 
 
 

yconsole使用说明的更多相关文章

  1. ycache分布式缓存框架

    介绍   ycache是yhd的分布是缓存框架,设计目的是提供易扩展.高可靠的分布式缓存系统.ycache从全局视角分配和管理缓存,检测缓存的状态并做故障恢复.   当应用(应用:使用ycache的上 ...

  2. yagent使用说明

    介绍   yagent是ycache的一个组件,用于管理memcached或redis的缓存实例.主要功能包括启动cache实例.将cache实例的信息写到zk上给yconsole使用.检测cache ...

  3. Atitit.项目修改补丁打包工具 使用说明

    Atitit.项目修改补丁打包工具 使用说明 1.1. 打包工具已经在群里面.打包工具.bat1 1.2. 使用方法:放在项目主目录下,执行即可1 1.3. 打包工具的原理以及要打包的项目列表1 1. ...

  4. awk使用说明

    原文地址:http://www.cnblogs.com/verrion/p/awk_usage.html Awk使用说明 运维必须掌握的三剑客工具:grep(文件内容过滤器),sed(数据流处理器), ...

  5. “我爱背单词”beta版发布与使用说明

    我爱背单词BETA版本发布 第二轮迭代终于画上圆满句号,我们的“我爱背单词”beta版本已经发布. Beta版本说明 项目名称 我爱背单词 版本 Beta版 团队名称 北京航空航天大学计算机学院  拒 ...

  6. Oracle 中 union 和union all 的简单使用说明

    1.刚刚工作不久,经常接触oracle,但是对oracle很多东西都不是很熟.今天我们来了解一下union和union all的简单使用说明.Union(union all): 指令的目的是将两个 S ...

  7. Map工具系列-02-数据迁移工具使用说明

    所有cs端工具集成了一个工具面板 -打开(IE) Map工具系列-01-Map代码生成工具说明 Map工具系列-02-数据迁移工具使用说明 Map工具系列-03-代码生成BySQl工具使用说明 Map ...

  8. Map工具系列-03-代码生成BySQl工具使用说明

    所有cs端工具集成了一个工具面板 -打开(IE) Map工具系列-01-Map代码生成工具说明 Map工具系列-02-数据迁移工具使用说明 Map工具系列-03-代码生成BySQl工具使用说明 Map ...

  9. jQuery验证控件jquery.validate.js使用说明

    官网地址:http://bassistance.de/jquery-plugins/jquery-plugin-validation jQuery plugin: Validation 使用说明 转载 ...

随机推荐

  1. CSDN添加文章目录

    在发表的文章中,系统根据文章中H1到H6标签自动生成文章目录. 一.发表文章的时候合理使用“标题”标签. 二.目录生成.只要在文章中使用了“标题1”这样的功能,就可以在博文开头看到文章的目录.

  2. 【转】CNN+BLSTM+CTC的验证码识别从训练到部署

    [转]CNN+BLSTM+CTC的验证码识别从训练到部署 转载地址:https://www.jianshu.com/p/80ef04b16efc 项目地址:https://github.com/ker ...

  3. 关于IDEA的application.properties读取乱码,以及显示乱码问题

    设置编码 如果设置之后还是不成功,就重启IDEA 再不行就删除application.properties重新编辑, 我采用的是注释掉要读取的中文部分,再下面再写一行

  4. 四,k8s集群资源清单定义入门

    目录 资源对象 创建资源的方法 清单帮助命令 创建测试清单 资源的三种创建方式 资源对象 workload:Pod, ReplicaSet, Deployment, StatefulSet, Daem ...

  5. 自学Python6.5-内置模块(re、collections )

    自学Python之路-Python基础+模块+面向对象自学Python之路-Python网络编程自学Python之路-Python并发编程+数据库+前端自学Python之路-django 自学Pyth ...

  6. PHP强制修改返回的状态码

    在最后的程序执行完毕之前,加入下列语句,即可实现所有的返回码都为200即使在服务器内部发生错误,会报500情况下只要加上register_shutdown_function函数的处理同样可以实现返回2 ...

  7. java8学习之Stream实例剖析

    继续操练Stream,直接上代码: 而咱们要返回ArrayList,显示可以用构造引用来传递到里面,因为它刚好符合Supplier函数式接口的特性:不接收参数返回一个值,所以: 接下来试着将Strea ...

  8. 洛谷P3402 可持久化并查集

    n个集合 m个操作 操作: 1 a b 合并a,b所在集合 2 k 回到第k次操作之后的状态(查询算作操作) 3 a b 询问a,b是否属于同一集合,是则输出1否则输出0 说是可持久化并查集,实际上是 ...

  9. poj2279 Mr. Young's Picture Permutations[勾长公式 or 线性DP]

    若干人左对齐站成最多5行,给定每行站多少个,列数从第一排开始往后递减.要求身高从每排从左到右递增(我将题意篡改了便于理解233),每列从前向后递增.每个人身高为1...n(n<=30)中的一个数 ...

  10. 【51nod1672】区间交

    题目大意:给定一个长度为 N 的序列,以及 M 个区间,现从中选出 K 个区间,使得这些区间的交集区间的点权和最大,求最大值是多少. 题解: 发现直接选 K 个区间不可做,考虑从答案入手.设答案区间为 ...