linux线上程序问题调试命令

linux线上程序问题调试命令,第1张

根据这些可以查看系统调用的完整性,比如说服务器连接数一直涨,说明fd没有close,close调用在上边有缺失

strace -t -T -v -f -p 16705 -Te write 只看write系统调用

sudo gcore xxpid 生成dump文件

sudo dlv core binfile core.xxxx 调试coredump文件,查看调用栈、goroutines

查看系统级别日志 /var/log/messages

messages 日志是核心系统日志文件。它包含了系统启动时的引导消息,以及系统运行时的其他状态消息。IO 错误、网络错误和其他系统错误都会记录到这个文件中。其他信息,比如某个人的身份切换为 root,也在这里列出。如果服务正在运行,比如 DHCP 服务器,您可以在 messages 文件中观察它的活动。通常,/var/log/messages 是您在做故障诊断时首先要查看的文件。

tcpdump -i lo -nnA 'port 7076' and 'tcp[13] &4 != 0 ' 抓rst包,发送给7076端口或者是7076端口发出去的

mac osx系统:sudo tcpdump -i lo0 -nnA 'port 3000'

php异步调试和线上调试网站程序

php异步调试和线上调试网站程序既方便网站程序错误调试,又不影响网站的正常运行的调试方法。下面是我为大家带了的php异步调试和线上调试网站程序,欢迎阅读。

php异步调试和线上调试网站程序

   代码如下

//ini_set('error_reporting',E_ALL ^ E_NOTICE)//显示所有除了notice类型的错误信息

ini_set('error_reporting',E_ALL)//显示所有错误信息

ini_set('display_errors',off)//禁止将错误信息输出到输出端

ini_set('log_errors',On)//开启错误日志记录

ini_set('error_log','C:/phpernote')//定义错误日志存储位置

另外附加两句比较常用的排除错误信息的PHP语句:

代码如下

@ini_set('memory_limit','500M')//设置程序可占用最大内存为500MB

@ini_set('max_execution_time','180')//设置允许程序最长的执行时间为180秒

补充

die()和exit()也是我们常用的php调试一个方法

die()和exit()函数都有终止线程的作用,是php断点调试需要使用的最主要的函数,它们也是php程序员使用非常频繁的函数。然而两者又有什么区别呢?在程序调试时需要注意什么问题呢?

die()函数一般与“or”一并使用,写作“or die()”,经常看到这样的语句:

代码如下

$file = fopen($filename, 'r') or die("抱歉,无法打开: $filename")

or在这里是这样理解的,因为在PHP中并不区分数据类型,所以$file既可以是int也可以bool,所以这样的语句不会报错。但其处理过程可能有些朋友不大明白。其实在大多数的语言中, bool or bool这样的语句中,如果前一个值为真后一个值就不会再判断了。这里也是的,所以如果fopen函数执行正确的话,会返回一个大于0的int值(这其实就是"真"),后面的语句就不会执行了。如果fopen函数执行失败,就会返回false,那么就会判断后面的表达式是否为真了。结果执行了die()之后,不管返回什么,程序都已经停止执行了,并且显示指定的.出错信息,也就达到了调试的目的。就这样。

实际上,die和exit是等价的,都是用来终止当前脚本。

php手册对两者的解释如是说:

exit() 函数输出一条消息,并退出当前脚本。该函数是 die() 函数的别名。

die() 函数输出一条消息,并退出当前脚本。该函数是 exit() 函数的别名。

实例:

代码如下

<?php $site = "http://www.111cn.net/"fopen($site,"r") or exit("Unable to connect to $site")?>

<?php $site = "http://www.111cn.net/"fopen($site,"r") or die("Unable to connect to $site")?>

var_dump()和print_r()

var_dump -- 打印变量的相关信息

void var_dump ( mixed expression [, mixed expression [, ...]] )

