# HelloSwoole *** 本文假设你已经有了 Linux 操作系统的 PHP 环境,并且符合上一篇文章的环境要求,强烈推荐使用 Vagrant 来搭建开发环境 除了可以按照文中搭建虚拟机或VPS安装环境 外,也推荐你直接使用[新浪云](http://t.cn/RbsUCkH)来部署环境,更方便快捷,注册账号赠送的云豆足够免费使用到学习完整本书的内容。 ### 安装 Swoole PECL 拓展 可以通过 pecl 命令或者通过源码包编译安装,本文采用 pecl 命令来安装 Swoole 在命令行输入 ~~~ $ > pecl install swoole ~~~ 安装 Swoole PECL 拓展,执行命令后通过`php -m`命令来检查 Swoole 是否安装成功,如果返回的拓展列表中包含`swoole`则表明已经安装成功,也可以通过`phpinfo`来检查 Swoole 是否安装成功。 ### 安装 ThinkPHP5 框架 #### 1.安装 Composer 如果已经安装了 Composer 可以跳过本步骤,但是请确定通过`composer self-update`命令来确保已经使用了最新版本的 Composer 使用以下命令可以直接通过 Composer 官网下载 Composer.phar 并自动安装到`/usr/local/bin/`目录下 ~~~ $ > php -r "readfile('https://getcomposer.org/installer');" | php -- --install-dir=/usr/local/bin/ --filename=composer $ > composer self-update ~~~ 如果以上安装过程极慢的话,可以尝试用以下方式通过 Composer 国内镜像来安装。 ~~~ $ > php -r "readfile('http://install.phpcomposer.com/installer');" | php -- --install-dir=/usr/local/bin/ --filename=composer $ > composer config -g repo.packagist composer https://packagist.phpcomposer.com $ > composer self-update ~~~ #### 2.安装 ThinkPHP5 框架 使用以下命令把最新版本的 ThinkPHP5 框架安装到当前目录下的 thinkSwooleFirst 文件夹中 ~~~ $ > composer create-project topthink/think thinkSwooleFirst --prefer-dist ~~~ ### 安装 think-swoole Composer 包 把命令行目录切换到 thinkSwooleFirst 目录,通过 Composer 安装 think-swoole ~~~ $ > composer require topthink/think-swoole ~~~ > 安装 think-swoole Composer 包之前必须先安装好 Swoole PECL 拓展 ### HelloSwoole 当环境全部搭建完成后,我们在`application/index/controller`目录下建立`Demon.php`文件,用来书写 Swoole 与 ThinkPHP5 的 TCP 服务器的 Hello World ~~~ <?php namespace app\index\controller; // 必须 use 并继承 \think\swoole\Server 类 use think\swoole\Server; class Demon extends Server { // 监听所有地址 protected $host = '0.0.0.0'; // 监听 9501 端口 protected $port = 9501; // 指定运行模式为多进程 protected $mode = SWOOLE_PROCESS; // 指定 socket 的类型为 ipv4 的 tcp socket protected $sockType = SWOOLE_SOCK_TCP; // 配置项 protected $option = [ /** * 设置启动的worker进程数 * 业务代码是全异步非阻塞的,这里设置为CPU的1-4倍最合理 * 业务代码为同步阻塞,需要根据请求响应时间和系统负载来调整 */ 'worker_num' => 4, // 守护进程化 'daemonize' => false, // 监听队列的长度 'backlog' => 128 ]; /** * 收到信息时回调函数 * @param \swoole_server $server swoole_server对象 * @param $fd TCP客户端连接的文件描述符 * @param $from_id TCP连接所在的Reactor线程ID * @param $data 收到的数据内容 */ public function onReceive(\swoole_server $server, $fd, $from_id, $data) { $server->send($fd, 'onReceive: ' . $data); } } ~~~ 以上代码即使用 ThinkPHP5 和 Swoole 完成了相对简单的 TCP 服务器,接下来就可以运行服务器 使用以下命令即可启动 TCP 服务器 ~~~ $ > php public/index.php index/Demon/start ~~~ 我们可以通过修改配置项`daemonize`为false,让程序不使用守护进程,更方便我们的调试 如果配置项`daemonize`为true,也可以使用守护进程方式我们也可以使用`lsof`工具来检测,端口是否处于正常状态 ~~~ $ > lsof -i:9501 ~~~ 当确认程序正常运行后,使用`telnet`工具来连接 TCP 服务器,稍后的文章中我们也会讲述如果使用 swoole 的 TCP 客户端来连接 TCP 服务器 ~~~ telnet 127.0.0.1 9501 ~~~ 输入`hello`后会得到以下结果 ~~~ onReceive: hello ~~~