# 函數列表
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