August 13, 2014
基本调优工具
"一 mpstat – 查看CPU使率信息 vmstat – 报告虚存统计数据 iostat – 报告CPU状态和存储I/O统计数据 netstat – 报告络栈各项参数 ps – 系统上运的进程及其状态 top – 报告占CPU和内存最的进程 sar – 报告系统活动状态 pidstat – 检查具体某个进程的CPU和内存情况 perf – 综合性能检查具\n二 sysctl – 调整内核参数 strace – 跟踪进程的执 dtrace – 综合跟踪具 stap – 综合跟踪具 taskset – 绑定执CPU pmap – 报告进程内存映射信息 free – 报告物理帧和虚拟帧信息 dmesg – 系统启动信息,包括对各设备的监测 /proc – 各项系统参数读写接\n三 /sys – 额外系统参数读写接 iotop – 类似top,但于检测I/O ionice – 类似nice,但于设置进程的I/O优先级 ifcong – 监测与配置络接 tcpdump – 捕获某个络接上的流量 nicstat – 监测卡状态 sysctl – 调整内核参数 strace – …"
August 2, 2014
RabbitMQ中的ack介绍
"no_ack 的用途:确保 message 被 consumer “成功”处理了。这里“成功”的意思是,(在设置了 no_ack=false 的情况下)只要 consumer 手动应答了 Basic.Ack ,就算其“成功”处理了。\n对于ack简单的说就是“消费者”先从queue里读取一条数据,然后去处理,等处理完了,再给queue一个 ack 回应,表示处理完了,这时queue就将这条数据从队列中删除。如果不回应给队列ack的话,则这条消息仍然存在在queue中(这个也属于一种应用场景)。\n在 no_ack=true 的情况下,RabbitMQ 认为 message 一旦被 deliver 出去了,就已被确认了,所以会立即将缓存中的 message 删除。所以在 consumer 异常时会导致消息丢失。\nno_ack=false(此时为 手动应答)\n在这种情况下,要求 consumer 在处理完接收到的 Basic.Deliver + Content-Header + Content-Body 之后才回复 Ack 。而这个 Ack 是 AMQP 协议中的 Basic.Ack 。 …"
August 1, 2014
认识 RabbitMQ 消息队列
"RabbitMQ架构图 rabbitmq 架构图\n基本概念 Broker:简单来说就是消息队列服务器实体。 Exchange:消息交换机,它指定消息按什么规则,路由到哪个队列。 Queue:消息队列载体,每个消息都会被投入到一个或多个队列。 Binding:绑定,它的作用就是把exchange和queue按照路由规则绑定起来。 Routing Key:路由关键字,exchange根据这个关键字进行消息投递。 vhost:虚拟主机,一个broker里可以开设多个vhost,用作不同用户的权限分离。 producer:消息生产者,就是投递消息的程序。 consumer:消息消费者,就是接受消息的程序。 channel:消息通道,在客户端的每个连接里,可建立多个channel,每个channel代表一个会话任务。\n操作流程 (1)客户端连接到消息队列服务器,打开一个channel。 (2)客户端声明一个exchange,并设置相关属性。 (3)客户端声明一个queue,并设置相关属性。 (4)客户端使用routing key,在exchange和queue之间建立好绑定关系。 (5)客户端投 …"
August 1, 2014
将rabbitmq 里的消息持久化
"消息持久设置: 将交换机置为可持久;\n将通道置为可持久\n消息发送时设置可持久。\n当我们“生产”了一条可持久化的消息,尝试中断MQ服务,启动消费者获取消息,消息依然能够恢复。相反,则抛出异常。\n上面三条必须全部设置,不然消息将无法持久化。"
August 1, 2014
rabbitmq 添加远程访问功能
"刚刚安装过的rabbitmq 消息队列,并启用了插件管理功能,3.3.1版中,处于安全的考虑,guest这个默认的用户只能通过http://localhost:15672 来登录,其他的IP无法直接使用这个账号。 这对于服务器上没有安装桌面的情况是无法管理维护的,除非通过在前面添加一层代理向外提供服务,这个又有些麻烦了,这里通过配置文件来实现这个功能。\n只要编辑 /etc/rabbitmq/rabbitmq.config 文件,添加以下配置就可以了。\n[ {rabbit, [{tcp_listeners, [5672]}, {loopback_users, [“asdf”]}]} ].\n现在添加了一个新授权用户asdf,可以通过外网使用这个用户名和密码访问.(记得要先用命令添加这个命令才行,#rabbitmqctl add_user asdf pwd123456)我是通过在管理平台里直接添加的用户和密码的,我的测试环境装有桌面的。 参考文档: http://www.rabbitmq.com/access-control.html\n# rabbitmqctl add_user asdf …"
August 1, 2014
【架构】关于RabbitMQ
"1 什么是RabbitMQ? RabbitMQ是实现AMQP(高级消息队列协议)的消息中间件的一种,最初起源于金融系统,用于在分布式系统中存储转发消息,在易用性、扩展性、高可用性等方面表现不俗。消息中间件主要用于组件之间的解耦,消息的发送者无需知道消息使用者的存在,反之亦然: 单向解耦 双向解耦(如:RPC)\n例如一个日志系统,很容易使用RabbitMQ简化工作量,一个Consumer可以进行消息的正常处理,另一个Consumer负责对消息进行日志记录,只要在程序中指定两个Consumer所监听的queue以相同的方式绑定到同一个exchange即可,剩下的消息分发工作由RabbitMQ完成。\n使用RabbitMQ server需要:\nErLang语言包;\nRabbitMQ安装包;\nRabbitMQ同时提供了java的客户端(一个jar包)。\n2 概念和特性 2.1 交换机(exchange): 1. 接收消息,转发消息到绑定的队列。四种类型:direct, topic, headers and fanout\ndirect:转发消息到routigKey指定的队列\ntopic:按规则转发 …"
July 28, 2014
mysql中数据类型的长度解释
"11.2. 数值类型 MySQL支持所有标准SQL数值数据类型。这些类型包括严格数值数据类型(INTEGER、SMALLINT、DECIMAL和NUMERIC),以及近似数值数据类型(FLOAT、REAL和DOUBLE PRECISION)。关键字INT是INTEGER的同义词,关键字DEC是DECIMAL的同义词。\nBIT数据类型保存位字段值,并且支持MyISAM、MEMORY、InnoDB和BDB表。\n作为SQL标准的扩展,MySQL也支持整数类型TINYINT、MEDIUMINT和BIGINT。下面的表显示了需要的每个整数类型的存储和范围。\n类型 字节 最小值 最大值 (带符号的/无符号的) (带符号的/无符号的) TINYINT 1 -128 127 0 255 SMALLINT 2 -32768 32767 0 65535 MEDIUMINT 3 -8388608 8388607 0 16777215 INT 4 -2147483648 2147483647 0 4294967295 BIGINT 8 -9223372036854775808 …"
July 23, 2014
MySQL 更新并返回计数
"对于想使用 MySQL 实现简单 ID 分配器, 一般就是设置一个整数字段, 然后想分配的时候加 1 并返回. 新手往往犯错误, 先执行一条 update 语句, 然后再 select 那个字段. 但这是错误的!\nCREATE TABLE `mytable` ( `counter` int(10) NOT NULL DEFAULT \u0026#39;0\u0026#39; ) ENGINE=InnoDB DEFAULT CHARSET=utf8; insert into mytable values(1); 正确的方式应该是使用 last_insert_id() 函数:\nupdate mytable set counter=last_insert_id(counter+1); select last_insert_id(); 另一种方法(http://imysql.cn/2010/07/01/mysql-faq-using-mysql-as-serial-generator.html):\nSELECT `ID` FROM `ID_RANGE_XX` ORDER BY ID LIMIT 1 FOR …"
June 20, 2014
golint—golang代码质量检测
"github: https://github.com/golang/lint\ngolint是类似javascript中的jslint的工具,主要功能就是检测代码中不规范的地方。golint用于检测go代码。\n使用 $ go get github.com/golang/lint $ go install github.com/golang/lint golint 文件名或者目录 检测对应的代码。\ngolint会输出一些代码存在的问题: 比如:\nrecorder.go:55:5: exported var RecordBind should have comment or be unexported recorder.go:158:1: exported function Record_ErrorRecord should have comment or be unexported recorder.go:173:6: don\u0026#39;t use underscores in Go names; type Data_MemStats should be DataMemStats …"
June 19, 2014
Swift中的标准函数
"Swift中共有74个内建函数,但是在Swift官方文档(“ The Swift Programming Language”)中只记录了7中。剩下的67个都没有记录。\n本文将列举Swift所有的内建函数。本文中提到的所谓的内建函数是指那些在Swift中不需要导入任何模块(如Foundation等)或者引用任何类就可以使用的函数。\nabs(signedNumber): 返回给定的有符号数字的绝对值。很简单,但是没有在文档中记录。\nabs(-1) == 1 abs(-42) == 42 abs(42) == 42 contains(sequence, element): 如果给定的序列(如数组)包含特定的元素,则返回true。\nvar languages = [“Swift”, “Objective-C”] contains(languages, “Swift”) == true contains(languages, “Java”) == false contains([29, 85, 42, 96, 75], 42) == true dropFirst(sequence): 返回一个去 …"