0707.md

1.内网穿透ngroK
2.

单一应用架构

  • 当网站流量很小时,只需一个应用,将所有功能都部署在一起,以减少部署节点和成本。
  • 此时,用于简化增删改查工作量的 数据访问框架(ORM) 是关键。

垂直应用架构

  • 当访问量逐渐增大,单一应用增加机器带来的加速度越来越小,将应用拆成互不相干的几个应用,以提升效率。
  • 此时,用于加速前端页面开发的 Web框架(MVC) 是关键。

分布式服务架构

  • 当垂直应用越来越多,应用之间交互不可避免,将核心业务抽取出来,作为独立的服务,逐渐形成稳定的服务中心,使前端应用能更快速的响应多变的市场需求。
  • 此时,用于提高业务复用及整合的 分布式服务框架(RPC) 是关键。

流动计算架构:

  • 当服务越来越多,容量的评估,小服务资源的浪费等问题逐渐显现,此时需增加一个调度中心基于访问压力实时管理集群容量,提高集群利用率。
  • 此时,用于提高机器利用率的 资源调度和治理中心(SOA) 是关键。

微服务架构:随着敏捷开发、持续交付、DevOps理论的发展和实践,以及基于Docker等轻量级容器(LXC)部署应用和服务的成熟,微服务架构开始流行,逐渐成为应用架构的未来演进方向。通过服务的原子化拆分,以及微服务的独立打包、部署和升级,小团队敏捷缴费,应用的交付周期将缩短,运维成本也将大幅下降。

3.spring声明式事务和编程式事务
spring事务注入方式:
https://blog.csdn.net/yaerfeng/article/details/28390773

4.spring事务传播行为:
| 事务传播行为类型 | 说明
-|-|-
PROPAGATION_REQUIRED | 如果当前没有事务,就新建一个事务,如果已经存在一个事务中,加入到这个事务中。这是最常见的选择。 |
PROPAGATION_SUPPORTS | 支持当前事务,如果当前没有事务,就以非事务方式执行。
PROPAGATION_MANDATORY| 使用当前的事务,如果当前没有事务,就抛出异常。
PROPAGATION_REQUIRES_NEW | 新建事务,如果当前存在事务,把当前事务挂起。
PROPAGATION_NOT_SUPPORTED | 以非事务方式执行操作,如果当前存在事务,就把当前事务挂起。
PROPAGATION_NEVER| 以非事务方式执行,如果当前存在事务,则抛出异常。
PROPAGATION_NESTED | 如果当前存在事务,则在嵌套事务内执行。如果当前没有事务,则执行与PROPAGATION_REQUIRED类似的操作。

5.5种io模型
Stevens在文章中一共比较了五种IO Model:

* blocking IO  阻塞io
* nonblocking IO  费阻塞io
* IO multiplexing  io多路复用
* signal driven IO
* asynchronous IO   异步io
* [https://www.cnblogs.com/findumars/p/6361627.html](https://www.cnblogs.com/findumars/p/6361627.html)

6.pmml