就想我这样 发表于 2023-2-26 21:13:50

PHP 并发方案建议

1,消息队列解决方案:


[*]RabbitMQ:RabbitMQ 是一个开源的 AMQP 消息中间件,提供了高可用、高并发、高吞吐量的消息队列服务。使用 PHP 语言可以通过 AMQP 扩展连接到 RabbitMQ 服务,实现消息的生产、消费和处理。
[*]Redis 队列:Redis 是一个开源的内存数据库,提供了高速、高性能的数据结构服务,如字符串、列表、集合、哈希表等。通过使用 Redis 的 List 类型实现队列,可以实现消息的生产、消费和处理。
[*]Kafka:Kafka 是一个开源的分布式消息系统,具有高吞吐量、低延迟、高可靠性的特点。使用 PHP 语言可以通过 Kafka 客户端扩展连接到 Kafka 服务,实现消息的生产、消费和处理。
[*]Beanstalkd:Beanstalkd 是一个轻量级的消息队列服务,具有高可用、高可靠性、高性能的特点。使用 PHP 语言可以通过 Pheanstalk 客户端扩展连接到 Beanstalkd 服务,实现消息的生产、消费和处理。
[*]ZeroMQ:ZeroMQ 是一个开源的高性能消息传递库,提供了多种消息传递模式,如 publish/subscribe、request/reply、pipeline 等。使用 PHP 语言可以通过 ZeroMQ 扩展连接到 ZeroMQ 服务,实现消息的生产、消费和处理。
2,协程解决方案 + 异步 IO解决方案:


[*]Swoole:Swoole 是一个基于 PHP 语言的高性能异步、协程网络通信框架,提供了协程、异步 IO、网络通信、定时器等功能,支持 HTTP、WebSocket、TCP 等多种协议。使用 Swoole 可以实现 PHP 的协程特性,提高 PHP 应用的性能和并发能力。
[*]Coroutine:Coroutine 是一个轻量级的协程库,提供了协程、异步 IO、网络通信等功能,支持 HTTP、WebSocket、TCP 等多种协议。使用 Coroutine 可以方便地实现 PHP 的协程特性,以提高 PHP 应用的性能和并发能力。
[*]PHP-FPM 协程:PHP-FPM 是 PHP 的 FastCGI 进程管理器,支持使用协程池实现协程,提高 PHP 应用的性能和并发能力。使用 PHP-FPM 协程需要在 PHP-FPM 配置文件中开启协程池,并通过特定的函数调用实现协程的切换和调度。
[*]Amp:Amp 是一个基于 PHP 语言的异步编程框架,提供了协程、异步 IO、Promise、网络通信等功能,支持 HTTP、WebSocket、TCP 等多种协议。使用 Amp 可以方便地实现 PHP 的协程特性,以提高 PHP 应用的性能和并发能力。
[*]ReactPHP:ReactPHP 是一个基于 PHP 语言的异步编程框架,提供了异步 IO、网络通信等功能,支持 HTTP、WebSocket、TCP 等多种协议。使用 ReactPHP 可以方便地实现 PHP 的* 异步 IO 特性,以提高 PHP 应用的性能和并发能力。
[*]Workerman:Workerman是一个高性能的PHP异步网络框架,支持TCP/UDP/Unix Socket协议、异步IO、事件驱动等,可以用于开发高并发、实时通信的应用程序。
[*]PHP-PM:PHP-PM是一个基于PHP的进程管理器,使用了Swoole扩展提供异步I/O和协程支持,可以快速、稳定地运行PHP应用程序。
3,缓存解决方案:


