Deprecated
: htmlspecialchars(): Passing null to parameter #1 ($string) of type string is deprecated in
/www/wwwroot/testblog.58heshihu.com/var/Widget/Archive.php
on line
1057
首页
关于
Search
1
给你10个市场数据调研报告的免费下载网站!以后竞品数据就从这里找!
182 阅读
2
php接口优化 使用curl_multi_init批量请求
144 阅读
3
《从菜鸟到大师之路 ElasticSearch 篇》
107 阅读
4
2024年备考系统架构设计师
104 阅读
5
PHP 文件I/O
92 阅读
php
thinkphp
laravel
工具
开源
mysql
数据结构
总结
思维逻辑
令人感动的创富故事
读书笔记
前端
vue
js
css
书籍
开源之旅
架构
消息队列
docker
教程
代码片段
redis
服务器
nginx
linux
科普
java
c
ElasticSearch
测试
php进阶
php基础
登录
Search
标签搜索
php函数
php语法
性能优化
安全
错误和异常处理
问题
vue
Composer
Session
缓存
框架
Swoole
api
并发
异步
正则表达式
php-fpm
mysql 索引
开发规范
协程
dafenqi
累计撰写
786
篇文章
累计收到
28
条评论
首页
栏目
php
thinkphp
laravel
工具
开源
mysql
数据结构
总结
思维逻辑
令人感动的创富故事
读书笔记
前端
vue
js
css
书籍
开源之旅
架构
消息队列
docker
教程
代码片段
副业
redis
服务器
nginx
linux
科普
java
c
ElasticSearch
测试
php进阶
php基础
页面
关于
搜索到
2
篇与
的结果
2024-01-02
PHP底层的高可扩展性架构设计与实现
PHP底层的高可扩展性架构设计与实现php中文网 php中文网课程 2023-11-13 12:01 发表于湖南随着互联网技术的迅速发展,PHP作为一种广泛应用的后台开发语言,其底层的架构设计和实现变得尤为重要。高可扩展性是一个优秀的框架或语言必须具备的核心特性之一。本文将探讨PHP底层的高可扩展性架构设计与实现,并通过具体的代码示例进行说明。模块化设计模块化设计是实现PHP底层高可扩展性的关键。通过将系统分解成独立的模块,每个模块只负责处理特定功能,降低了模块之间的耦合性,使得系统更易于维护和扩展。在PHP底层的架构设计过程中,模块化可以通过以下几种方式实现:1.1 使用命名空间(namespace)命名空间是PHP中实现模块化的一种方式。通过使用不同的命名空间,可以将功能相似的类或函数进行归类,降低了命名冲突的可能性。下面是一个简单的示例:namespace MyNamespace; class MyClass { //... }1.2 使用自定义扩展PHP允许开发者自定义扩展,通过自定义扩展可以将系统的功能进行模块化封装,提供统一的接口供其他模块调用。例如,我们可以通过自定义扩展实现对缓存的统一管理:<?php $cache = new MyCache(); $cache->set('key', 'value', 3600); $value = $cache->get('key');运行时动态加载PHP作为一种动态语言,具有灵活的特性,可以在运行时动态加载模块,使系统具备更高的可扩展性。在PHP底层的架构设计中,可以通过以下几种方式实现运行时动态加载:2.1 使用自动加载机制PHP提供了spl_autoload_register函数,通过注册自定义的自动加载函数,可以在需要时动态加载类文件。以下是一个示例:<?php spl_autoload_register(function ($class) { require_once __DIR__ . '/library/' . $class . '.php'; }); $myClass = new MyClass();2.2 使用PSR标准PHP-FIG发布的PSR标准(PHP Standards Recommendation)规定了一系列编码标准和规范,其中包括了自动加载规范(PSR-4)。遵循PSR标准,可以更好地组织代码,实现模块的自动加载。以下是一个示例:<?php spl_autoload_register(function ($class) { $path = str_replace('\', DIRECTORY_SEPARATOR, $class); $file = __DIR__ . '/' . $path . '.php'; if (file_exists($file)) { require_once $file; } }); $myClass = new MyClass();基于事件驱动的架构基于事件驱动的架构是一种在PHP底层实现高可扩展性的有效方式。通过定义不同的事件和事件监听器,可以使系统在特定情况下触发相应的操作,从而实现系统的扩展和灵活性。以下是一个简单的示例:<?php $eventDispatcher = new EventDispatcher(); // 定义事件 class MyEvent extends Event { //... } // 定义事件监听器 class MyEventListener implements ListenerInterface { public function onMyEvent(MyEvent $event) { // 处理事件 } } // 注册事件监听器 $eventDispatcher->addListener(MyEvent::class, 'MyEventListener::onMyEvent'); // 触发事件 $event = new MyEvent(); $eventDispatcher->dispatch($event);缓存和优化在PHP底层的架构设计过程中,合理地使用缓存和优化技术可以进一步提高系统的可扩展性。以下是一些常用的缓存和优化方式:4.1 使用opcode缓存PHP解释器在每次运行时都会将PHP代码编译成opcode,然后再执行。使用opcode缓存工具(例如APC、OpCache)可以避免每次都重新编译PHP代码,提高系统的性能。4.2 使用缓存机制将一些频繁读取、计算的数据进行缓存,可以有效降低系统的负载,提高响应速度。可以使用文件缓存、内存缓存(例如Memcached、Redis)等方式进行数据缓存。综上所述,PHP底层的高可扩展性架构设计与实现需要采取模块化设计、运行时动态加载、基于事件驱动的架构以及缓存和优化等方式。开发者可以根据实际需求选择合适的架构设计,通过具体的代码实现灵活的系统扩展和高可扩展性。
2024年01月02日
10 阅读
0 评论
0 点赞
2023-08-31
什么是高可用
什么是高可用一、什么是高可用高可用HA(High Availability) 是 分布式系统架构设计 中必须考虑的因素之一,它通常是指, 通过设计减少系统不能提供服务的时间 。假设系统一直能够提供服务,我们说系统的可用性是100%。如果系统每运行100个时间单位,会有1个时间单位无法提供服务,我们说系统的可用性是99%。很多公司的高可用目标是4个9,也就是99.99%,这就意味着,系统的年停机时间为8.76个小时。百度的搜索首页,是业内公认高可用保障非常出色的系统,甚至人们会通过www.baidu.com 能不能访问来判断“网络的连通性”,百度高可用的服务让人留下啦“网络通畅,百度就能访问”,“百度打不开,应该是网络连不上”的印象,这其实是对百度HA最高的褒奖。二、如何保障系统的高可用我们都知道,单点是系统高可用的大敌,单点往往是系统高可用最大的风险和敌人,应该尽量 在系统设计的过程中避免单点 。方法论上, 高可用保证的原则是“集群化”,或者叫“冗余”:只有一个单点,挂了服务会受影响;如果有冗余备份,挂了还有其他backup能够顶上。 保证系统高可用,架构设计的核心准则是:冗余。 有了冗余之后,还不够,每次出现故障需要人工介入恢复势必会增加系统的不可服务实践。所以,又往往是通过“自动故障转移”来实现系统的高可用。 接下来我们看下典型互联网架构中,如何通过冗余+自动故障转移来保证系统的高可用特性。三、常见的互联网分层架构常见互联网分布式架构如上,分为:(1)客户端层: 典型调用方是浏览器browser或者手机应用APP(2)反向代理层: 系统入口,反向代理(3)站点应用层: 实现核心应用逻辑,返回html或者json(4)服务层: 如果实现了服务化,就有这一层(5)数据-缓存层: 缓存加速访问存储(6)数据-数据库层: 数据库固化数据存储整个系统的高可用,又是通过每一层的冗余+自动故障转移来综合实现的。四、分层高可用架构实践【客户端层->反向代理层】的高可用【客户端层】到【反向代理层】的高可用, 是通过反向代理层的冗余来实现的 。以nginx为例:有两台nginx,一台对线上提供服务,另一台冗余以保证高可用,常见的实践是keepalived存活探测,相同virtual IP提供服务。自动故障转移:当nginx挂了的时候,keepalived能够探测到,会自动的进行故障转移,将流量自动迁移到shadow-nginx,由于使用的是相同的virtual IP,这个切换过程对调用方是透明的。【反向代理层->站点层】的高可用【反向代理层】到【站点层】的高可用, 是通过站点层的冗余来实现的 。假设反向代理层是nginx,nginx.conf里能够配置多个web后端,并且nginx能够探测到多个后端的存活性。自动故障转移:当web-server挂了的时候,nginx能够探测到,会自动的进行故障转移,将流量自动迁移到其他的web-server,整个过程由nginx自动完成,对调用方是透明的。【站点层->服务层】的高可用【站点层】到【服务层】的高可用, 是通过服务层的冗余来实现的 。“服务连接池”会建立与下游服务多个连接,每次请求会“随机”选取连接来访问下游服务。自动故障转移:当service挂了的时候,service-connection-pool能够探测到,会自动的进行故障转移,将流量自动迁移到其他的service,整个过程由连接池自动完成,对调用方是透明的(所以说RPC-client中的服务连接池是很重要的基础组件)。【服务层>缓存层】的高可用【服务层】到【缓存层】的高可用, 是通过缓存数据的冗余来实现的 。缓存层的数据冗余又有几种方式 :第一种是利用客户端的封装,service对cache进行双读或者双写。缓存层也可以通过支持主从同步的缓存集群来解决缓存层的高可用问题。以redis为例,redis天然支持主从同步,redis官方也有sentinel哨兵机制,来做redis的存活性检测。自动故障转移:当redis主挂了的时候,sentinel能够探测到,会通知调用方访问新的redis,整个过程由sentinel和redis集群配合完成,对调用方是透明的。说完缓存的高可用,这里要多说一句, 业务对缓存并不一定有“高可用”要求,更多的对缓存的使用场景,是用来“加速数据访问”:把一部分数据放到缓存里,如果缓存挂了或者缓存没有命中,是可以去后端的数据库中再取数据的。 这类允许“cache miss”的业务场景,缓存架构的建议是:将kv缓存封装成服务集群,上游设置一个代理(代理可以用集群冗余的方式保证高可用),代理的后端根据缓存访问的key水平切分成若干个实例,每个实例的访问并不做高可用。缓存实例挂了屏蔽:当有水平切分的实例挂掉时,代理层直接返回cache miss,此时缓存挂掉对调用方也是透明的。key水平切分实例减少,不建议做re-hash,这样容易引发缓存数据的不一致。【服务层>数据库层】的高可用大部分互联网技术,数据库层都用了“主从同步,读写分离”架构,所以数据库层的高可用,又分为“读库高可用”与“写库高可用”两类。【服务层>数据库层“读”】的高可用【服务层】到【数据库读】的高可用,是通过读库的冗余来实现的。 既然冗余了读库,一般来说就至少有2个从库,“数据库连接池”会建立与读库多个连接,每次请求会路由到这些读库。自动故障转移:当读库挂了的时候,db-connection-pool能够探测到,会自动的进行故障转移,将流量自动迁移到其他的读库,整个过程由连接池自动完成,对调用方是透明的(所以说DAO中的数据库连接池是很重要的基础组件)。【服务层>数据库层“写”】的高可用【服务层】到【数据库写】的高可用,是通过写库的冗余来实现的。 以mysql为例,可以设置两个mysql双主同步,一台对线上提供服务,另一台冗余以保证高可用,常见的实践是keepalived存活探测,相同virtual IP提供服务。自动故障转移:当写库挂了的时候,keepalived能够探测到,会自动的进行故障转移,将流量自动迁移到shadow-db-master,由于使用的是相同的virtual IP,这个切换过程对调用方是透明的。五、总结高可用HA(High Availability)是分布式系统架构设计中必须考虑的因素之一,它通常是指,通过设计减少系统不能提供服务的时间。 方法论上,高可用是通过冗余+自动故障转移来实现的。 整个互联网分层系统架构的高可用,又是通过每一层的冗余+自动故障转移来综合实现的,具体的:(1)【客户端层】到【反向代理层】的高可用,是通过反向代理层的冗余实现的,常见实践是keepalived + virtual IP自动故障转移(2)【反向代理层】到【站点层】的高可用,是通过站点层的冗余实现的,常见实践是nginx与web-server之间的存活性探测与自动故障转移(3)【站点层】到【服务层】的高可用,是通过服务层的冗余实现的,常见实践是通过service-connection-pool来保证自动故障转移(4)【服务层】到【缓存层】的高可用,是通过缓存数据的冗余实现的,常见实践是缓存客户端双读双写,或者利用缓存集群的主从数据同步与sentinel保活与自动故障转移;更多的业务场景,对缓存没有高可用要求,可以使用缓存服务化来对调用方屏蔽底层复杂性(5)【服务层】到【数据库“读”】的高可用,是通过读库的冗余实现的,常见实践是通过db-connection-pool来保证自动故障转移(6)【服务层】到【数据库“写”】的高可用,是通过写库的冗余实现的,常见实践是keepalived + virtual IP自动故障转移
2023年08月31日
36 阅读
0 评论
0 点赞