aex/php-async

基于 PHP 将文件异步发送到服务器

1.3.0 2019-04-30 09:27 UTC

This package is auto-updated.

Last update: 2024-09-05 03:25:27 UTC


README

license LICENSE

介绍

php-async 是一个基于 PHP 开发的工具,方便开发者直接在本地调试远程 测试服务器 代码。

特性

  • 使用简单
  • 可配置
  • 使用 socket 通讯

安装

composer require aex/php-async ^1.0.0 -vvv

使用

服务端:(async_server.php)

<?php
require "../vendor/autoload.php";
use Aex\PhpAsync\PhpAsync;

$config = []; // 下面会说明各配置项
$p = new PhpAsync($config);
$p->fireServer();

php async_server.php

客户端 (async_client.php)

<?php
require "../vendor/autoload.php";
use Aex\PhpAsync\PhpAsync;

$config = []; // 下面会说明各配置项
$p = new PhpAsync($config);
$p->fireClient();

php async_client.php

配置

服务端

$config = [
	'ip' => '0.0.0.0', // 监听的ip
	'port' => 8313, // 监听的端口
	'server-async-path' => '/code/test_code/', // 服务端同步目录的绝对路径,以/(DIRECTORY_SEPARATOR)结尾
	'duplicate_name_suffix' => '.pasync', // 副本文件后缀(生成的临时文件,应避免是你项目会用到的后缀)
	'command_separator' => '(::)' // 命令分隔符
];

客户端

$config = [
	'ip' => '127.0.0.1', // 服务端ip
	'port' => 8313, // 服务端端口
	'client-async-path' => '/code/test_code/', // 客户端同步目录的绝对路径,以/(DIRECTORY_SEPARATOR)结尾
	'duplicate_name_suffix' => '.pasync', // 副本文件后缀(生成的临时文件,应避免是你项目慧勇斗啊)
	'command_separator' => '(::)' // 命令分隔符
];

说明: 此项目应避免在生产环境中使用,除非你非常了解可能存在的问题,并能迅速恢复被修改的文件。不配置任何项目直接运行,项目会同步 vendor/aex/php-async/test_code/下的 client 和 server 目录。你可以尝试修改client下的文件看server目录的结果。在 php-async 运行之前默认认为服务端代码和客户端代码是一致的,只会检测到开始运行后增量的变化。

使用场景举例

在开发微信项目时,很多 API 只能在外部服务器测试使用,在测试服务器直接修改代码又不能像在本地 IDE 那样方便。如果服务器使用 git,本地代码每次修改都要提交并推送,即使只是修改一行调试代码。服务器同时需要拉取代码,即使配置钩子,也要付出一定的成本。使用 php-async 可以让你每次本地修改后几乎都能立即(间隔5秒)在测试环境中看到调试效果。调试完成后,你可以使用 git revert 撤销代码。

已知BUG

由于精力有限,次要 BUG 将逐步修复

  • 同步修改的文件最后一行都多一个换行
  • 删除目录,服务端只会把下面的所有文件删除,留下空目录

许可证

php-async 基于 MIT 许可协议 (MIT)