[*]Memcached:Memcached 是一款开源的高性能分布式内存缓存系统,支持多种语言,包括 PHP,广泛应用于 Web 应用程序中,被认为是 PHP 缓存的首选方案之一。Memcached 的主要优点是速度快、稳定可靠,可扩展性好,能够有效地缓解 Web 应用程序中的数据库压力。
[*]Redis:Redis 是一款开源的高性能键值对存储系统,支持多种数据结构,包括字符串、列表、哈希表、集合等,可以作为缓存、消息队列、分布式锁等多种用途。Redis 的主要优点是速度快、性能稳定、可靠性高、支持多种数据结构和高级特性,被广泛应用于 Web 应用程序中,也是 PHP 缓存的常用方案之一。
[*]APC(Alternative PHP Cache):APC 是 PHP 官方推荐的一款缓存扩展,能够缓存 PHP 脚本文件,提高 PHP 应用程序的性能和响应速度。APC 的主要优点是易于安装和使用,对于小型的 Web 应用程序而言,可以提供一定的性能提升。
[*]Xcache:Xcache 是一款开源的 PHP 缓存扩展,支持 PHP 5.x 和 PHP 7.x,具有性能高、稳定性好、支持多种缓存策略等优点,被广泛应用于 PHP 应用程序中。
[*]OpCache:OpCache 是 PHP 官方推荐的一款缓存扩展,用于缓存 PHP 脚本的字节码,提高 PHP 应用程序的性能和响应速度。OpCache 的主要优点是易于安装和使用,对于小型的 Web 应用程序而言,可以提供一定的性能提升。
4,分布式解决方案:


[*]Apache Thrift:Apache Thrift是一种可扩展、跨语言的分布式服务框架,支持多种编程语言,包括PHP、Java、Python等。它提供了高效的远程服务调用和跨语言的数据传输。
[*]gRPC:gRPC是Google开发的高性能、开源的RPC框架,支持多种编程语言,包括PHP、Java、Python等。它基于HTTP/2协议,支持多种数据序列化格式,如Protobuf和JSON。
[*]ZooKeeper:ZooKeeper是一种高可用性、高性能的分布式协调服务,主要用于构建分布式系统。它提供了高效的协调服务,支持多种编程语言,包括PHP、Java、Python等。
[*]Redis:Redis是一种高性能、内存型的键值存储系统,支持多种数据结构,如字符串、哈希表、列表等。它提供了分布式集群和主从复制等功能,可以用于构建分布式应用。
[*]Apache Kafka:Apache Kafka是一种分布式的流处理平台,主要用于构建实时数据流应用。它支持高吞吐量的消息传输,提供了高效的数据传输和持久化存储。
[*]Eureka:Eureka是Netflix开发的一种分布式服务发现框架,主要用于构建微服务架构。它提供了高可用性、高性能的服务注册和发现功能,可以用于构建分布式系统。
[*]Consul:Consul是一种分布式服务发现和配置管理系统,支持多种数据中心和跨数据中心的服务发现和故障转移。它提供了高可用性、高性能的服务注册和发现功能,可以用于构建分布式系统。
5,服务器集群解决方案:


[*]LVS:Linux Virtual Server(LVS)是一个高可用性、高性能的服务器集群解决方案,可以提供负载均衡和高可用性服务。
[*]Nginx:Nginx是一款高性能的Web服务器和反向代理服务器,可以通过反向代理和负载均衡实现服务器集群。
[*]HAProxy:HAProxy是一款高性能的TCP/HTTP负载均衡器,可以实现服务器集群、高可用性、高并发等功能。
[*]Apache:Apache是一款流行的Web服务器,可以通过模块扩展实现负载均衡和服务器集群功能。
[*]MySQL Cluster:MySQL Cluster是MySQL提供的高可用性、高性能、可扩展的数据库解决方案,可以实现数据库集群。
6,分表分库解决方案:

分表:将单个数据表中的数据按照某种规则拆分到多个数据表中,可以提高单个数据表的查询效率和数据存储的性能。
分库:将整个数据库按照某种规则划分成多个子库,每个子库可以放置不同的数据表,可以提高数据库整体的扩展性和性能。

[*]Sharding中间件:Sharding中间件是一种常见的分库分表方案,可以将数据分散到多个数据库中,同时也可以支持分表,将单个表的数据分散到多个数据表中。
[*]Proxy层:通过在应用程序和数据库之间增加一层代理层,将请求分散到多个数据库中,可以实现分库分表的效果。
7,数据库索引解决方案:


