English | 中文
Yet Another Swoole Debugger.
You'll need to install the Boost library first.
macos:
brew install boost
ubuntu:
apt-get install libboost-all-dev
centos:
yum install boost boost-devel
phpize --clean && \
phpize && \
./configure && \
make clean && \
make && \
make install
set the ini file:
zend_extension=yasd.so
see the extension info:
php --ri yasd
zend_extension=yasd
yasd.debug_mode=remote
yasd.remote_host=127.0.0.1
yasd.remote_port=9000
All command supports fuzzy matching of priorities.
set the ini file:
zend_extension=yasd
yasd.debug_mode=cmd
php -e test.php
l
list source code
b absolute-file-path lineno
This will also save the breakpoint information in the cache file -- .breakpoints_file.log
You can change this file name by the ini file, e.g.
yasd.breakpoints_file="yasd.log"
If the cache file exists, the breakpoints in the file are automatically loaded when debug is started.
d absolute-file-path lineno
If a breakpoint is set or deleted without specifying absolute-file-path
, It will set breakpoint in the current file.
We can monitor the variable changes or conditions, for example:
watch a
watch a > 10
watch name == swoole
r
n
s
f
bt
show all breakpoints:
i
c
q
p
variable name do not need to have $
, for example:
p a
p this
p this->prop
le
When using yasd
, if the framework starts slowly (most of the time it's because the framework is scanning a lot of files), you can execute the following command.
composer dump-autoload -o
Then modify the following configuration config/config.php
:
'scan_cacheable' => env('SCAN_CACHEABLE', true)
We did not find a slow start problem.
We did not find a slow start problem.
We did not find a slow start problem.
We did not find a slow start problem.
- No absolute path to the file is used
- The breakpoint is not a valid line, such as a function declaration, blank line, etc
- The code is generated with proxy classes, such as Hyperf. So you need to set breakpoints in the proxy class.