# 函数列表
swoole除了网络通信相关的函数外,还提供了一些获取系统信息的函数供PHP程序使用。
[TOC=2,3]
## swoole_set_process_name
用于设置进程的名称。修改进程名称后,此函数接受一个字符串参数。 此函数与PHP5.5提供的cli_set_process_title功能是相同的。但swoole_set_process_name可用于PHP5.2之上的任意版本。swoole_set_process_name兼容性比cli_set_process_title要差,如果存在cli_set_process_title函数则优先使用cli_set_process_title。
**功能描述**:设置进程的名称
**函数原型**:
```php
void swoole_set_process_name(string $name);
```
**返回**:无<br>
**参数说明**:<br>
| 参数 | 说明 |
| -------- | -------- |
| string name | 进程名称 |
**说明**:<br>
修改进程名称后,通过ps命令看到的将不再是php your_file.php,而是设定的字符串<br>
示例代码:
```
swoole_set_process_name("swoole server");
var_dump($argv);
sleep(1000);
```
>swoole_set_process_name在1.6.3版本提供
>在onStart回调中执行此函数,将修改主进程的名称。在onWorkerStart中调用将修改worker子进程的名称。
如何为Swoole Server重命名各个进程名称
* 在swoole_server_create之前修改为manager进程名称
* onStart调用时修改为主进程名称
* onWorkerStart修改为worker进程名称
>1.6.12后增加了onManagerStart事件回调,可以在这里设置管理进程的名称
>低版本Linux内核和Mac OSX不支持进程重命名
## swoole_version
**功能描述**:获取swoole扩展的版本号<br>
**函数原型**:<br>
```php
string swoole_version();
```
**返回**:swoole扩展的版本号<br>
**样例**:
```php
echo swoole_version();
```
## swoole_strerror
**功能描述**:将标准的Unix Errno错误码转换成错误信息<br>
**函数原型**:<br>
```php
string swoole_strerror(int $errno);
```
**返回**:转化后的错误信息<br>
**参数说明**:<br>
| 参数 | 说明 |
| -------- | -------- |
| int errno | errno错误码 |
**样例**:
```php
echo swoole_strerror( $errno );
```
## swoole_errno
**功能描述**:获取最近一次系统调用的错误码<br>
**函数原型**:<br>
```php
int swoole_errno();
```
**返回**:最近一次系统调用的错误码<br>
**参数说明**:无<br>
**说明**:<br>
错误码的值与操作系统有关。可是使用swoole_strerror将错误转换为错误信息。<br>
**样例**:
```php
echo swoole_strerror(swoole_errno());
```
## swoole_get_local_ip
**功能描述**:此函数用于获取本机所有网络接口的IP地址<br>
**函数原型**:<br>
```php
array swoole_get_local_ip();
$result = array("eth0" => "192.168.1.100");
```
**返回**:以interface名称为key的关联数组<br>
**参数说明**:无<br>
**说明**:<br>
目前只返回IPv4地址,返回结果会过滤掉本地loop地址127.0.0.1<br>
返回结果样例array("eth0" => "192.168.1.100");
**样例**:
```php
var_dump(swoole_get_local_ip());
```
* 目前只返回IPv4地址,返回结果会过滤掉本地loop地址127.0.0.1。
* 结果数组是以interface名称为key的关联数组。比如 array("eth0" => "192.168.1.100")
* 此函数会实时调用ioctl系统调用获取接口信息,底层无缓存
## swoole_clear_dns_cache
清除swoole内置的DNS缓存,对swoole_client和swoole_async_dns_lookup 有效。
```
function swoole_clear_dns_cache();
```
## swoole_get_local_mac
获取本机网卡Mac地址。
```
function swoole_get_local_mac() : array;
```
调用成功返回所有网卡的Mac地址
```
array(4) {
["lo"]=>
string(17) "00:00:00:00:00:00"
["eno1"]=>
string(17) "64:00:6A:65:51:32"
["docker0"]=>
string(17) "02:42:21:9B:12:05"
["vboxnet0"]=>
string(17) "0A:00:27:00:00:00"
}
```
>在1.9.18或更高版本可用
- swoole简介
- swoole功能概述
- 序章
- 开发必读
- 1 环境搭建
- 1.1 环境搭建
- 1.2 搭建Echo服务器
- 2 初识Swoole
- 2.1 Worker进程
- 2.2 TaskWorker进程
- 2.3 Timer定时器
- 2.4 Process进程
- 2.5 Table内存表
- 2.6 多端口监听
- 2.7 sendfile文件支持
- 2.8 SSL支持
- 2.9 热重启
- 2.10 http_server
- 附录*server配置
- 附录*server函数
- 附录*server属性
- 附录*server回调函数
- 附录*server高级特性
- 心跳检测
- 3 Swoole协议
- 3.1 EOF协议
- 3.2 固定包头协议
- 3.3 Http协议
- 3.4 WebSocket协议
- 3.5 MTQQ协议
- 内置http_server
- 内置websocket_server
- Swoole\Redis\Server
- 4 Swoole异步IO
- 4.1 AsyncIO
- 异步文件系统IO
- swoole_async_readfile
- swoole_async_writefile
- swoole_async_read
- swoole_async_write
- 5 swoole异步客户端
- ws_client
- http_client
- mysql_client
- redis_client
- tcp_client
- http2_client
- 6 swoole协程
- Swoole\Coroutine\Http\Client
- Swoole\Coroutine\MySQL
- Swoole\Coroutine\Redis
- Coroutine\PostgreSQL
- Swoole\Coroutine\Client
- Swoole\Coroutine\Socket
- Swoole\Coroutine\Channel
- Coroutine
- Swoole\Coroutine::create
- Swoole\Coroutine::resume
- Swoole\Coroutine::suspend
- Swoole\Coroutine::sleep
- Coroutine::getaddrinfo
- Coroutine::gethostbyname
- swoole_async_dns_lookup_coro
- Swoole\Coroutine::getuid
- getDefer
- setDefer
- recv
- Coroutine::stats
- Coroutine::fread
- Coroutine::fget
- Coroutine::fwrite
- Coroutine::readFIle
- Coroutine::writeFIle
- Coroutine::exec
- 7 swoole_process
- process::construct
- process::start
- process::name
- process::signal
- process::setaffinity
- process::exit
- process::kill
- process::daemon
- process->exec
- process::wait
- process::alarm
- 8 swoole定时器
- swoole_timer_tick
- swoole_timer_after
- swoole_timer_clear
- 9 swoole_event
- swoole_event_add
- swoole_event_set
- swoole_event_del
- swoole_event_wait
- swoole_event_defer
- swoole_event_write
- swoole_event_exit
- swoole提供的function
- 常见问题
- 客户端链接失败原因
- 如何设置进程数
- 如何实现异步任务
- 如何选择swoole三种模式
- php中哪些函数是阻塞的
- 是否可以共用1个redis或mysql连接
- 如何在回调函数中访问外部的变量
- 为什么不要send完后立即close
- 不同的Server程序实例间如何通信
- MySQL的连接池、异步、断线重连
- 在php-fpm或apache中使用swoole
- 学习Swoole需要掌握哪些基础知识
- 在phpinfo中有在php-m中没有
- 同步阻塞与异步非阻塞选择
- CURL发送POST请求服务器端超时
- 附录
- 预定义常量
- 内核参数调优
- php四种回调写法
- 守护进程程序常用数据结构
- swoole生命周期
- swoole_server中内存管理机制
- 使用jemalloc优化swoole内存分配性能
- Reactor、Worker、Task的关系
- Manager进程
- Swoole的实现
- Reactor线程
- 安装扩展
- swoole-worker手册
- swoole相关开源项目
- 写在后面的话
- 版本更新记录
- 4.0