[*]B-tree索引:B-tree索引是一种常用的索引类型,可以加速等值查询、范围查询和排序等操作,常用于MySQL、PostgreSQL等数据库。
[*]Hash索引:Hash索引是一种基于哈希表的索引方式,可以快速的进行等值查询,但不支持范围查询和排序等操作,常用于Memcached、Redis等内存型数据库。
[*]Full-Text索引:Full-Text索引是一种用于全文搜索的索引方式,可以加速全文搜索和相关性排序等操作,常用于MySQL、PostgreSQL等数据库。
[*]空间索引:空间索引是一种用于空间数据的索引方式,可以加速空间数据的查询和分析,常用于GIS系统等。
8,PHPCDN技术解决方案:

静态资源CDN加速:将PHP应用程序中的静态资源(如CSS、JS、图片等)上传到CDN服务商,并使用CDN加速访问,可以减轻PHP应用程序的服务器负载,提升访问速度和用户体验。
动态内容缓存:使用CDN服务商提供的动态内容缓存功能,可以将PHP应用程序中的动态内容缓存到CDN节点中,减轻PHP应用程序的服务器负载,提升访问速度和用户体验。
智能路由选择:通过CDN服务商提供的智能路由选择功能,可以根据用户的地理位置、网络环境等因素,自动选择最优的CDN节点进行访问,提升访问速度和稳定性。
防DDoS攻击:通过CDN服务商提供的DDoS防护功能,可以有效防御DDoS攻击,提升PHP应用程序的可用性和安全性。

[*]Nginx:Nginx是一种高性能的Web服务器和反向代理服务器,可以集成CDN模块来实现CDN功能。
[*]Varnish Cache:Varnish Cache是一种开源的Web加速器,可以将常见的静态资源缓存到本地服务器上,从而提高网站的响应速度。
[*]Cloudflare:Cloudflare是一种云端CDN服务提供商,可以通过将网站的DNS解析到Cloudflare来实现CDN功能。
[*]Akamai:Akamai是一种全球性CDN服务提供商,可以提供全球性的CDN服务,从而提高网站的访问速度。
[*]Amazon CloudFront:Amazon CloudFront是一种AWS的CDN服务,可以通过将网站的内容存储到亚马逊的云端服务器上来实现CDN功能。
9,高可用架构设计


[*]主从复制:主从复制是将数据从主数据库实时复制到一个或多个从数据库的过程。PHP 框架 Laravel 中就实现了主从复制机制。


[*] 第一步:   首先,需要在 config/database.php 文件中配置主库和从库的连接信息,如下所示:
点击查看代码'connections' => [
    'mysql' => [
      'write' => [
            'host' => env('DB_HOST', 'localhost'),
            'username' => env('DB_USERNAME', 'forge'),
            'password' => env('DB_PASSWORD', ''),
            'port' => env('DB_PORT', '3306'),
            'database' => env('DB_DATABASE', 'forge'),
            'charset' => 'utf8mb4',
            'collation' => 'utf8mb4_unicode_ci',
            'prefix' => '',
            'strict' => true,
            'engine' => null,
      ],
      'read' => [
            'host' => 'slave1',
            'username' => env('DB_USERNAME', 'forge'),
            'password' => env('DB_PASSWORD', ''),
            'port' => env('DB_PORT', '3306'),
            'database' => env('DB_DATABASE', 'forge'),
            'charset' => 'utf8mb4',
            'collation' => 'utf8mb4_unicode_ci',
            'prefix' => '',
            'strict' => true,
            'engine' => null,
      ],
      'sticky'    => true,
      'driver' => 'mysql',
      'url' => env('DATABASE_URL'),
      'host' => env('DB_HOST', 'localhost'),
      'port' => env('DB_PORT', '3306'),
      'database' => env('DB_DATABASE', 'forge'),
      'username' => env('DB_USERNAME', 'forge'),
      'password' => env('DB_PASSWORD', ''),
      'charset' => 'utf8mb4',
      'collation' => 'utf8mb4_unicode_ci',
      'prefix' => '',
      'strict' => true,
      'engine' => null,
      'options' => extension_loaded('pdo_mysql') ? array_filter([
            PDO::MYSQL_ATTR_SSL_CA => env('MYSQL_ATTR_SSL_CA'),
      ]) : [],
    ],
],

