聚石塔目前支持以下“部署类型”:
1)容器部署;
2)Serverless容器;
3)虚拟机部署(不再升级,保持原有客户);
4)轻容器部署(不再升级,保持原有客户)。
“容器部署”、“Serverless容器”是推荐的接入方式,主要区别及对比如下:
容器部署(K8S) |
Serverless |
|
适用场景 |
适用于业务规模较大,业务流量无规律或流量平稳,容器实例需常驻提供服务的应用。 |
适用于业务场景简单,业务流量规律,有明显波峰波谷或有周期性的弹性伸缩业务场景。 |
运维成本方面 |
1.集群版本更新时,需要手工进行集群版本升级; 2.需要管理容器集群内ECS的生命周期。 |
免运维。 |
易用性方面 |
1.需要新建集群,管理容器集群节点(ECS)资源; 2.需要进行功能扩展安装,如日志采集组件。 |
1.开箱即用,直接创建云应用即可; 2.与微服务引擎MSE无缝集成。 |
灵活性方面 |
1.支持多种应用类型(无状态应用、有状态应用、守护进程集、CronJob等); 2.根据自身需求灵活安装插件。 |
目前仅支持无状态应用。 |
成本方面 |
1.周期性弹性伸缩场景下,Serverless容器拥有更好的性价比; 2.日常应用实例无须弹性伸缩情况下,容器部署更具性价比; 详情见价格对比:点击查看详情 |
聚石塔应用类型目前支持已下应用类型:
1)无状态应用;
2)有状态应用;
3)守护进程集;
4)定时任务;
5)IngressController。
聚石塔应用类型 |
对应K8S概念 |
无状态应用 |
Deployment |
有状态应用 |
StatefulSet |
守护进程集 |
DaemonSet |
定时任务 |
CronJob |
IngressController |
IngressController |
尽量选择无状态服务,比如日志,打印标准输出到持久化存储,通过SLS日志服务采集处理。数据库有状态服务不建议部署在容器平台,有状态会限制可扩展性、降低可用性并增加成本。
比如web,无状态服务存储的html和日志文件,这些数据,每个pod访问都是一致的,可以用无状态配合分布式存储nas,做数据持久化。
无状态应用是最常用的一种应用类型,它运行的实例不会在本地存储需要持久化的数据,并且多个实例对于同一个请求响应的结果是完全一致的,多个实例可以共享相同的持久化数据,可以轻松实现扩缩容。例如:nginx实例,tomcat实例等。
有状态服务可以说是需要数据存储功能的服务、或者指多线程类型的服务,队列等。(mysql数据库、kafka、zookeeper等)。每个实例都需要有自己独立的持久化存储。
YAML配置可参考:点击查看说明文档。
使用持久化存储可参考:点击查看说明文档。
DaemonSet确保全部(或某些)节点上运行一个Pod副本。当有节点加入集群时,也会为他们新增一个Pod。当有节点从集群移除时,这些Pod也会被回收。删除DaemonSet将会删除它创建的所有Pod。
① 在集群的每个节点上运行存储 Daemon,比如 glusterd 或 ceph。
② 在每个节点上运行日志收集 Daemon,比如 flunentd 或 logstash。
③ 在每个节点上运行监控 Daemon,比如 Prometheus Node Exporter 或 collectd。
具体使用文档:点击查看。
一个 CronJob 对象就像Linux系统中的 crontab (cron table) 文件中的一行。它用 Cron 格式进行编写,并周期性地在给定的调度时间执行 Job。
具体使用文档:点击查看。
ingress将来自集群外部的HTTP和HTTPS路由暴露给集群内的服务(k8s Service),流量路由规则由ingress资源来定义。简单的来说,ingress能够将不同域名+ 路径(如 aaa.com/api)映射到集群内的k8s service上。
详细解释及使用文档:点击查看。