此函数显示关于一个或多个表达式的结构信息,包括表达式的类型与值。数组将递归展开值,通过缩进显示其结构。

提示: 为了防止程序直接将结果输出到浏览器,可以使用输出控制函数(output-control functions)来捕获此函数的输出,并把它们保存到一个例如 string 类型的变量中。

代码如下

<?php

$a = array (1, 2, array ("a", "b", "c"))

var_dump ($a)

$b = 3.1

$c = TRUE

var_dump($b,$c)

?>

var_dump()可以输出多个变量,如:var_dump($b,$c)

print_r -- 打印关于变量的易于理解的信息

bool print_r ( mixed expression [, bool return] )

注: 参数 return 是在 PHP 4.3.0 的时候加上的

print_r() 显示关于一个变量的易于理解的信息。如果给出的是 string、integer 或 float,将打印变量值本身。如果给出的是 array,将会按照一定格式显示键和元素。object 与数组类似。

记住,print_r() 将把数组的指针移到最后边。使用reset() 可让指针回到开始处。

代码如下

<pre>

<?php

$a = array ('a' =>'apple',

'b' =>'banana',

'c' =>array ('x','y','z'))

print_r ($a)

?>

</pre>

上边的代码将输出:

<pre>Array ( [a] =>apple [b] =>banana [c] =>Array ( [0] =>x [1] =>y [2] =>z ) ) </pre>

如果想捕捉 print_r() 的输出,可使用 return 参数。若此参数设为 TRUE,print_r() 将不打印结果(此为默认动作),而是返回其输出。

例子:return 参数示例

代码如下

<?php

$b = array ('m' =>'monkey',

'foo' =>'bar',

'x' =>array ('x', 'y', 'z'))

$results = print_r ($b, true)//$results 包含了 print_r 的输出结果

?>

注: 如果想在 PHP 4.3.0 之前的版本中捕捉 print_r() 的输出,可使用输出控制函数。

注: 在 PHP 4.0.4 之前的版本中,如果给出的 array 或 object 包含了直接或间接指向自身的引用,print_r() 将永远继续下去。print_r($GLOBALS) 就是一个例子,因为 $GLOBALS 自身即是全局变量,其包含了指向自身的引用。

下面的几个函数可以让你随时查看程序中任何变量的类型及其值。

代码如下

function ss_array_as_string (&$array, $column = 0) {

$str = "Array(

n"

while(list($var, $val) = each($array)){

for ($i = 0$i <$column+1$i++){

$str .= "&nbsp&nbsp&nbsp&nbsp"

}

$str .= $var. ==>

$str .= ss_as_string($val, $column+1)."

n"

}

for ($i = 0$i <$column$i++){

$str .= "&nbsp&nbsp&nbsp&nbsp"

}

return $str.)

}

function ss_object_as_string (&$object, $column = 0) {

if (empty($object->classname)) {

return "$object"

}

else {

$str = $object->classname."(

n"

while (list(,$var) = each($object->persistent_slots)) {

for ($i = 0$i <$column$i++){

$str .= "&nbsp&nbsp&nbsp&nbsp"

}

global $$var

$str .= $var. ==>

$str .= ss_as_string($$var, column+1)."

n"

}

for ($i = 0$i <$column$i++){

$str .= "&nbsp&nbsp&nbsp&nbsp"

}

return $str.)

}

}

function ss_as_string (&$thing, $column = 0) {

if (is_object($thing)) {

return ss_object_as_string($thing, $column)

}

elseif (is_array($thing)) {

return ss_array_as_string($thing, $column)

}

elseif (is_double($thing)) {

return "Double(".$thing.")"

}

elseif (is_long($thing)) {

return "Long(".$thing.")"

}

elseif (is_string($thing)) {

return "String(".$thing.")"

}

else {

return "Unknown(".$thing.")"

}

}


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/yw/11712534.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-18
下一篇 2023-05-18

发表评论

登录后才能评论

评论列表(0条)

保存