[*] 第二步:   然后,在使用数据库连接的地方,可以指定使用主库或从库连接,如下所示:
点击查看代码$users = DB::connection('mysql')->select('select * from users'); // 从库连接
DB::connection('mysql')->statement('update users set votes = 100 where name = ?', ['John']); // 主库连接

[*] 补充:   可以使用 Laravel 自带的 DB 类或者第三方库来实现自动化的主从切换和负载均衡,如 laravel-master-slave 库。


[*]双主架构:双主架构是指一个集群中有两个主节点,每个节点都能够进行写操作。当一个节点发生故障时,另一个节点可以接替它的工作。PHP 框架 Yii2 中支持双主架构。


[*] 第一步:在 Yii2 的配置文件 config/db.php 中配置主数据库和备份数据库的连接信息:
点击查看代码return [
    'class' => 'yii\db\Connection',
    'dsn' => 'mysql:host=主库IP地址;dbname=数据库名',
    'username' => '用户名',
    'password' => '密码',
    'charset' => 'utf8',

    'slaveConfig' => [
      'username' => '用户名',
      'password' => '密码',
      'attributes' => [
            // use a smaller connection timeout
            PDO::ATTR_TIMEOUT => 10,
      ],
    ],
    'slaves' => [
      ['dsn' => 'mysql:host=备库IP地址;dbname=数据库名'],
    ],
];

[*] 第二步:在代码中进行双主架构的读写分离:
点击查看代码$db = Yii::$app->db;
$db->setMaster(true); // 使用主库进行写操作
$model->save();
$db->setMaster(false); // 使用备库进行读操作
$data = $model->find()->asArray()->all();

[*] 补充:配置负载均衡,通过负载均衡将流量分配到多个服务器上,从而实现高可用和负载均衡。可以使用第三方软件如 Nginx 或 LVS 来实现。


[*]读写分离:读写分离是指将读和写操作分离到不同的数据库中,可以提高数据库的性能和稳定性。PHP 框架 ThinkPHP 中支持读写分离。


[*] 第一步:在数据库配置文件中定义主库和从库的连接参数;
点击查看代码// 主库配置
'db_config' => [
    'type'   => 'mysql',
    'hostname' => 'localhost',
    'database' => 'mydatabase',
    'username' => 'root',
    'password' => '123456',
    'hostport' => '3306',
    'params'   => [
      \PDO::ATTR_PERSISTENT => true,
    ],
],

// 从库配置
'db_config_read' => [
    'type'   => 'mysql',
    'hostname' => 'localhost',
    'database' => 'mydatabase',
    'username' => 'readonly',
    'password' => 'readonlypwd',
    'hostport' => '3306',
    'params'   => [
      \PDO::ATTR_PERSISTENT => true,
    ],
],

[*] 第二步:定义一个数据库操作类,用于连接主库或从库
点击查看代码use think\db\Connection;

class Db extends Connection
{
    public function __construct($config = [])
    {
      if (isset($config['is_master']) && $config['is_master'] === true) {
            $this->connect($config);
      } else {
            $this->connect($config, true);
      }
    }
}

[*] 第三步:在需要读写分离的地方,通过实例化Db类来连接数据库
点击查看代码use app\common\model\User;
use app\common\model\Db;

// 连接主库
$userModel = new User(new Db(config('db_config', [], false)));

// 连接从库
$userModel = new User(new Db(config('db_config_read', [], false)));

[*] 补充:主从库之间的数据同步需要通过第三方工具实现。在写入数据后,需要在主库和从库之间进行同步,否则在从库上可能无法查询到最新写入的数据。部分需要严格控制数据一致性的场景,例如金融、医疗等领域,读写分离可能不是最佳的解决方案,需要使用主从复制或者双主架构来实现数据同步和高可用。


