关于管道 Channel
- Channel 用来同步并发执行的函数并提供它们某种传值交流的机制。
- Channel 的一些特性:通过 channel 传递的元素类型、容器(或缓冲区)和 传递的方向由“<-”操作符指定。
c <- 123
,把值 123 输入到管道 c,<-c
,把管道 c 的值读取到左边,value := <-c
,这样就是读到 value 变量里面。
c <- 123
,把值 123 输入到管道 c,<-c
,把管道 c 的值读取到左边,value := <-c
,这样就是读到 value 变量里面。Channel是一个通道,可以通过它读取和写入数据,它就像自来水管一样,网络数据通过Channel读取和写入。通道与流的不同之处在于通道是双向的,流只是在一个方向上移动(一个流必须是InputStream或者OutputStream的子类),而且通道可以用于读、写或者同事用于读写。因为Channel是全双工的,所以它可以比流更好地映射底层操作系统的API。特别是在UNIX网络编程模型中,底层操作系统的通道都是全双工的,同时支持读写操作。
Web服务:Tengine/OpenResty&Tomcat
缓存:Redis/Memcache
队列:RocketMQ
数据存储:Mysql/MongoDB/Hadoop/Cassandra/ElasticSearch
大数据计算:JStorm/Hive/MapReduce/MaxCompute
分布式锁:Zookeeper
服务化:SpringCloud
框架:SpringBoot/Spring/Struts/Ibatis
容器:Docker
大部分PHP框架中,为了防止一个类被重复实例化,往往采用“单例模式”实例化类。我们的项目框架是这样做的:
先写好一个基类 /framework/Base.class.php,内容如下:
<?php namespace framework; defined('SITE_PATH') or die('Access Denied'); /** * 业务基类 * * @package framework */ class Base { /** * 类实例化(单例模式) * * @return mixed * @throws Exception */ public static function instance() { static $_instance = array(); $classFullName = get_called_class(); if (!isset($_instance[$classFullName])) { core_load_class($classFullName); if (!class_exists($classFullName, false)) { throw new Exception('"' . $classFullName . '" was not found !'); } $_instance[$classFullName] = new $classFullName(); } return $_instance[$classFullName]; } } ?>
今天在以SSH免密方式,拉取git代码(git pull)时,报错:
WARNING:Your password has expired
我们在 Java IO 流的分类介绍 这篇博客中介绍知道:
根据功能分为 节点流 和 包装流(处理流)
节点流:可以从或向一个特定的地方(节点)读写数据,如FileReader。
包装流(处理流):是对一个已存在的流的连接和封装,通过所封装的流的功能调用实现数据读写。如BufferedReader.处理流的构造方法总是要带一个其他的流对象做参数。一个流对象经过其他流的多次包装,称为流的链接。
sigh,很遗憾,没有写完整,还有很多想做而没有做的事情,总结一下想做而没有做的事情吧
1)性能测试,没有条件和环境给我做这个事情
2)对portal,对页面的支持,没有一个可以直观的可视页面
3)注册中心对zookeeper的支持
4)监控中心链路调用的追踪的支持,这个很重要,不过没有做
Mac/Linux 平台下,通用命令:
lsof -i:8080 (8080 为 端口号,根据需要,替换为其他端口号)
可以查看该端口被什么程序占用,并显示 pid,方便 kill 掉
打算 回滚Git的远程仓库到指定版本,通常的做法是用本地的某个版本 强制推送覆盖,可以运行 git命令
git push -f
但平常我习惯用 PhpStorm 自带的 Git 插件来管理版本控制,,,,发现 PhpStorm 这个强制推送按钮竟然是 灰色不可用的