[*]多数据中心:多数据中心是指将数据分布在多个地理位置的数据中心中,可以提高数据的可用性和可靠性。PHP 框架 Symfony 中支持多数据中心架构。
方案一:使用Doctrine ORM框架以及其提供的分布式事务支持。通过使用分布式事务,可以在多个数据中心之间实现数据的同步和一致性。此外,可以使用Symfony的事件和消息系统,实现跨数据中心的异步通信。
方案二:使用Symfony Messenger组件,该组件提供了一个灵活的消息传递系统。可以使用该组件来实现数据的异步同步和处理。同样地,可以通过事件和消息传递来实现跨数据中心的通信。
10,安全架构设计

1),身份认证:使用 PHP 语言和框架(如 Laravel 或 Yii2)实现基于角色的访问控制(RBAC)系统,包括用户登录、注册、找回密码等功能,使用加盐哈希加密用户密码,保护用户隐私。

基于 session 的身份认证:通过保存用户的认证状态信息在服务器端的 session 中,判断用户是否已经登录。通常会在登录时设置 session,注销时删除 session。
基于 cookie 的身份认证:通过将用户的认证状态信息保存在客户端的 cookie 中,判断用户是否已经登录。与 session 方式相比,可以减轻服务器的压力,但需要注意 cookie 安全问题。
基于 token 的身份认证:通过给用户分配一个唯一的 token,用于标识用户身份和验证用户身份。通常会在用户登录时生成 token,并在后续的请求中携带 token 进行身份验证。
基于 OAuth2.0 的身份认证:OAuth2.0 是一种授权协议,可以用于实现第三方授权登录。用户可以通过第三方应用程序进行登录认证,同时保护用户的隐私和安全。
基于 OpenID Connect 的身份认证:OpenID Connect 是一种基于 OAuth2.0 的身份认证协议,可以用于实现单点登录和用户身份认证。用户可以通过 OpenID Connect 进行跨应用程序的身份认证。
基于 SAML 的身份认证:SAML 是一种基于 XML 的身份认证协议,可以用于实现企业间的单点登录和用户身份认证。用户可以通过 SAML 进行跨组织的身份认证。
实例:

a,CAS(Central Authentication Service):一个开源的单点登录协议和实现,它通过一个中心认证服务器来认证用户身份,其他系统可以通过 CAS 客户端库来与 CAS 服务器进行交互。
1.安装phpCAS客户端》》2.配置CAS客户端》》3.CAS登录验证》》4.CAS注销
点击查看代码//1.安装phpCAS客户端
composer require jasig/phpcas
//2.配置CAS客户端
phpCAS::client(CAS_VERSION_2_0, 'cas.server.com', 443, 'cas');
phpCAS::setNoCasServerValidation();
//其中:
//CAS_VERSION_2_0表示使用CAS2.0协议进行认证。
//cas.server.com是CAS服务器的域名或IP地址。
//443是CAS服务器的端口号。
//cas是CAS服务器的上下文路径。
//setNoCasServerValidation()表示不验证CAS服务器的SSL证书,生产环境应该验证。

//3.CAS登录验证
phpCAS::client(CAS_VERSION_2_0, 'cas.server.com', 443, 'cas');
phpCAS::setNoCasServerValidation();
phpCAS::forceAuthentication();
//其中,forceAuthentication()会检查用户是否已经登录,如果没有登录,则会重定向到CAS服务器的登录页面进行登录。
//4.CAS注销
phpCAS::client(CAS_VERSION_2_0, 'cas.server.com', 443, 'cas');
phpCAS::setNoCasServerValidation();
phpCAS::logout();
//其中,logout()会向CAS服务器发送注销请求,并重定向到CAS服务器的注销页面。 b,JWT:使用 Firebase 的 JWT 库来生成和验证 JWT。在 generateToken 函数中,我们设置了 token 的有效期为 1 小时,并将用户 ID 存入了 token 的 sub 字段。在 validateToken 函数中,我们使用 JWT::decode 函数验证了 token 是否正确,并返回了 token 中存储的用户 ID。
点击查看代码
页: [1]
查看完整版本: PHP 并发方案建议