linux-command/c/strace.html

709 lines
155 KiB
HTML
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="renderer" content="webkit">
<meta http-equiv="X-UA-Compatible" content="IE=edge, chrome=1">
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no"/>
<meta name="description" content="strace:跟踪系统调用和信号 - 最专业的Linux命令大全内容包含Linux命令手册、详解、学习值得收藏的Linux命令速查手册。">
<meta name="keywords" content="Linux,Command,命令大全,Linux命令手册,strace,跟踪系统调用和信号">
<title>strace 命令Linux strace 命令详解:跟踪系统调用和信号 - Linux 命令搜索引擎</title>
<link rel="shortcut icon" href="../img/favicon.ico">
<link rel="stylesheet" type="text/css" href="../css/index.css?v=1740369652603">
<script src="../js/dark-mode.min.js"></script>
<script type="module" src="../js/github-corners.js"></script>
</head>
<body>
<dark-mode permanent dark="Dark" light="Light" style="position: fixed;left: 10px;top: 8px; z-index: 999;"></dark-mode>
<github-corners target="__blank" z-index="999" position="fixed" href="https://github.com/jaywcjlove/linux-command"></github-corners>
<div class="header header_list">
<div class="header_inner">
<div class="logo">
<a href="/">
<svg width="183px" height="48px" viewBox="0 0 183 48" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"> <!-- kenny wang <wowohoo@qq.com> https://github.com/jaywcjlove --> <title>logo</title> <desc>Linux Command Logo. https://github.com/jaywcjlove</desc><g stroke="none" stroke-width="1" fill="none" fill-rule="evenodd"> <g transform="translate(-576.000000, -261.000000)" fill="currentColor"> <g id="logo" transform="translate(576.000000, 261.000000)"> <path d="M20.4917792,0.000336524232 C20.1886146,-0.000100520225 19.8723998,0.0124863601 19.542641,0.0387964365 C11.2083649,0.710004944 13.4186692,9.51473754 13.2949769,12.4631618 C13.1427718,14.6193207 12.7056049,16.3185233 11.2226825,18.426428 C9.48047033,20.4982285 7.02763261,23.8514609 5.86566251,27.3420607 C5.3172635,28.9894735 5.05630425,30.6686289 5.29730805,32.2578406 C5.22181299,32.325447 5.14994103,32.3962788 5.08160039,32.469239 C4.57008792,33.0153217 4.19213625,33.6769851 3.77100458,34.1224689 C3.37755968,34.5149436 2.81698897,34.6642292 2.20097918,34.8852382 C1.58472464,35.1063477 0.908127379,35.4323261 0.497432332,36.2204265 C0.497432332,36.2204265 0.497432332,36.2207368 0.49712203,36.2207368 C0.496684986,36.222048 0.495373852,36.2233591 0.494936808,36.2246702 L0.494936808,36.2246702 C0.123151829,36.919077 0.233680372,37.718746 0.347224522,38.4596325 C0.460773043,39.2004972 0.575720105,39.9005856 0.423139144,40.3755699 C-0.0645762474,41.7086473 -0.126850712,42.6307542 0.216491414,43.2996202 C0.560563403,43.9698759 1.2680029,44.2657113 2.06756262,44.432706 C3.66668644,44.7666954 5.83232039,44.6837094 7.53908826,45.5883128 L7.68579097,45.3115063 L7.54060917,45.5891344 C9.36778716,46.5444437 11.2201913,46.8837519 12.698079,46.5461831 C13.7695766,46.3014513 14.6393781,45.6634363 15.0860725,44.6816946 C16.2420201,44.6760567 17.5104717,44.1864315 19.5423657,44.0745568 C20.9208039,43.9635213 22.6427241,44.564051 24.6233484,44.4540775 C24.6751207,44.6689591 24.750052,44.8756375 24.8526175,45.0720452 C24.8539287,45.0742305 24.8548028,45.0759786 24.8556769,45.0780328 C25.6234722,46.6133699 27.0500902,47.3156173 28.570428,47.1956355 C30.0927718,47.075492 31.711331,46.1778551 33.0196848,44.6208231 L32.7798304,44.4192582 L33.0215204,44.618616 C34.2685787,43.1065034 36.3384911,42.4794975 37.7110118,41.6516741 C38.3972721,41.2377581 38.9541192,40.7194802 38.9971462,39.966706 C39.0401514,39.2142991 38.5984218,38.3711223 37.5826868,37.2436088 L37.5823765,37.2432985 C37.5820662,37.2428614 37.5815024,37.2424244 37.5810654,37.2415503 C37.2473295,36.8644028 37.0881185,36.1654026 36.91702,35.4210285 C36.7460395,34.6771089 36.5551865,33.8746254 35.9444344,33.3545687 L35.9444344,33.3545687 C35.9431233,33.3532575 35.9418121,33.3523835 35.940938,33.3515094 L35.940938,33.3515094 C35.6978714,33.1397045 35.4452772,32.9959518 35.1909042,32.8993694 C36.0400422,30.3810493 35.7068789,27.8734149 34.8497254,25.6073831 C33.7977638,22.8263338 31.9611937,20.4030752 30.5585738,18.7453569 C28.9885703,16.7650385 27.4529665,14.8848863 27.4832187,12.1079627 C27.5299825,7.86977213 27.9494053,0.0101787654 20.4914689,0 L20.4917792,0.000336524232 Z M21.5014393,6.5296802 C21.9246338,6.5296802 22.2860696,6.65372652 22.6573476,6.92320377 C23.0345213,7.1969553 23.3062494,7.53965497 23.5252523,8.01821865 C23.7401952,8.48461502 23.843613,8.94086321 23.8537568,9.48229573 C23.8537568,9.49649968 23.8537568,9.50864951 23.8576902,9.52285346 C23.8616236,10.0784681 23.7664397,10.5509481 23.5555483,11.0335676 C23.4352081,11.3089536 23.2970146,11.540089 23.1316064,11.7401941 C23.0754506,11.7132285 23.0171357,11.6873118 22.9566488,11.6624396 L22.9566488,11.6624396 C22.5373789,11.4828667 22.2157491,11.3685884 21.9476879,11.2755722 C22.044856,11.158772 22.1257661,11.0202464 22.1969169,10.8470719 C22.3043949,10.5854877 22.3571155,10.3299784 22.367255,10.025813 C22.367255,10.0136631 22.3711884,10.00348 22.3711884,9.98931975 C22.3772633,9.69732161 22.3387597,9.44789596 22.2535753,9.19239103 C22.1643483,8.92472316 22.0507955,8.73208707 21.886541,8.57188842 C21.722291,8.41168541 21.5580366,8.33869024 21.361336,8.33260221 C21.3521143,8.33216517 21.3429364,8.33216517 21.3338459,8.33216517 C21.1488275,8.33260221 20.9881699,8.39616596 20.8219532,8.53532529 C20.6475593,8.6813331 20.5177834,8.86788115 20.4103054,9.12744186 C20.3028318,9.38699819 20.2501067,9.64452664 20.239976,9.95073309 C20.2377908,9.96288293 20.2377908,9.97306607 20.2377908,9.9852159 C20.2342945,10.1535261 20.2449584,10.307711 20.2709188,10.4574381 C19.8923378,10.2687966 19.535574,10.1401875 19.2007499,10.0604924 C19.181651,9.91570835 19.1706375,9.76629596 19.1670975,9.61007442 L19.1670975,9.56750629 C19.1610225,9.01391519 19.2522643,8.53941165 19.4651836,8.05679657 C19.6781029,7.57417712 19.9417194,7.2274173 20.3128051,6.94555422 C20.6838952,6.66369114 21.0488973,6.53391079 21.4808239,6.52985938 L21.5010154,6.52985938 L21.5014393,6.5296802 Z M15.7091362,6.98827969 C15.9898804,6.98871673 16.2410892,7.0827381 16.5009296,7.29023807 C16.7828014,7.51531597 16.9957164,7.80326271 17.1741616,8.20882685 C17.3526112,8.614391 17.4479175,9.01995077 17.4742757,9.49851445 L17.4742757,9.50244785 C17.4870374,9.70344023 17.485464,9.89263677 17.469643,10.0758677 C17.4141165,10.091645 17.3597045,10.1087334 17.3064069,10.1270762 C17.0036968,10.2312719 16.7369205,10.373272 16.5044085,10.5268101 C16.5271785,10.366205 16.5305437,10.2032486 16.5131057,10.0215605 C16.5109204,10.0114211 16.5109204,10.0032921 16.5109204,9.99319633 C16.4865771,9.75189098 16.435893,9.54911109 16.3507218,9.34429895 C16.2594713,9.131384 16.1580813,8.98132478 16.0242452,8.86573527 C15.9029566,8.76098882 15.7883592,8.71289208 15.6622806,8.71384046 C15.6492567,8.71384046 15.636058,8.71427751 15.6227281,8.71558864 C15.4807804,8.72773848 15.3631674,8.79669098 15.251638,8.93255936 C15.1401086,9.068419 15.0671091,9.23672919 15.0143884,9.4597792 C14.9616634,9.68284232 14.9474682,9.90184967 14.9697706,10.1532945 C14.9697706,10.1634339 14.9719558,10.1715629 14.9719558,10.1816586 C14.9962992,10.4249963 15.0449553,10.6277718 15.1321501,10.8325883 C15.2213771,11.0434797 15.3247905,11.1935346 15.4586266,11.3091153 C15.481047,11.3284764 15.5032139,11.3458708 15.525289,11.361399 C15.3860816,11.468536 15.3196072,11.5179308 15.2055298,11.6017559 C15.1323642,11.6554425 15.0452263,11.7193646 14.94395,11.7940162 C14.7230765,11.5871106 14.5507673,11.3270648 14.4001137,10.984671 C14.2216641,10.5791112 14.1263578,10.1735471 14.0979674,9.69498342 L14.0979674,9.69105002 C14.0716136,9.21249508 14.1182463,8.8008429 14.2500545,8.37500864 C14.3818627,7.94916563 14.5582845,7.6409444 14.813785,7.38745861 C15.06929,7.13399031 15.3268184,7.00623784 15.6370763,6.99001912 C15.6613322,6.98870799 15.6853347,6.98827095 15.709123,6.98827095 L15.7091362,6.98827969 Z M18.3434478,10.3083666 C18.9959552,10.3057443 19.7811624,10.5197693 20.731756,11.1309629 C21.3156605,11.5106715 21.7700031,11.5424053 22.8162176,11.9904939 L22.8175288,11.9909309 L22.8188399,11.991368 C23.322219,12.1979021 23.6176741,12.4671083 23.7620255,12.7505841 C23.906377,13.034073 23.9099039,13.3414857 23.7890786,13.6648724 C23.5474411,14.3116676 22.7761407,14.9923468 21.6937826,15.3303395 L21.6929085,15.3307766 L21.6920344,15.3312136 C21.1642857,15.5026793 20.7040867,15.8813302 20.1615484,16.1915706 C19.6190277,16.5017979 19.00512,16.7520102 18.1703739,16.7037212 C18.1703739,16.7037168 18.1703739,16.7037212 18.1703739,16.7037212 C17.4597396,16.6622893 17.0349499,16.4210539 16.650849,16.1123607 C16.2667437,15.8036631 15.9320245,15.4158517 15.4418966,15.1280491 L15.4405854,15.1271751 L15.4392743,15.126301 C14.6497885,14.6800742 14.2187709,14.163964 14.0834969,13.7165354 C13.9482185,13.2691068 14.075193,12.8871911 14.4668766,12.5936327 C14.9072645,12.2635986 15.2131825,12.0390976 15.4169632,11.8895453 C15.6194022,11.7409983 15.703625,11.685297 15.7680935,11.623394 C15.7684038,11.622957 15.7685305,11.622957 15.7689675,11.6225199 L15.7692735,11.6220829 C16.1001729,11.3088706 16.6276463,10.738226 17.4227569,10.4645313 C17.696421,10.3703264 18.001784,10.3095466 18.3435746,10.3081961 L18.3434478,10.3083666 Z M22.9062619,13.0069369 C22.6246829,13.0237631 22.3297828,13.1687002 21.9864013,13.3604054 C21.6430199,13.5521105 21.256878,13.7973406 20.8384079,14.0388338 C20.0014721,14.5218204 19.038047,14.9837283 18.0805918,14.9837283 C17.1216551,14.9837283 16.3555118,14.5408493 15.7808726,14.0854752 C15.4935509,13.8577838 15.2564149,13.6284404 15.0669561,13.4510265 C14.9722311,13.3623109 14.8900799,13.2867065 14.8134179,13.2276487 C14.7367734,13.1685909 14.6743853,13.1100357 14.5461303,13.1100357 L14.5400116,13.3795435 C14.5308337,13.4697233 14.5213935,13.4669437 14.5251084,13.4693999 C14.5310959,13.4733333 14.5608587,13.4835601 14.5955731,13.5103509 C14.6519344,13.5537495 14.7301609,13.6245375 14.8230067,13.7114832 C15.0086981,13.8853788 15.2554403,14.124464 15.5592255,14.3652012 C16.166796,14.8466668 17.0117515,15.3406363 18.0806093,15.3406363 C19.1509618,15.3406363 20.1636375,14.8403471 21.016875,14.3479598 C21.4434872,14.1017639 21.8309534,13.8560094 22.1604324,13.6720705 C22.4898897,13.4881185 22.7670895,13.3727781 22.9275766,13.3632068 L22.9062925,13.00695 L22.9062619,13.0069369 Z M23.8576858,14.2878093 C24.5685911,17.0901733 26.2220701,21.1378562 27.2848005,23.113201 C27.8496849,24.1612205 28.9735097,26.3878921 29.4590574,29.0706371 C29.7667148,29.0611969 30.1054855,29.1059065 30.4682673,29.1987042 C31.7377591,25.907589 29.3917525,22.3626165 28.3189832,21.375368 C27.8858722,20.9551061 27.8650557,20.7668098 28.0797669,20.7757081 C29.2436775,21.8049915 30.7716374,23.8752142 31.3275492,26.211938 C31.581035,27.2774436 31.6350799,28.3975886 31.3630809,29.5030663 C31.4961478,29.5583437 31.6312951,29.6184504 31.7682604,29.683286 C33.806037,30.6755779 34.5596721,31.5384567 34.1973186,32.716121 C34.0779748,32.7117506 33.960576,32.7126247 33.8460659,32.7152469 C33.8354021,32.7155572 33.8247819,32.715684 33.814118,32.716121 C34.1092104,31.7826203 33.4554837,31.0941179 31.7135031,30.305952 C29.9067264,29.5110511 28.4669839,29.5901387 28.2236507,31.2022427 C28.2080919,31.2867016 28.1955487,31.3727644 28.1860212,31.460029 C28.05104,31.506902 27.9153158,31.5667509 27.7792552,31.6412014 C26.9308557,32.1054213 26.4677896,32.9477371 26.2102393,33.9808403 C25.9529032,35.0131131 25.8791213,36.2610673 25.8081016,37.6639101 L25.8081016,37.6647842 C25.7647031,38.3701826 25.4746935,39.3242507 25.1805582,40.3347805 C22.2207839,42.446033 18.1128938,43.3607409 14.6251435,40.9805006 C14.3887768,40.6065916 14.1176344,40.2361221 13.8385378,39.8707355 C13.6603154,39.6373843 13.4772332,39.4054841 13.2952172,39.1768225 C13.6532528,39.1768225 13.9575843,39.1184771 14.2035442,39.0069433 C14.5094142,38.8682516 14.724322,38.6454901 14.8306462,38.3594969 C15.0432858,37.7875325 14.8297721,36.9806654 14.1489836,36.0592664 C13.4682956,35.137933 12.3154554,34.0981212 10.6214273,33.0592009 C10.6214273,33.0592009 10.621117,33.0592009 10.621117,33.0588906 C9.37658486,32.2846183 8.68057408,31.3355981 8.3547924,30.3051959 C8.02898013,29.2747018 8.07466439,28.1604089 8.32577265,27.0602631 C8.80774091,24.9485692 10.0461107,22.8947793 10.8362565,21.605909 C11.0489879,21.4493815 10.9122629,21.8964561 10.0363515,23.5230089 C9.25134103,25.0101357 7.78376323,28.4420972 9.79314068,31.1210705 C9.84684033,29.2145776 10.3021401,27.2701931 11.0664741,25.45145 C12.1797968,22.9278068 14.5084483,18.5514927 14.6933968,15.0635108 C14.7887555,15.1327561 15.1164383,15.3538525 15.2624505,15.4368866 C15.2627608,15.4373237 15.2628875,15.4373237 15.2633246,15.4373237 C15.6905181,15.6888908 16.0113611,16.0566244 16.426903,16.3905832 C16.8432709,16.7252019 17.3634237,17.0142238 18.149269,17.0600129 L18.149269,17.0600129 C19.066516,17.113092 19.7655905,16.8289912 20.3383504,16.5014745 C20.9102449,16.1744603 21.3671137,15.8125482 21.7999582,15.6712779 C21.8003952,15.6708409 21.8012693,15.6708409 21.8017063,15.6708409 C22.7163355,15.3848215 23.44356,14.8785842 23.857393,14.2881327 L23.8576858,14.2878093 Z M29.6669682,30.3312962 C30.0374289,30.329548 30.4861993,30.4530917 30.9774372,30.6728508 C32.2995623,31.2832227 32.713238,31.8063999 32.3522873,32.5749338 C32.0481219,33.1548918 30.7462669,34.0775407 29.8540319,33.8342075 C28.9435503,33.5989814 28.4994564,32.2869871 28.6474877,31.2953987 C28.7267763,30.6220356 29.1076387,30.3339097 29.6669682,30.3312962 L29.6669682,30.3312962 Z M28.1710786,32.1433306 C28.2458176,33.3559191 28.8457529,34.5926195 29.9067526,34.8602742 C31.0678224,35.1661922 32.7418469,34.16998 33.4486352,33.3574182 C33.5895689,33.3517803 33.7273516,33.3448313 33.8611658,33.3416409 C34.4811527,33.3266503 35.001157,33.3620509 35.5324588,33.8267253 L35.534207,33.8284735 L35.5359552,33.8302216 C35.9442465,34.1761336 36.1383204,34.8298385 36.3066481,35.5621545 C36.4749627,36.294475 36.6095636,37.0920505 37.11435,37.6602345 L37.115224,37.6611086 L37.1156611,37.6619827 C38.0861227,38.7388952 38.3980544,39.4668146 38.3715083,39.931406 C38.344936,40.3960279 38.008556,40.7409347 37.3873891,41.1155867 C36.1455928,41.864576 33.9453056,42.5158727 32.5399192,44.2181871 C31.3196037,45.6704378 29.8315635,46.4680352 28.5210638,46.5714617 C27.2105642,46.6748883 26.0799127,46.1309646 25.4133237,44.793071 L25.4115756,44.7900117 L25.4098274,44.7869524 C24.9962959,44.0002986 25.1685614,42.758852 25.5169207,41.4493706 C25.8652845,40.1398937 26.3657922,38.7953264 26.4327911,37.7024923 L26.4327911,37.7007442 L26.4327911,37.698996 C26.5036666,36.2987755 26.5820418,35.0759688 26.8172504,34.1324728 C27.0524633,33.1889769 27.4228236,32.5499829 28.0790545,32.1909116 C28.109604,32.1742165 28.139948,32.1584392 28.1701128,32.1435097 L28.1710786,32.1433306 Z M6.86074718,32.2348346 C6.95869322,32.2351449 7.06234705,32.2434006 7.17277507,32.2601394 C7.91559769,32.3726653 8.5633675,32.8920358 9.18746261,33.7385341 C9.8115621,34.5850455 10.3922762,35.7405823 10.9892352,37.0223812 L10.9901093,37.0241294 L10.9905463,37.0258776 C11.4702594,38.0271115 12.4825418,39.128044 13.3403902,40.2511564 C14.1982341,41.3742689 14.8621527,42.5016163 14.7756966,43.3644732 L14.7753863,43.3684066 L14.775076,43.37234 C14.6632363,44.843978 13.8330966,45.6451198 12.5587449,45.9361914 C11.2847734,46.2271625 9.55771794,45.9379396 7.83269472,45.035587 L7.83094655,45.035587 C5.9224477,44.0247687 3.65205856,44.1251622 2.19566909,43.8209924 C1.46727769,43.6688572 0.99200058,43.44013 0.773862951,43.0151698 C0.55571221,42.5902315 0.550839164,41.8488511 1.01440785,40.5847437 L1.01659307,40.5791059 L1.01834125,40.573468 C1.24759292,39.8663213 1.07793226,39.0925822 0.96663015,38.3663367 C0.855328038,37.6400911 0.800894151,36.9795116 1.04888192,36.5190765 L1.05019305,36.5168913 L1.05150418,36.514706 C1.36900824,35.9026821 1.83472718,35.683902 2.41273159,35.4765375 C2.990736,35.2691556 3.67612223,35.1062953 4.21734934,34.5638925 L4.21997161,34.5612703 L4.22259387,34.558648 C4.72293985,34.0308163 5.09877623,33.3691834 5.53863963,32.8995879 C5.90977341,32.5033678 6.28118253,32.2407652 6.84099715,32.2368755 L6.86053303,32.2368755 L6.86074718,32.2348346 Z"></path> <path d="M58.5014648,40 L58.5014648,6.7578125 L65.4194336,6.7578125 L65.4194336,35.2832031 L80.4008789,35.2832031 L80.4008789,40 L58.5014648,40 L58.5014648,40 L58.5014648,40 Z M86.2524414,40 L86.2524414,15.3378906 L92.9008789,15.3378906 L92.9008789,40 L86.2524414,40 L86.2524414,40 L86.2524414,40 Z M86.2524414,11.1826172 L86.2524414,5.63476562 L92.9008789,5.63476562 L92.9008789,11.1826172 L86.2524414,11.1826172 L86.2524414,11.1826172 L86.2524414,11.1826172 Z M100.211426,40 L100.211426,15.3378906 L106.859863,15.3378906 L106.859863,19.9873047 C109.031098,16.513329 111.8312,14.7763672 115.260254,14.7763672 C117.461437,14.7763672 119.198399,15.4726493 120.471191,16.8652344 C121.743984,18.2578195 122.380371,20.1594932 122.380371,22.5703125 L122.380371,40 L115.731934,40 L115.731934,24.2099609 C115.731934,21.4098167 114.803557,20.0097656 112.946777,20.0097656 C110.835439,20.0097656 108.806488,21.4996596 106.859863,24.4794922 L106.859863,40 L100.211426,40 L100.211426,40 L100.211426,40 Z M145.672363,40 L145.672363,35.3505859 C143.516102,38.8245616 140.716,40.5615234 137.271973,40.5615234 C135.07079,40.5615234 133.333828,39.8652413 132.061035,38.4726562 C130.788242,37.0800712 130.151855,35.1783975 130.151855,32.7675781 L130.151855,15.3378906 L136.800293,15.3378906 L136.800293,31.1279297 C136.800293,33.9280739 137.736156,35.328125 139.60791,35.328125 C141.704275,35.328125 143.725739,33.838231 145.672363,30.8583984 L145.672363,15.3378906 L152.320801,15.3378906 L152.320801,40 L145.672363,40 L145.672363,40 L145.672363,40 Z M158.003418,40 L166.471191,27.6240234 L158.362793,15.3378906 L165.932129,15.3378906 L171.23291,23.1542969 L176.309082,15.3378906 L181.699707,15.3378906 L173.973145,27.4443359 L182.26123,40 L174.691895,40 L169.166504,31.8466797 L163.506348,40 L158.003418,40 L158.003418,40 L158.003418,40 Z"></path> </g> </g> </g> </svg>
</a>
</div>
<div class="search">
<ul class="search-list" id="result">
<!-- <li><a href="#"><strong>find</strong> - 指定目录下查找文件。</a></li> -->
</ul>
<input type="text" class="query" id="query" autocomplete="off" autofocus="autofocus" placeholder="Linux 命令搜索"/>
<div class="enter-input">
<input type="hidden" id="current_path" value="/c/strace.html">
<button id="search_btn">搜索</button>
</div>
</div>
</div>
</div>
<script type="text/javascript" src="../js/copy-to-clipboard.js"></script>
<div class="markdown-body">
<span class="edit_btn">
<a target="_blank" href="https://github.com/jaywcjlove/linux-command/edit/master/command/strace.md">纠正错误</a>
<span class="split"></span>
<a target="_blank" href="https://github.com/jaywcjlove/linux-command/edit/master/command/strace.md">添加实例</a>
</span>
<dark-mode style="position: fixed; top: 8px; left: 10px; z-index: 999;;display: none;" dark="Dark" light="Light"></dark-mode><script>const t=document;const e="_dark_mode_theme_";const s="permanent";const o="colorschemechange";const i="permanentcolorscheme";const h="light";const r="dark";const n=(t,e,s=e)=>{Object.defineProperty(t,s,{enumerable:true,get(){const t=this.getAttribute(e);return t===null?"":t},set(t){this.setAttribute(e,t)}})};const c=(t,e,s=e)=>{Object.defineProperty(t,s,{enumerable:true,get(){return this.hasAttribute(e)},set(t){if(t){this.setAttribute(e,"")}else{this.removeAttribute(e)}}})};class a extends HTMLElement{static get observedAttributes(){return["mode",h,r,s]}LOCAL_NANE=e;constructor(){super();this.t()}connectedCallback(){n(this,"mode");n(this,r);n(this,h);c(this,s);const a=localStorage.getItem(e);if(a&&[h,r].includes(a)){this.mode=a;this.permanent=true}if(this.permanent&&!a){localStorage.setItem(e,this.mode)}const l=[h,r].includes(a);if(this.permanent&&a){this.o()}else{if(window.matchMedia&&window.matchMedia("(prefers-color-scheme: dark)").matches){this.mode=r;this.o()}if(window.matchMedia&&window.matchMedia("(prefers-color-scheme: light)").matches){this.mode=h;this.o()}}if(!this.permanent&&!l){window.matchMedia("(prefers-color-scheme: light)").onchange=t=>{this.mode=t.matches?h:r;this.o()};window.matchMedia("(prefers-color-scheme: dark)").onchange=t=>{this.mode=t.matches?r:h;this.o()}}const d=new MutationObserver(((s,h)=>{this.mode=t.documentElement.dataset.colorMode;if(this.permanent&&l){localStorage.setItem(e,this.mode);this.i(i,{permanent:this.permanent})}this.h();this.i(o,{colorScheme:this.mode})}));d.observe(t.documentElement,{attributes:true});this.i(o,{colorScheme:this.mode});this.h()}attributeChangedCallback(t,s,o){if(t==="mode"&&s!==o&&[h,r].includes(o)){const t=localStorage.getItem(e);if(this.mode===t){this.mode=o;this.h();this.o()}else if(this.mode&&this.mode!==t){this.h();this.o()}}else if((t===h||t===r)&&s!==o){this.h()}if(t==="permanent"&&typeof this.permanent==="boolean"){this.permanent?localStorage.setItem(e,this.mode):localStorage.removeItem(e)}}o(){t.documentElement.setAttribute("data-color-mode",this.mode)}h(){this.icon.textContent=this.mode===h?"🌒":"🌞";this.text.textContent=this.mode===h?this.getAttribute(r):this.getAttribute(h)}t(){var s=this.attachShadow({mode:"open"});this.label=t.createElement("span");this.label.setAttribute("class","wrapper");this.label.onclick=()=>{this.mode=this.mode===h?r:h;if(this.permanent){localStorage.setItem(e,this.mode)}this.o();this.h()};s.appendChild(this.label);this.icon=t.createElement("span");this.label.appendChild(this.icon);this.text=t.createElement("span");this.label.appendChild(this.text);const o=`
[data-color-mode*='dark'], [data-color-mode*='dark'] body {
color-scheme: dark;
--color-theme-bg: #0d1117;
--color-theme-text: #c9d1d9;
background-color: var(--color-theme-bg);
color: var(--color-theme-text);
}
[data-color-mode*='light'], [data-color-mode*='light'] body {
color-scheme: light;
--color-theme-bg: #fff;
--color-theme-text: #24292f;
background-color: var(--color-theme-bg);
color: var(--color-theme-text);
}`;const i="_dark_mode_style_";const n=t.getElementById(i);if(!n){var c=t.createElement("style");c.id=i;c.textContent=o;t.head.appendChild(c)}var a=t.createElement("style");a.textContent=`
.wrapper { cursor: pointer; user-select: none; position: relative; }
.wrapper > span + span { margin-left: .4rem; }
`;s.appendChild(a)}i(t,e){this.dispatchEvent(new CustomEvent(t,{bubbles:true,composed:true,detail:e}))}}customElements.define("dark-mode",a);</script><script>const __TEMPLATE__ = document.createElement('template');
__TEMPLATE__.innerHTML = `
<style>
markdown-style h1:hover a.anchor .octicon-link:before,
markdown-style h2:hover a.anchor .octicon-link:before,
markdown-style h3:hover a.anchor .octicon-link:before,
markdown-style h4:hover a.anchor .octicon-link:before,
markdown-style h5:hover a.anchor .octicon-link:before,
markdown-style h6:hover a.anchor .octicon-link:before {
width: 16px;
height: 16px;
content: ' ';
display: inline-block;
background-color: currentColor;
-webkit-mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' version='1.1' aria-hidden='true'><path fill-rule='evenodd' d='M7.775 3.275a.75.75 0 001.06 1.06l1.25-1.25a2 2 0 112.83 2.83l-2.5 2.5a2 2 0 01-2.83 0 .75.75 0 00-1.06 1.06 3.5 3.5 0 004.95 0l2.5-2.5a3.5 3.5 0 00-4.95-4.95l-1.25 1.25zm-4.69 9.64a2 2 0 010-2.83l2.5-2.5a2 2 0 012.83 0 .75.75 0 001.06-1.06 3.5 3.5 0 00-4.95 0l-2.5 2.5a3.5 3.5 0 004.95 4.95l1.25-1.25a.75.75 0 00-1.06-1.06l-1.25 1.25a2 2 0 01-2.83 0z'></path></svg>");
mask-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' version='1.1' aria-hidden='true'><path fill-rule='evenodd' d='M7.775 3.275a.75.75 0 001.06 1.06l1.25-1.25a2 2 0 112.83 2.83l-2.5 2.5a2 2 0 01-2.83 0 .75.75 0 00-1.06 1.06 3.5 3.5 0 004.95 0l2.5-2.5a3.5 3.5 0 00-4.95-4.95l-1.25 1.25zm-4.69 9.64a2 2 0 010-2.83l2.5-2.5a2 2 0 012.83 0 .75.75 0 001.06-1.06 3.5 3.5 0 00-4.95 0l-2.5 2.5a3.5 3.5 0 004.95 4.95l1.25-1.25a.75.75 0 00-1.06-1.06l-1.25 1.25a2 2 0 01-2.83 0z'></path></svg>");
}
[data-color-mode*='light'], [data-color-mode*='light'] body, markdown-style[theme*='light'] { --color-prettylights-syntax-comment: #6e7781; --color-prettylights-syntax-constant: #0550ae; --color-prettylights-syntax-entity: #8250df; --color-prettylights-syntax-storage-modifier-import: #24292f; --color-prettylights-syntax-entity-tag: #116329; --color-prettylights-syntax-keyword: #cf222e; --color-prettylights-syntax-string: #0a3069; --color-prettylights-syntax-variable: #953800; --color-prettylights-syntax-brackethighlighter-unmatched: #82071e; --color-prettylights-syntax-invalid-illegal-text: #f6f8fa; --color-prettylights-syntax-invalid-illegal-bg: #82071e; --color-prettylights-syntax-carriage-return-text: #f6f8fa; --color-prettylights-syntax-carriage-return-bg: #cf222e; --color-prettylights-syntax-string-regexp: #116329; --color-prettylights-syntax-markup-list: #3b2300; --color-prettylights-syntax-markup-heading: #0550ae; --color-prettylights-syntax-markup-italic: #24292f; --color-prettylights-syntax-markup-bold: #24292f; --color-prettylights-syntax-markup-deleted-text: #82071e; --color-prettylights-syntax-markup-deleted-bg: #FFEBE9; --color-prettylights-syntax-markup-inserted-text: #116329; --color-prettylights-syntax-markup-inserted-bg: #dafbe1; --color-prettylights-syntax-markup-changed-text: #953800; --color-prettylights-syntax-markup-changed-bg: #ffd8b5; --color-prettylights-syntax-markup-ignored-text: #eaeef2; --color-prettylights-syntax-markup-ignored-bg: #0550ae; --color-prettylights-syntax-meta-diff-range: #8250df; --color-prettylights-syntax-brackethighlighter-angle: #57606a; --color-prettylights-syntax-sublimelinter-gutter-mark: #8c959f; --color-prettylights-syntax-constant-other-reference-link: #0a3069; --color-fg-default: #24292f; --color-fg-muted: #57606a; --color-fg-subtle: #6e7781; --color-canvas-default: #ffffff; --color-canvas-subtle: #f6f8fa; --color-border-default: #d0d7de; --color-border-muted: hsla(210,18%,87%,1); --color-neutral-muted: rgba(175,184,193,0.2); --color-accent-fg: #0969da; --color-accent-emphasis: #0969da; --color-attention-subtle: #fff8c5; --color-danger-fg: #cf222e; } [data-color-mode*='dark'], [data-color-mode*='dark'] body, markdown-style[theme*='dark'] { --color-prettylights-syntax-comment: #8b949e; --color-prettylights-syntax-constant: #79c0ff; --color-prettylights-syntax-entity: #d2a8ff; --color-prettylights-syntax-storage-modifier-import: #c9d1d9; --color-prettylights-syntax-entity-tag: #7ee787; --color-prettylights-syntax-keyword: #ff7b72; --color-prettylights-syntax-string: #a5d6ff; --color-prettylights-syntax-variable: #ffa657; --color-prettylights-syntax-brackethighlighter-unmatched: #f85149; --color-prettylights-syntax-invalid-illegal-text: #f0f6fc; --color-prettylights-syntax-invalid-illegal-bg: #8e1519; --color-prettylights-syntax-carriage-return-text: #f0f6fc; --color-prettylights-syntax-carriage-return-bg: #b62324; --color-prettylights-syntax-string-regexp: #7ee787; --color-prettylights-syntax-markup-list: #f2cc60; --color-prettylights-syntax-markup-heading: #1f6feb; --color-prettylights-syntax-markup-italic: #c9d1d9; --color-prettylights-syntax-markup-bold: #c9d1d9; --color-prettylights-syntax-markup-deleted-text: #ffdcd7; --color-prettylights-syntax-markup-deleted-bg: #67060c; --color-prettylights-syntax-markup-inserted-text: #aff5b4; --color-prettylights-syntax-markup-inserted-bg: #033a16; --color-prettylights-syntax-markup-changed-text: #ffdfb6; --color-prettylights-syntax-markup-changed-bg: #5a1e02; --color-prettylights-syntax-markup-ignored-text: #c9d1d9; --color-prettylights-syntax-markup-ignored-bg: #1158c7; --color-prettylights-syntax-meta-diff-range: #d2a8ff; --color-prettylights-syntax-brackethighlighter-angle: #8b949e; --color-prettylights-syntax-sublimelinter-gutter-mark: #484f58; --color-prettylights-syntax-constant-other-reference-link: #a5d6ff; --color-fg-default: #c9d1d9; --color-fg-muted: #8b949e; --color-fg-subtle: #484f58; --color-canvas-default: #0d1117; --color-canvas-subtle: #161b22; --color-border-default: #30363d; --color-border-muted: #21262d; --color-neutral-muted: rgba(110,118,129,0.4); --color-accent-fg: #58a6ff; --color-accent-emphasis: #1f6feb; --color-attention-subtle: rgba(187,128,9,0.15); --color-danger-fg: #f85149; } markdown-style { display: block; -webkit-text-size-adjust: 100%; font-family: -apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji"; font-size: 16px; line-height: 1.5; word-wrap: break-word; color: var(--color-fg-default); background-color: var(--color-canvas-default); } markdown-style details, markdown-style figcaption, markdown-style figure { display: block; } markdown-style summary { display: list-item; } markdown-style [hidden] { display: none !important; } markdown-style a { background-color: transparent; color: var(--color-accent-fg); text-decoration: none; } markdown-style a:active, markdown-style a:hover { outline-width: 0; } markdown-style abbr[title] { border-bottom: none; text-decoration: underline dotted; } markdown-style b, markdown-style strong { font-weight: 600; } markdown-style dfn { font-style: italic; } markdown-style h1 { margin: .67em 0; font-weight: 600; padding-bottom: .3em; font-size: 2em; border-bottom: 1px solid var(--color-border-muted); } markdown-style mark { background-color: var(--color-attention-subtle); color: var(--color-text-primary); } markdown-style small { font-size: 90%; } markdown-style sub, markdown-style sup { font-size: 75%; line-height: 0; position: relative; vertical-align: baseline; } markdown-style sub { bottom: -0.25em; } markdown-style sup { top: -0.5em; } markdown-style img { border-style: none; max-width: 100%; box-sizing: content-box; background-color: var(--color-canvas-default); } markdown-style code, markdown-style kbd, markdown-style pre, markdown-style samp { font-family: monospace,monospace; font-size: 1em; } markdown-style figure { margin: 1em 40px; } markdown-style hr { box-sizing: content-box; overflow: hidden; background: transparent; border-bottom: 1px solid var(--color-border-muted); height: .25em; padding: 0; margin: 24px 0; background-color: var(--color-border-default); border: 0; } markdown-style input { font: inherit; margin: 0; overflow: visible; font-family: inherit; font-size: inherit; line-height: inherit; } markdown-style [type=button], markdown-style [type=reset], markdown-style [type=submit] { -webkit-appearance: button; } markdown-style [type=button]::-moz-focus-inner, markdown-style [type=reset]::-moz-focus-inner, markdown-style [type=submit]::-moz-focus-inner { border-style: none; padding: 0; } markdown-style [type=button]:-moz-focusring, markdown-style [type=reset]:-moz-focusring, markdown-style [type=submit]:-moz-focusring { outline: 1px dotted ButtonText; } markdown-style [type=checkbox], markdown-style [type=radio] { box-sizing: border-box; padding: 0; } markdown-style [type=number]::-webkit-inner-spin-button, markdown-style [type=number]::-webkit-outer-spin-button { height: auto; } markdown-style [type=search] { -webkit-appearance: textfield; outline-offset: -2px; } markdown-style [type=search]::-webkit-search-cancel-button, markdown-style [type=search]::-webkit-search-decoration { -webkit-appearance: none; } markdown-style ::-webkit-input-placeholder { color: inherit; opacity: .54; } markdown-style ::-webkit-file-upload-button { -webkit-appearance: button; font: inherit; } markdown-style a:hover { text-decoration: underline; } markdown-style hr::before { display: table; content: ""; } markdown-style hr::after { display: table; clear: both; content: ""; } markdown-style table { border-spacing: 0; border-collapse: collapse; display: block; width: max-content; max-width: 100%; overflow: auto; } markdown-style td, markdown-style th { padding: 0; } markdown-style details summary { cursor: pointer; } markdown-style details:not([open])>*:not(summary) { display: none !important; } markdown-style kbd { display: inline-block; padding: 3px 5px; font: 11px ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,Liberation Mono,monospace; line-height: 10px; color: var(--color-fg-default); vertical-align: middle; background-color: var(--color-canvas-subtle); border: solid 1px var(--color-neutral-muted); border-bottom-color: var(--color-neutral-muted); border-radius: 6px; box-shadow: inset 0 -1px 0 var(--color-neutral-muted); } markdown-style h1, markdown-style h2, markdown-style h3, markdown-style h4, markdown-style h5, markdown-style h6 { margin-top: 24px; margin-bottom: 16px; font-weight: 600; line-height: 1.25; } markdown-style h2 { font-weight: 600; padding-bottom: .3em; font-size: 1.5em; border-bottom: 1px solid var(--color-border-muted); } markdown-style h3 { font-weight: 600; font-size: 1.25em; } markdown-style h4 { font-weight: 600; font-size: 1em; } markdown-style h5 { font-weight: 600; font-size: .875em; } markdown-style h6 { font-weight: 600; font-size: .85em; color: var(--color-fg-muted); } markdown-style p { margin-top: 0; margin-bottom: 10px; } markdown-style blockquote { margin: 0; padding: 0 1em; color: var(--color-fg-muted); border-left: .25em solid var(--color-border-default); } markdown-style ul, markdown-style ol { margin-top: 0; margin-bottom: 0; padding-left: 2em; } markdown-style ol ol, markdown-style ul ol { list-style-type: lower-roman; } markdown-style ul ul ol, markdown-style ul ol ol, markdown-style ol ul ol, markdown-style ol ol ol { list-style-type: lower-alpha; } markdown-style dd { margin-left: 0; } markdown-style tt, markdown-style code { font-family: ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,Liberation Mono,monospace; font-size: 12px; } markdown-style pre { margin-top: 0; margin-bottom: 0; font-family: ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,Liberation Mono,monospace; font-size: 12px; word-wrap: normal; } markdown-style .octicon { display: inline-block; overflow: visible !important; vertical-align: text-bottom; fill: currentColor; } markdown-style ::placeholder { color: var(--color-fg-subtle); opacity: 1; } markdown-style input::-webkit-outer-spin-button, markdown-style input::-webkit-inner-spin-button { margin: 0; -webkit-appearance: none; appearance: none; }
markdown-style .token.comment, markdown-style .token.prolog, markdown-style .token.doctype, markdown-style .token.cdata { color: var(--color-prettylights-syntax-comment); } markdown-style .token.namespace { opacity: 0.7; } markdown-style .token.tag, markdown-style .token.selector, markdown-style .token.constant, markdown-style .token.symbol, markdown-style .token.deleted { color: var(--color-prettylights-syntax-entity-tag); } markdown-style .token.maybe-class-name { color: var(--color-prettylights-syntax-variable); } markdown-style .token.property-access, markdown-style .token.operator, markdown-style .token.boolean, markdown-style .token.number, markdown-style .token.selector markdown-style .token.class, markdown-style .token.attr-name, markdown-style .token.string, markdown-style .token.char, markdown-style .token.builtin { color: var(--color-prettylights-syntax-constant); } markdown-style .token.deleted { color: var(--color-prettylights-syntax-markup-deleted-text); } markdown-style .token.property { color: var(--color-prettylights-syntax-constant); } markdown-style .token.punctuation { color: var(--color-prettylights-syntax-markup-bold); } markdown-style .token.function { color: var(--color-prettylights-syntax-entity); } markdown-style .code-line .token.deleted { background-color: var(--color-prettylights-syntax-markup-deleted-bg); } markdown-style .token.inserted { color: var(--color-prettylights-syntax-markup-inserted-text); } markdown-style .code-line .token.inserted { background-color: var(--color-prettylights-syntax-markup-inserted-bg); } markdown-style .token.variable { color: var(--color-prettylights-syntax-constant); } markdown-style .token.entity, markdown-style .token.url, .language-css markdown-style .token.string, .style markdown-style .token.string { color: var(--color-prettylights-syntax-string); } markdown-style .token.color, markdown-style .token.atrule, markdown-style .token.attr-value, markdown-style .token.function, markdown-style .token.class-name { color: var(--color-prettylights-syntax-string); } markdown-style .token.rule, markdown-style .token.regex, markdown-style .token.important, markdown-style .token.keyword { color: var(--color-prettylights-syntax-keyword); } markdown-style .token.coord { color: var(--color-prettylights-syntax-meta-diff-range); } markdown-style .token.important, markdown-style .token.bold { font-weight: bold; } markdown-style .token.italic { font-style: italic; } markdown-style .token.entity { cursor: help; }
markdown-style [data-catalyst] { display: block; } markdown-style g-emoji { font-family: "Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol"; font-size: 1em; font-style: normal !important; font-weight: 400; line-height: 1; vertical-align: -0.075em; } markdown-style g-emoji img { width: 1em; height: 1em; } markdown-style::before { display: table; content: ""; } markdown-style::after { display: table; clear: both; content: ""; } markdown-style>*:first-child { margin-top: 0 !important; } markdown-style>*:last-child { margin-bottom: 0 !important; } markdown-style a:not([href]) { color: inherit; text-decoration: none; } markdown-style .absent { color: var(--color-danger-fg); } markdown-style a.anchor { float: left; padding-right: 4px; margin-left: -20px; line-height: 1; } markdown-style a.anchor:focus { outline: none; } markdown-style p, markdown-style blockquote, markdown-style ul, markdown-style ol, markdown-style dl, markdown-style table, markdown-style pre, markdown-style details { margin-top: 0; margin-bottom: 16px; } markdown-style blockquote>:first-child { margin-top: 0; } markdown-style blockquote>:last-child { margin-bottom: 0; } markdown-style sup>a::before { content: "["; } markdown-style sup>a::after { content: "]"; }
markdown-style .octicon-video { border: 1px solid #d0d7de !important; border-radius: 6px !important; display: block; } markdown-style .octicon-video summary { border-bottom: 1px solid #d0d7de !important; padding: 8px 16px !important; cursor: pointer; } markdown-style .octicon-video > video { display: block !important; max-width: 100% !important; padding: 2px; box-sizing: border-box; border-bottom-right-radius: 6px !important; border-bottom-left-radius: 6px !important; } markdown-style details.octicon-video:not([open])>*:not(summary) { display: none !important; } markdown-style details.octicon-video:not([open]) > summary { border-bottom: 0 !important; } markdown-style h1 .octicon-link, markdown-style h2 .octicon-link, markdown-style h3 .octicon-link, markdown-style h4 .octicon-link, markdown-style h5 .octicon-link, markdown-style h6 .octicon-link { color: var(--color-fg-default); vertical-align: middle; visibility: hidden; } markdown-style h1:hover .anchor, markdown-style h2:hover .anchor, markdown-style h3:hover .anchor, markdown-style h4:hover .anchor, markdown-style h5:hover .anchor, markdown-style h6:hover .anchor { text-decoration: none; } markdown-style h1:hover .anchor .octicon-link, markdown-style h2:hover .anchor .octicon-link, markdown-style h3:hover .anchor .octicon-link, markdown-style h4:hover .anchor .octicon-link, markdown-style h5:hover .anchor .octicon-link, markdown-style h6:hover .anchor .octicon-link { visibility: visible; } markdown-style h1 tt, markdown-style h1 code, markdown-style h2 tt, markdown-style h2 code, markdown-style h3 tt, markdown-style h3 code, markdown-style h4 tt, markdown-style h4 code, markdown-style h5 tt, markdown-style h5 code, markdown-style h6 tt, markdown-style h6 code { padding: 0 .2em; font-size: inherit; } markdown-style ul.no-list, markdown-style ol.no-list { padding: 0; list-style-type: none; } markdown-style ol[type="1"] { list-style-type: decimal; } markdown-style ol[type=a] { list-style-type: lower-alpha; } markdown-style ol[type=i] { list-style-type: lower-roman; } markdown-style div>ol:not([type]) { list-style-type: decimal; } markdown-style ul ul, markdown-style ul ol, markdown-style ol ol, markdown-style ol ul { margin-top: 0; margin-bottom: 0; } markdown-style li>p { margin-top: 16px; } markdown-style li+li { margin-top: .25em; } markdown-style dl { padding: 0; } markdown-style dl dt { padding: 0; margin-top: 16px; font-size: 1em; font-style: italic; font-weight: 600; } markdown-style dl dd { padding: 0 16px; margin-bottom: 16px; } markdown-style table th { font-weight: 600; } markdown-style table th, markdown-style table td { padding: 6px 13px; border: 1px solid var(--color-border-default); } markdown-style table tr { background-color: var(--color-canvas-default); border-top: 1px solid var(--color-border-muted); } markdown-style table tr:nth-child(2n) { background-color: var(--color-canvas-subtle); } markdown-style table img { background-color: transparent; vertical-align: middle; } markdown-style img[align=right] { padding-left: 20px; } markdown-style img[align=left] { padding-right: 20px; } markdown-style .emoji { max-width: none; vertical-align: text-top; background-color: transparent; } markdown-style span.frame { display: block; overflow: hidden; } markdown-style span.frame>span { display: block; float: left; width: auto; padding: 7px; margin: 13px 0 0; overflow: hidden; border: 1px solid var(--color-border-default); } markdown-style span.frame span img { display: block; float: left; } markdown-style span.frame span span { display: block; padding: 5px 0 0; clear: both; color: var(--color-fg-default); } markdown-style span.align-center { display: block; overflow: hidden; clear: both; } markdown-style span.align-center>span { display: block; margin: 13px auto 0; overflow: hidden; text-align: center; } markdown-style span.align-center span img { margin: 0 auto; text-align: center; } markdown-style span.align-right { display: block; overflow: hidden; clear: both; } markdown-style span.align-right>span { display: block; margin: 13px 0 0; overflow: hidden; text-align: right; } markdown-style span.align-right span img { margin: 0; text-align: right; } markdown-style span.float-left { display: block; float: left; margin-right: 13px; overflow: hidden; } markdown-style span.float-left span { margin: 13px 0 0; } markdown-style span.float-right { display: block; float: right; margin-left: 13px; overflow: hidden; } markdown-style span.float-right>span { display: block; margin: 13px auto 0; overflow: hidden; text-align: right; } markdown-style code, markdown-style tt { padding: .2em .4em; margin: 0; font-size: 85%; background-color: var(--color-neutral-muted); border-radius: 6px; } markdown-style code br, markdown-style tt br { display: none; } markdown-style del code { text-decoration: inherit; } markdown-style pre code { font-size: 100%; } markdown-style pre>code { padding: 0; margin: 0; word-break: normal; white-space: pre; background: transparent; border: 0; } markdown-style pre { position: relative; font-size: 85%; line-height: 1.45; background-color: var(--color-canvas-subtle); border-radius: 6px; } markdown-style pre code, markdown-style pre tt { display: inline; max-width: auto; padding: 0; margin: 0; overflow: visible; line-height: inherit; word-wrap: normal; background-color: transparent; border: 0; } markdown-style pre > code { padding: 16px; overflow: auto; display: block; } markdown-style .csv-data td, markdown-style .csv-data th { padding: 5px; overflow: hidden; font-size: 12px; line-height: 1; text-align: left; white-space: nowrap; } markdown-style .csv-data .blob-num { padding: 10px 8px 9px; text-align: right; background: var(--color-canvas-default); border: 0; } markdown-style .csv-data tr { border-top: 0; } markdown-style .csv-data th { font-weight: 600; background: var(--color-canvas-subtle); border-top: 0; } markdown-style .footnotes { font-size: 12px; color: var(--color-fg-muted); border-top: 1px solid var(--color-border-default); } markdown-style .footnotes ol { padding-left: 16px; } markdown-style .footnotes li { position: relative; } markdown-style .footnotes li:target::before { position: absolute; top: -8px; right: -8px; bottom: -8px; left: -24px; pointer-events: none; content: ""; border: 2px solid var(--color-accent-emphasis); border-radius: 6px; } markdown-style .footnotes li:target { color: var(--color-fg-default); } markdown-style .footnotes .data-footnote-backref g-emoji { font-family: monospace; } markdown-style .task-list-item { list-style-type: none; } markdown-style .task-list-item label { font-weight: 400; } markdown-style .task-list-item.enabled label { cursor: pointer; } markdown-style .task-list-item+.task-list-item { margin-top: 3px; } markdown-style .task-list-item .handle { display: none; } markdown-style .task-list-item-checkbox, markdown-style input[type="checkbox"] { margin: 0 .2em .25em -1.6em; vertical-align: middle; } markdown-style .contains-task-list:dir(rtl) .task-list-item-checkbox, markdown-style .contains-task-list:dir(rtl) input[type="checkbox"] { margin: 0 -1.6em .25em .2em; } markdown-style ::-webkit-calendar-picker-indicator { filter: invert(50%); }
</style>
<slot></slot>
`;
class MarkdownStyle extends HTMLElement {
constructor() {
super();
this.shadow = this.attachShadow({ mode: 'open' });
this.shadow.appendChild(__TEMPLATE__.content.cloneNode(true));
const style = Array.prototype.slice
.call(this.shadow.children)
.find((item) => item.tagName === 'STYLE');
if (style) {
const id = '__MARKDOWN_STYLE__';
const findStyle = document.getElementById(id);
if (!findStyle) {
style.id = id;
document.head.append(style);
}
}
}
get theme() {
const value = this.getAttribute('theme');
return value === null ? '' : value;
}
set theme(name) {
this.setAttribute('theme', name);
}
connectedCallback() {
if (!this.theme) {
const { colorMode } = document.documentElement.dataset;
this.theme = colorMode;
const observer = new MutationObserver((mutationsList, observer) => {
this.theme = document.documentElement.dataset.colorMode;
});
observer.observe(document.documentElement, { attributes: true });
window.matchMedia('(prefers-color-scheme: light)').onchange = (event) => {
this.theme = event.matches ? 'light' : 'dark';
};
window.matchMedia('(prefers-color-scheme: dark)').onchange = (event) => {
this.theme = event.matches ? 'dark' : 'light';
};
}
}
}
customElements.define('markdown-style', MarkdownStyle);</script><markdown-style style="max-width: 960px; margin: 0 auto 60px auto; padding: 8px;" class="markdown-style">
<h1 id="strace"><a class="anchor" aria-hidden="true" tabindex="-1" href="#strace"><span class="octicon octicon-link"></span></a>strace</h1>
<p>跟踪系统调用和信号</p>
<h2 id="补充说明"><a class="anchor" aria-hidden="true" tabindex="-1" href="#补充说明"><span class="octicon octicon-link"></span></a>补充说明</h2>
<p><strong>strace命令</strong> 是一个集诊断、调试、统计与一体的工具我们可以使用strace对应用的系统调用和信号传递的跟踪结果来对应用进行分析以达到解决问题或者是了解应用工作过程的目的。当然strace与专业的调试工具比如说gdb之类的是没法相比的因为它不是一个专业的调试器。</p>
<p>strace的最简单的用法就是执行一个指定的命令在指定的命令结束之后它也就退出了。在命令执行的过程中strace会记录和解析命令进程的所有系统调用以及这个进程所接收到的所有的信号值。</p>
<h3 id="语法"><a class="anchor" aria-hidden="true" tabindex="-1" href="#语法"><span class="octicon octicon-link"></span></a>语法</h3>
<pre class="language-shell"><code class="language-shell code-highlight"><span class="code-line line-number" line="1"><span class="token function">strace</span> <span class="token punctuation">[</span> <span class="token parameter variable">-dffhiqrtttTvxx</span> <span class="token punctuation">]</span> <span class="token punctuation">[</span> <span class="token parameter variable">-acolumn</span> <span class="token punctuation">]</span> <span class="token punctuation">[</span> <span class="token parameter variable">-eexpr</span> <span class="token punctuation">]</span> <span class="token punctuation">..</span>.
</span><span class="code-line line-number" line="2"> <span class="token punctuation">[</span> <span class="token parameter variable">-ofile</span> <span class="token punctuation">]</span> <span class="token punctuation">[</span>-ppid <span class="token punctuation">]</span> <span class="token punctuation">..</span>. <span class="token punctuation">[</span> <span class="token parameter variable">-sstrsize</span> <span class="token punctuation">]</span> <span class="token punctuation">[</span> <span class="token parameter variable">-uusername</span> <span class="token punctuation">]</span>
</span><span class="code-line line-number" line="3"> <span class="token punctuation">[</span> <span class="token parameter variable">-Evar</span><span class="token operator">=</span>val <span class="token punctuation">]</span> <span class="token punctuation">..</span>. <span class="token punctuation">[</span> <span class="token parameter variable">-Evar</span> <span class="token punctuation">]</span><span class="token punctuation">..</span>.
</span><span class="code-line line-number" line="4"> <span class="token punctuation">[</span>command <span class="token punctuation">[</span> arg <span class="token punctuation">..</span>. <span class="token punctuation">]</span> <span class="token punctuation">]</span>
</span><span class="code-line line-number" line="5">
</span><span class="code-line line-number" line="6"><span class="token function">strace</span> <span class="token parameter variable">-c</span> <span class="token punctuation">[</span> <span class="token parameter variable">-eexpr</span> <span class="token punctuation">]</span> <span class="token punctuation">..</span>. <span class="token punctuation">[</span> <span class="token parameter variable">-Ooverhead</span> <span class="token punctuation">]</span> <span class="token punctuation">[</span> <span class="token parameter variable">-Ssortby</span> <span class="token punctuation">]</span>
</span><span class="code-line line-number" line="7"> <span class="token punctuation">[</span> <span class="token builtin class-name">command</span> <span class="token punctuation">[</span> arg<span class="token punctuation">..</span>. <span class="token punctuation">]</span> <span class="token punctuation">]</span>
</span></code><div onclick="copied(this)" data-code="strace [ -dffhiqrtttTvxx ] [ -acolumn ] [ -eexpr ] ...
[ -ofile ] [-ppid ] ... [ -sstrsize ] [ -uusername ]
[ -Evar=val ] ... [ -Evar ]...
[command [ arg ... ] ]
strace -c [ -eexpr ] ... [ -Ooverhead ] [ -Ssortby ]
[ command [ arg... ] ]
" class="copied"><svg class="octicon-copy" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M0 6.75C0 5.784.784 5 1.75 5h1.5a.75.75 0 010 1.5h-1.5a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-1.5a.75.75 0 011.5 0v1.5A1.75 1.75 0 019.25 16h-7.5A1.75 1.75 0 010 14.25v-7.5z"></path><path fill-rule="evenodd" d="M5 1.75C5 .784 5.784 0 6.75 0h7.5C15.216 0 16 .784 16 1.75v7.5A1.75 1.75 0 0114.25 11h-7.5A1.75 1.75 0 015 9.25v-7.5zm1.75-.25a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-7.5a.25.25 0 00-.25-.25h-7.5z"></path></svg><svg class="octicon-check" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M13.78 4.22a.75.75 0 010 1.06l-7.25 7.25a.75.75 0 01-1.06 0L2.22 9.28a.75.75 0 011.06-1.06L6 10.94l6.72-6.72a.75.75 0 011.06 0z"></path></svg></div></pre>
<h3 id="选项"><a class="anchor" aria-hidden="true" tabindex="-1" href="#选项"><span class="octicon octicon-link"></span></a>选项</h3>
<pre class="language-shell"><code class="language-shell code-highlight"><span class="code-line line-number" line="1"><span class="token parameter variable">-c</span> 统计每一系统调用的所执行的时间,次数和出错的次数等.
</span><span class="code-line line-number" line="2"><span class="token parameter variable">-d</span> 输出strace关于标准错误的调试信息.
</span><span class="code-line line-number" line="3"><span class="token parameter variable">-f</span> 跟踪由fork调用所产生的子进程.
</span><span class="code-line line-number" line="4"><span class="token parameter variable">-ff</span> 如果提供-o filename,则所有进程的跟踪结果输出到相应的filename.pid中,pid是各进程的进程号.
</span><span class="code-line line-number" line="5"><span class="token parameter variable">-F</span> 尝试跟踪vfork调用.在-f时,vfork不被跟踪.
</span><span class="code-line line-number" line="6"><span class="token parameter variable">-h</span> 输出简要的帮助信息.
</span><span class="code-line line-number" line="7"><span class="token parameter variable">-i</span> 输出系统调用的入口指针.
</span><span class="code-line line-number" line="8"><span class="token parameter variable">-q</span> 禁止输出关于脱离的消息.
</span><span class="code-line line-number" line="9"><span class="token parameter variable">-r</span> 打印出相对时间关于,,每一个系统调用.
</span><span class="code-line line-number" line="10"><span class="token parameter variable">-t</span> 在输出中的每一行前加上时间信息.
</span><span class="code-line line-number" line="11"><span class="token parameter variable">-tt</span> 在输出中的每一行前加上时间信息,微秒级.
</span><span class="code-line line-number" line="12"><span class="token parameter variable">-ttt</span> 微秒级输出,以秒了表示时间.
</span><span class="code-line line-number" line="13"><span class="token parameter variable">-T</span> 显示每一调用所耗的时间.
</span><span class="code-line line-number" line="14"><span class="token parameter variable">-v</span> 输出所有的系统调用.一些调用关于环境变量,状态,输入输出等调用由于使用频繁,默认不输出.
</span><span class="code-line line-number" line="15"><span class="token parameter variable">-V</span> 输出strace的版本信息.
</span><span class="code-line line-number" line="16"><span class="token parameter variable">-x</span> 以十六进制形式输出非标准字符串
</span><span class="code-line line-number" line="17"><span class="token parameter variable">-xx</span> 所有字符串以十六进制形式输出.
</span><span class="code-line line-number" line="18"><span class="token parameter variable">-a</span> <span class="token function">column</span> 设置返回值的输出位置.默认 为40.
</span><span class="code-line line-number" line="19"><span class="token parameter variable">-e</span> <span class="token function">expr</span> 指定一个表达式,用来控制如何跟踪.格式:<span class="token punctuation">[</span>qualifier<span class="token operator">=</span><span class="token punctuation">]</span><span class="token punctuation">[</span><span class="token operator">!</span><span class="token punctuation">]</span>value1<span class="token punctuation">[</span>,value2<span class="token punctuation">]</span><span class="token punctuation">..</span>.
</span><span class="code-line line-number" line="20">qualifier只能是 trace,abbrev,verbose,raw,signal,read,write其中之一.value是用来限定的符号或数字.默认的 qualifier是 trace.感叹号是否定符号.例如:-eopen等价于 <span class="token parameter variable">-e</span> <span class="token assign-left variable">trace</span><span class="token operator">=</span>open,表示只跟踪open调用.而-etrace<span class="token operator">!=</span>open 表示跟踪除了open以外的其他调用.有两个特殊的符号 all 和 none. 注意有些shell使用<span class="token operator">!</span>来执行历史记录里的命令,所以要使用<span class="token punctuation">\</span><span class="token punctuation">\</span>.
</span><span class="code-line line-number" line="21"><span class="token parameter variable">-e</span> <span class="token assign-left variable">trace</span><span class="token operator">=</span>set 只跟踪指定的系统 调用.例如:-e <span class="token assign-left variable">trace</span><span class="token operator">=</span>open,close,rean,write表示只跟踪这四个系统调用.默认的为set<span class="token operator">=</span>all.
</span><span class="code-line line-number" line="22"><span class="token parameter variable">-e</span> <span class="token assign-left variable">trace</span><span class="token operator">=</span>file 只跟踪有关文件操作的系统调用.
</span><span class="code-line line-number" line="23"><span class="token parameter variable">-e</span> <span class="token assign-left variable">trace</span><span class="token operator">=</span>process 只跟踪有关进程控制的系统调用.
</span><span class="code-line line-number" line="24"><span class="token parameter variable">-e</span> <span class="token assign-left variable">trace</span><span class="token operator">=</span>network 跟踪与网络有关的所有系统调用.
</span><span class="code-line line-number" line="25"><span class="token parameter variable">-e</span> <span class="token assign-left variable">strace</span><span class="token operator">=</span>signal 跟踪所有与系统信号有关的 系统调用
</span><span class="code-line line-number" line="26"><span class="token parameter variable">-e</span> <span class="token assign-left variable">trace</span><span class="token operator">=</span>ipc 跟踪所有与进程通讯有关的系统调用
</span><span class="code-line line-number" line="27"><span class="token parameter variable">-e</span> <span class="token assign-left variable">abbrev</span><span class="token operator">=</span>set 设定strace输出的系统调用的结果集.-v 等与 <span class="token assign-left variable">abbrev</span><span class="token operator">=</span>none.默认为abbrev<span class="token operator">=</span>all.
</span><span class="code-line line-number" line="28"><span class="token parameter variable">-e</span> <span class="token assign-left variable">raw</span><span class="token operator">=</span>set 将指定的系统调用的参数以十六进制显示.
</span><span class="code-line line-number" line="29"><span class="token parameter variable">-e</span> <span class="token assign-left variable">signal</span><span class="token operator">=</span>set 指定跟踪的系统信号.默认为all.如 <span class="token assign-left variable">signal</span><span class="token operator">=</span><span class="token operator">!</span>SIGIO<span class="token punctuation">(</span>或者signal<span class="token operator">=</span><span class="token operator">!</span>io<span class="token punctuation">)</span>,表示不跟踪SIGIO信号.
</span><span class="code-line line-number" line="30"><span class="token parameter variable">-e</span> <span class="token assign-left variable">read</span><span class="token operator">=</span>set 输出从指定文件中读出 的数据.例如: <span class="token parameter variable">-e</span> <span class="token assign-left variable">read</span><span class="token operator">=</span><span class="token number">3,5</span>
</span><span class="code-line line-number" line="31"><span class="token parameter variable">-e</span> <span class="token assign-left variable">write</span><span class="token operator">=</span>set 输出写入到指定文件中的数据.
</span><span class="code-line line-number" line="32"><span class="token parameter variable">-o</span> filename 将strace的输出写入文件filename
</span><span class="code-line line-number" line="33"><span class="token parameter variable">-p</span> pid 跟踪指定的进程pid.
</span><span class="code-line line-number" line="34"><span class="token parameter variable">-s</span> strsize 指定输出的字符串的最大长度.默认为32.文件名一直全部输出.
</span><span class="code-line line-number" line="35"><span class="token parameter variable">-u</span> username 以username的<span class="token environment constant">UID</span>和GID执行被跟踪的命令
</span></code><div onclick="copied(this)" data-code="-c 统计每一系统调用的所执行的时间,次数和出错的次数等.
-d 输出strace关于标准错误的调试信息.
-f 跟踪由fork调用所产生的子进程.
-ff 如果提供-o filename,则所有进程的跟踪结果输出到相应的filename.pid中,pid是各进程的进程号.
-F 尝试跟踪vfork调用.在-f时,vfork不被跟踪.
-h 输出简要的帮助信息.
-i 输出系统调用的入口指针.
-q 禁止输出关于脱离的消息.
-r 打印出相对时间关于,,每一个系统调用.
-t 在输出中的每一行前加上时间信息.
-tt 在输出中的每一行前加上时间信息,微秒级.
-ttt 微秒级输出,以秒了表示时间.
-T 显示每一调用所耗的时间.
-v 输出所有的系统调用.一些调用关于环境变量,状态,输入输出等调用由于使用频繁,默认不输出.
-V 输出strace的版本信息.
-x 以十六进制形式输出非标准字符串
-xx 所有字符串以十六进制形式输出.
-a column 设置返回值的输出位置.默认 为40.
-e expr 指定一个表达式,用来控制如何跟踪.格式:[qualifier=][!]value1[,value2]...
qualifier只能是 trace,abbrev,verbose,raw,signal,read,write其中之一.value是用来限定的符号或数字.默认的 qualifier是 trace.感叹号是否定符号.例如:-eopen等价于 -e trace=open,表示只跟踪open调用.而-etrace!=open 表示跟踪除了open以外的其他调用.有两个特殊的符号 all 和 none. 注意有些shell使用!来执行历史记录里的命令,所以要使用\\.
-e trace=set 只跟踪指定的系统 调用.例如:-e trace=open,close,rean,write表示只跟踪这四个系统调用.默认的为set=all.
-e trace=file 只跟踪有关文件操作的系统调用.
-e trace=process 只跟踪有关进程控制的系统调用.
-e trace=network 跟踪与网络有关的所有系统调用.
-e strace=signal 跟踪所有与系统信号有关的 系统调用
-e trace=ipc 跟踪所有与进程通讯有关的系统调用
-e abbrev=set 设定strace输出的系统调用的结果集.-v 等与 abbrev=none.默认为abbrev=all.
-e raw=set 将指定的系统调用的参数以十六进制显示.
-e signal=set 指定跟踪的系统信号.默认为all.如 signal=!SIGIO(或者signal=!io),表示不跟踪SIGIO信号.
-e read=set 输出从指定文件中读出 的数据.例如: -e read=3,5
-e write=set 输出写入到指定文件中的数据.
-o filename 将strace的输出写入文件filename
-p pid 跟踪指定的进程pid.
-s strsize 指定输出的字符串的最大长度.默认为32.文件名一直全部输出.
-u username 以username的UID和GID执行被跟踪的命令
" class="copied"><svg class="octicon-copy" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M0 6.75C0 5.784.784 5 1.75 5h1.5a.75.75 0 010 1.5h-1.5a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-1.5a.75.75 0 011.5 0v1.5A1.75 1.75 0 019.25 16h-7.5A1.75 1.75 0 010 14.25v-7.5z"></path><path fill-rule="evenodd" d="M5 1.75C5 .784 5.784 0 6.75 0h7.5C15.216 0 16 .784 16 1.75v7.5A1.75 1.75 0 0114.25 11h-7.5A1.75 1.75 0 015 9.25v-7.5zm1.75-.25a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-7.5a.25.25 0 00-.25-.25h-7.5z"></path></svg><svg class="octicon-check" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M13.78 4.22a.75.75 0 010 1.06l-7.25 7.25a.75.75 0 01-1.06 0L2.22 9.28a.75.75 0 011.06-1.06L6 10.94l6.72-6.72a.75.75 0 011.06 0z"></path></svg></div></pre>
<h3 id="实例"><a class="anchor" aria-hidden="true" tabindex="-1" href="#实例"><span class="octicon octicon-link"></span></a>实例</h3>
<p><strong>追踪系统调用</strong></p>
<p>现在我们做一个很简单的程序来演示strace的基本用法。这个程序的C语言代码如下</p>
<pre class="language-shell"><code class="language-shell code-highlight"><span class="code-line line-number" line="1"><span class="token comment"># filename test.c</span>
</span><span class="code-line line-number" line="2"><span class="token comment">#include &#x3C;stdio.h></span>
</span><span class="code-line line-number" line="3">
</span><span class="code-line line-number" line="4">int <span class="token function-name function">main</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
</span><span class="code-line line-number" line="5"><span class="token punctuation">{</span>
</span><span class="code-line line-number" line="6"> int a<span class="token punctuation">;</span>
</span><span class="code-line line-number" line="7"> scanf<span class="token punctuation">(</span><span class="token string">"%d"</span>, <span class="token operator">&#x26;</span>a<span class="token punctuation">)</span><span class="token punctuation">;</span>
</span><span class="code-line line-number" line="8"> printf<span class="token punctuation">(</span><span class="token string">"%09d<span class="token entity" title="\n">\n</span>"</span>, a<span class="token punctuation">)</span><span class="token punctuation">;</span>
</span><span class="code-line line-number" line="9"> <span class="token builtin class-name">return</span> <span class="token number">0</span><span class="token punctuation">;</span>
</span><span class="code-line line-number" line="10"><span class="token punctuation">}</span>
</span></code><div onclick="copied(this)" data-code="# filename test.c
#include <stdio.h>
int main()
{
int a;
scanf(&#x22;%d&#x22;, &#x26;a);
printf(&#x22;%09d\n&#x22;, a);
return 0;
}
" class="copied"><svg class="octicon-copy" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M0 6.75C0 5.784.784 5 1.75 5h1.5a.75.75 0 010 1.5h-1.5a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-1.5a.75.75 0 011.5 0v1.5A1.75 1.75 0 019.25 16h-7.5A1.75 1.75 0 010 14.25v-7.5z"></path><path fill-rule="evenodd" d="M5 1.75C5 .784 5.784 0 6.75 0h7.5C15.216 0 16 .784 16 1.75v7.5A1.75 1.75 0 0114.25 11h-7.5A1.75 1.75 0 015 9.25v-7.5zm1.75-.25a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-7.5a.25.25 0 00-.25-.25h-7.5z"></path></svg><svg class="octicon-check" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M13.78 4.22a.75.75 0 010 1.06l-7.25 7.25a.75.75 0 01-1.06 0L2.22 9.28a.75.75 0 011.06-1.06L6 10.94l6.72-6.72a.75.75 0 011.06 0z"></path></svg></div></pre>
<p>然后我们用<code>gcc -o test test.c</code>编译一下得到一个可执行的文件test。然后用strace调用执行</p>
<pre class="language-shell"><code class="language-shell code-highlight"><span class="code-line line-number" line="1"><span class="token function">strace</span> ./test
</span></code><div onclick="copied(this)" data-code="strace ./test
" class="copied"><svg class="octicon-copy" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M0 6.75C0 5.784.784 5 1.75 5h1.5a.75.75 0 010 1.5h-1.5a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-1.5a.75.75 0 011.5 0v1.5A1.75 1.75 0 019.25 16h-7.5A1.75 1.75 0 010 14.25v-7.5z"></path><path fill-rule="evenodd" d="M5 1.75C5 .784 5.784 0 6.75 0h7.5C15.216 0 16 .784 16 1.75v7.5A1.75 1.75 0 0114.25 11h-7.5A1.75 1.75 0 015 9.25v-7.5zm1.75-.25a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-7.5a.25.25 0 00-.25-.25h-7.5z"></path></svg><svg class="octicon-check" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M13.78 4.22a.75.75 0 010 1.06l-7.25 7.25a.75.75 0 01-1.06 0L2.22 9.28a.75.75 0 011.06-1.06L6 10.94l6.72-6.72a.75.75 0 011.06 0z"></path></svg></div></pre>
<p>执行期间会要求你输入一个整数我们输入99最后得到如下的结果</p>
<pre class="language-shell"><code class="language-shell code-highlight"><span class="code-line line-number" line="1">// 直接执行test的结果
</span><span class="code-line line-number" line="2">oracle@orainst<span class="token punctuation">[</span>orcl<span class="token punctuation">]</span>:~ $./test
</span><span class="code-line line-number" line="3">
</span><span class="code-line line-number" line="4">// 执行的结果
</span><span class="code-line line-number" line="5"><span class="token number">99</span>
</span><span class="code-line line-number" line="6">000000099
</span><span class="code-line line-number" line="7">
</span><span class="code-line line-number" line="8">// 通过strace执行test的结果
</span><span class="code-line line-number" line="9">oracle@orainst<span class="token punctuation">[</span>orcl<span class="token punctuation">]</span>:~ <span class="token variable">$strace</span> ./test
</span><span class="code-line line-number" line="10">
</span><span class="code-line line-number" line="11">// strace的trace结果
</span><span class="code-line line-number" line="12">execve<span class="token punctuation">(</span><span class="token string">"./test"</span>, <span class="token punctuation">[</span><span class="token string">"./test"</span><span class="token punctuation">]</span>, <span class="token punctuation">[</span>/* <span class="token number">41</span> vars */<span class="token punctuation">]</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">0</span>
</span><span class="code-line line-number" line="13">uname<span class="token punctuation">(</span><span class="token punctuation">{</span>sys<span class="token operator">=</span><span class="token string">"Linux"</span>, <span class="token assign-left variable">node</span><span class="token operator">=</span><span class="token string">"orainst.desktop.mycompany.com"</span>, <span class="token punctuation">..</span>.<span class="token punctuation">}</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">0</span>
</span><span class="code-line line-number" line="14">brk<span class="token punctuation">(</span><span class="token number">0</span><span class="token punctuation">)</span> <span class="token operator">=</span> 0x8078000
</span><span class="code-line line-number" line="15">fstat64<span class="token punctuation">(</span><span class="token number">3</span>, <span class="token punctuation">{</span>st_mode<span class="token operator">=</span>S_IFREG<span class="token operator">|</span>0644, <span class="token assign-left variable">st_size</span><span class="token operator">=</span><span class="token number">65900</span>, <span class="token punctuation">..</span>.<span class="token punctuation">}</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">0</span>
</span><span class="code-line line-number" line="16">old_mmap<span class="token punctuation">(</span>NULL, <span class="token number">65900</span>, PROT_READ, MAP_PRIVATE, <span class="token number">3</span>, <span class="token number">0</span><span class="token punctuation">)</span> <span class="token operator">=</span> 0xbf5ef000
</span><span class="code-line line-number" line="17">close<span class="token punctuation">(</span><span class="token number">3</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">0</span>
</span><span class="code-line line-number" line="18">open<span class="token punctuation">(</span><span class="token string">"/lib/tls/libc.so.6"</span>, O_RDONLY<span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">3</span>
</span><span class="code-line line-number" line="19">read<span class="token punctuation">(</span><span class="token number">3</span>, <span class="token string">"<span class="token entity" title="\177">\177</span>ELF<span class="token entity" title="\1">\1</span><span class="token entity" title="\1">\1</span><span class="token entity" title="\1">\1</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\3">\3</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\3">\3</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\1">\1</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\200">\200</span>X<span class="token entity" title="\1">\1</span>"</span><span class="token punctuation">..</span>., <span class="token number">512</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">512</span>
</span><span class="code-line line-number" line="20">fstat64<span class="token punctuation">(</span><span class="token number">3</span>, <span class="token punctuation">{</span>st_mode<span class="token operator">=</span>S_IFREG<span class="token operator">|</span>0755, <span class="token assign-left variable">st_size</span><span class="token operator">=</span><span class="token number">1571692</span>, <span class="token punctuation">..</span>.<span class="token punctuation">}</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">0</span>
</span><span class="code-line line-number" line="21">old_mmap<span class="token punctuation">(</span>NULL, <span class="token number">4096</span>, PROT_READ<span class="token operator">|</span>PROT_WRITE, MAP_PRIVATE<span class="token operator">|</span>MAP_ANONYMOUS, -1, <span class="token number">0</span><span class="token punctuation">)</span> <span class="token operator">=</span> 0xbf5ee000
</span><span class="code-line line-number" line="22">old_mmap<span class="token punctuation">(</span>NULL, <span class="token number">1275340</span>, PROT_READ<span class="token operator">|</span>PROT_EXEC, MAP_PRIVATE, <span class="token number">3</span>, <span class="token number">0</span><span class="token punctuation">)</span> <span class="token operator">=</span> 0xa02000
</span><span class="code-line line-number" line="23">old_mmap<span class="token punctuation">(</span>0xb34000, <span class="token number">12288</span>, PROT_READ<span class="token operator">|</span>PROT_WRITE, MAP_PRIVATE<span class="token operator">|</span>MAP_FIXED, <span class="token number">3</span>, 0x132000<span class="token punctuation">)</span> <span class="token operator">=</span> 0xb34000
</span><span class="code-line line-number" line="24">old_mmap<span class="token punctuation">(</span>0xb37000, <span class="token number">9676</span>, PROT_READ<span class="token operator">|</span>PROT_WRITE, MAP_PRIVATE<span class="token operator">|</span>MAP_FIXED<span class="token operator">|</span>MAP_ANONYMOUS, -1, <span class="token number">0</span><span class="token punctuation">)</span> <span class="token operator">=</span> 0xb37000
</span><span class="code-line line-number" line="25">close<span class="token punctuation">(</span><span class="token number">3</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">0</span>
</span><span class="code-line line-number" line="26">set_thread_area<span class="token punctuation">(</span><span class="token punctuation">{</span>entry_number:-1 -<span class="token operator">></span> <span class="token number">6</span>, base_addr:0xbf5ee740, limit:1048575, seg_32bit:1, contents:0, read_exec_only:0, limit_in_pages:1, seg_not_present:0, useable:1<span class="token punctuation">}</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">0</span>
</span><span class="code-line line-number" line="27">munmap<span class="token punctuation">(</span>0xbf5ef000, <span class="token number">65900</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">0</span>
</span><span class="code-line line-number" line="28">fstat64<span class="token punctuation">(</span><span class="token number">0</span>, <span class="token punctuation">{</span>st_mode<span class="token operator">=</span>S_IFCHR<span class="token operator">|</span>0620, <span class="token assign-left variable">st_rdev</span><span class="token operator">=</span>makedev<span class="token punctuation">(</span><span class="token number">136</span>, <span class="token number">0</span><span class="token punctuation">)</span>, <span class="token punctuation">..</span>.<span class="token punctuation">}</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">0</span>
</span><span class="code-line line-number" line="29">mmap2<span class="token punctuation">(</span>NULL, <span class="token number">4096</span>, PROT_READ<span class="token operator">|</span>PROT_WRITE, MAP_PRIVATE<span class="token operator">|</span>MAP_ANONYMOUS, -1, <span class="token number">0</span><span class="token punctuation">)</span> <span class="token operator">=</span> 0xbf5ff000
</span><span class="code-line line-number" line="30">read<span class="token punctuation">(</span><span class="token number">0</span>, <span class="token number">99</span>
</span><span class="code-line line-number" line="31"><span class="token string">"99<span class="token entity" title="\n">\n</span>"</span>, <span class="token number">1024</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">3</span>
</span><span class="code-line line-number" line="32">fstat64<span class="token punctuation">(</span><span class="token number">1</span>, <span class="token punctuation">{</span>st_mode<span class="token operator">=</span>S_IFCHR<span class="token operator">|</span>0620, <span class="token assign-left variable">st_rdev</span><span class="token operator">=</span>makedev<span class="token punctuation">(</span><span class="token number">136</span>, <span class="token number">0</span><span class="token punctuation">)</span>, <span class="token punctuation">..</span>.<span class="token punctuation">}</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">0</span>
</span><span class="code-line line-number" line="33">mmap2<span class="token punctuation">(</span>NULL, <span class="token number">4096</span>, PROT_READ<span class="token operator">|</span>PROT_WRITE, MAP_PRIVATE<span class="token operator">|</span>MAP_ANONYMOUS, -1, <span class="token number">0</span><span class="token punctuation">)</span> <span class="token operator">=</span> 0xbf5fe000
</span><span class="code-line line-number" line="34">write<span class="token punctuation">(</span><span class="token number">1</span>, <span class="token string">"000000099<span class="token entity" title="\n">\n</span>"</span>, <span class="token number">10000000099</span>
</span><span class="code-line line-number" line="35"><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">10</span>
</span><span class="code-line line-number" line="36">munmap<span class="token punctuation">(</span>0xbf5fe000, <span class="token number">4096</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">0</span>
</span><span class="code-line line-number" line="37">exit_group<span class="token punctuation">(</span><span class="token number">0</span><span class="token punctuation">)</span> <span class="token operator">=</span> ?
</span></code><div onclick="copied(this)" data-code="// 直接执行test的结果
oracle@orainst[orcl]:~ $./test
// 执行的结果
99
000000099
// 通过strace执行test的结果
oracle@orainst[orcl]:~ $strace ./test
// strace的trace结果
execve(&#x22;./test&#x22;, [&#x22;./test&#x22;], [/* 41 vars */]) = 0
uname({sys=&#x22;Linux&#x22;, node=&#x22;orainst.desktop.mycompany.com&#x22;, ...}) = 0
brk(0) = 0x8078000
fstat64(3, {st_mode=S_IFREG|0644, st_size=65900, ...}) = 0
old_mmap(NULL, 65900, PROT_READ, MAP_PRIVATE, 3, 0) = 0xbf5ef000
close(3) = 0
open(&#x22;/lib/tls/libc.so.6&#x22;, O_RDONLY) = 3
read(3, &#x22;\177ELF\1\1\1\0\0\0\0\0\0\0\0\0\3\0\3\0\1\0\0\0\200X\1&#x22;..., 512) = 512
fstat64(3, {st_mode=S_IFREG|0755, st_size=1571692, ...}) = 0
old_mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0xbf5ee000
old_mmap(NULL, 1275340, PROT_READ|PROT_EXEC, MAP_PRIVATE, 3, 0) = 0xa02000
old_mmap(0xb34000, 12288, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_FIXED, 3, 0x132000) = 0xb34000
old_mmap(0xb37000, 9676, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_FIXED|MAP_ANONYMOUS, -1, 0) = 0xb37000
close(3) = 0
set_thread_area({entry_number:-1 -> 6, base_addr:0xbf5ee740, limit:1048575, seg_32bit:1, contents:0, read_exec_only:0, limit_in_pages:1, seg_not_present:0, useable:1}) = 0
munmap(0xbf5ef000, 65900) = 0
fstat64(0, {st_mode=S_IFCHR|0620, st_rdev=makedev(136, 0), ...}) = 0
mmap2(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0xbf5ff000
read(0, 99
&#x22;99\n&#x22;, 1024) = 3
fstat64(1, {st_mode=S_IFCHR|0620, st_rdev=makedev(136, 0), ...}) = 0
mmap2(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0xbf5fe000
write(1, &#x22;000000099\n&#x22;, 10000000099
) = 10
munmap(0xbf5fe000, 4096) = 0
exit_group(0) = ?
" class="copied"><svg class="octicon-copy" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M0 6.75C0 5.784.784 5 1.75 5h1.5a.75.75 0 010 1.5h-1.5a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-1.5a.75.75 0 011.5 0v1.5A1.75 1.75 0 019.25 16h-7.5A1.75 1.75 0 010 14.25v-7.5z"></path><path fill-rule="evenodd" d="M5 1.75C5 .784 5.784 0 6.75 0h7.5C15.216 0 16 .784 16 1.75v7.5A1.75 1.75 0 0114.25 11h-7.5A1.75 1.75 0 015 9.25v-7.5zm1.75-.25a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-7.5a.25.25 0 00-.25-.25h-7.5z"></path></svg><svg class="octicon-check" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M13.78 4.22a.75.75 0 010 1.06l-7.25 7.25a.75.75 0 01-1.06 0L2.22 9.28a.75.75 0 011.06-1.06L6 10.94l6.72-6.72a.75.75 0 011.06 0z"></path></svg></div></pre>
<p>从trace结构可以看到系统首先调用execve开始一个新的进行接着进行些环境的初始化操作最后停顿在”read(0,”上面这也就是执行到了我们的scanf函数等待我们输入数字呢在输入完99之后在调用write函数将格式化后的数值”000000099″输出到屏幕最后调用exit_group退出进行完成整个程序的执行过程。</p>
<p><strong>跟踪信号传递</strong></p>
<p>我们还是使用上面的那个test程序来观察进程接收信号的情况。还是先<code>strace ./test</code>,等到等待输入的画面的时候不要输入任何东西,然后打开另外一个窗口,输入如下的命令</p>
<pre class="language-shell"><code class="language-shell code-highlight"><span class="code-line line-number" line="1"><span class="token function">killall</span> <span class="token builtin class-name">test</span>
</span></code><div onclick="copied(this)" data-code="killall test
" class="copied"><svg class="octicon-copy" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M0 6.75C0 5.784.784 5 1.75 5h1.5a.75.75 0 010 1.5h-1.5a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-1.5a.75.75 0 011.5 0v1.5A1.75 1.75 0 019.25 16h-7.5A1.75 1.75 0 010 14.25v-7.5z"></path><path fill-rule="evenodd" d="M5 1.75C5 .784 5.784 0 6.75 0h7.5C15.216 0 16 .784 16 1.75v7.5A1.75 1.75 0 0114.25 11h-7.5A1.75 1.75 0 015 9.25v-7.5zm1.75-.25a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-7.5a.25.25 0 00-.25-.25h-7.5z"></path></svg><svg class="octicon-check" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M13.78 4.22a.75.75 0 010 1.06l-7.25 7.25a.75.75 0 01-1.06 0L2.22 9.28a.75.75 0 011.06-1.06L6 10.94l6.72-6.72a.75.75 0 011.06 0z"></path></svg></div></pre>
<p>这时候就能看到我们的程序推出了最后的trace结果如下</p>
<pre class="language-shell"><code class="language-shell code-highlight"><span class="code-line line-number" line="1">oracle@orainst<span class="token punctuation">[</span>orcl<span class="token punctuation">]</span>:~
</span><span class="code-line line-number" line="2"><span class="token variable">$strace</span> ./test
</span><span class="code-line line-number" line="3">
</span><span class="code-line line-number" line="4">execve<span class="token punctuation">(</span><span class="token string">"./test"</span>, <span class="token punctuation">[</span><span class="token string">"./test"</span><span class="token punctuation">]</span>, <span class="token punctuation">[</span>/* <span class="token number">41</span> vars */<span class="token punctuation">]</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">0</span>
</span><span class="code-line line-number" line="5">uname<span class="token punctuation">(</span><span class="token punctuation">{</span>sys<span class="token operator">=</span><span class="token string">"Linux"</span>, <span class="token assign-left variable">node</span><span class="token operator">=</span><span class="token string">"orainst.desktop.mycompany.com"</span>, <span class="token punctuation">..</span>.<span class="token punctuation">}</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">0</span>
</span><span class="code-line line-number" line="6">brk<span class="token punctuation">(</span><span class="token number">0</span><span class="token punctuation">)</span> <span class="token operator">=</span> 0x9ae2000
</span><span class="code-line line-number" line="7">old_mmap<span class="token punctuation">(</span>NULL, <span class="token number">65900</span>, PROT_READ, MAP_PRIVATE, <span class="token number">3</span>, <span class="token number">0</span><span class="token punctuation">)</span> <span class="token operator">=</span> 0xbf5ef000
</span><span class="code-line line-number" line="8">close<span class="token punctuation">(</span><span class="token number">3</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">0</span>
</span><span class="code-line line-number" line="9">open<span class="token punctuation">(</span><span class="token string">"/lib/tls/libc.so.6"</span>, O_RDONLY<span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">3</span>
</span><span class="code-line line-number" line="10">read<span class="token punctuation">(</span><span class="token number">3</span>, <span class="token string">"<span class="token entity" title="\177">\177</span>ELF<span class="token entity" title="\1">\1</span><span class="token entity" title="\1">\1</span><span class="token entity" title="\1">\1</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\3">\3</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\3">\3</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\1">\1</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\200">\200</span>X<span class="token entity" title="\1">\1</span>"</span><span class="token punctuation">..</span>., <span class="token number">512</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">512</span>
</span><span class="code-line line-number" line="11">fstat64<span class="token punctuation">(</span><span class="token number">3</span>, <span class="token punctuation">{</span>st_mode<span class="token operator">=</span>S_IFREG<span class="token operator">|</span>0755, <span class="token assign-left variable">st_size</span><span class="token operator">=</span><span class="token number">1571692</span>, <span class="token punctuation">..</span>.<span class="token punctuation">}</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">0</span>
</span><span class="code-line line-number" line="12">old_mmap<span class="token punctuation">(</span>NULL, <span class="token number">4096</span>, PROT_READ<span class="token operator">|</span>PROT_WRITE, MAP_PRIVATE<span class="token operator">|</span>MAP_ANONYMOUS, -1, <span class="token number">0</span><span class="token punctuation">)</span> <span class="token operator">=</span> 0xbf5ee000
</span><span class="code-line line-number" line="13">old_mmap<span class="token punctuation">(</span>NULL, <span class="token number">1275340</span>, PROT_READ<span class="token operator">|</span>PROT_EXEC, MAP_PRIVATE, <span class="token number">3</span>, <span class="token number">0</span><span class="token punctuation">)</span> <span class="token operator">=</span> 0x2e9000
</span><span class="code-line line-number" line="14">old_mmap<span class="token punctuation">(</span>0x41b000, <span class="token number">12288</span>, PROT_READ<span class="token operator">|</span>PROT_WRITE, MAP_PRIVATE<span class="token operator">|</span>MAP_FIXED, <span class="token number">3</span>, 0x132000<span class="token punctuation">)</span> <span class="token operator">=</span> 0x41b000
</span><span class="code-line line-number" line="15">old_mmap<span class="token punctuation">(</span>0x41e000, <span class="token number">9676</span>, PROT_READ<span class="token operator">|</span>PROT_WRITE, MAP_PRIVATE<span class="token operator">|</span>MAP_FIXED<span class="token operator">|</span>MAP_ANONYMOUS, -1, <span class="token number">0</span><span class="token punctuation">)</span> <span class="token operator">=</span> 0x41e000
</span><span class="code-line line-number" line="16">close<span class="token punctuation">(</span><span class="token number">3</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">0</span>
</span><span class="code-line line-number" line="17">set_thread_area<span class="token punctuation">(</span><span class="token punctuation">{</span>entry_number:-1 -<span class="token operator">></span> <span class="token number">6</span>, base_addr:0xbf5ee740, limit:1048575, seg_32bit:1, contents:0, read_exec_only:0, limit_in_pages:1, seg_not_present:0, useable:1<span class="token punctuation">}</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">0</span>
</span><span class="code-line line-number" line="18">munmap<span class="token punctuation">(</span>0xbf5ef000, <span class="token number">65900</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">0</span>
</span><span class="code-line line-number" line="19">fstat64<span class="token punctuation">(</span><span class="token number">0</span>, <span class="token punctuation">{</span>st_mode<span class="token operator">=</span>S_IFCHR<span class="token operator">|</span>0620, <span class="token assign-left variable">st_rdev</span><span class="token operator">=</span>makedev<span class="token punctuation">(</span><span class="token number">136</span>, <span class="token number">0</span><span class="token punctuation">)</span>, <span class="token punctuation">..</span>.<span class="token punctuation">}</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">0</span>
</span><span class="code-line line-number" line="20">mmap2<span class="token punctuation">(</span>NULL, <span class="token number">4096</span>, PROT_READ<span class="token operator">|</span>PROT_WRITE, MAP_PRIVATE<span class="token operator">|</span>MAP_ANONYMOUS, -1, <span class="token number">0</span><span class="token punctuation">)</span> <span class="token operator">=</span> 0xbf5ff000
</span><span class="code-line line-number" line="21">read<span class="token punctuation">(</span><span class="token number">0</span>, 0xbf5ff000, <span class="token number">1024</span><span class="token punctuation">)</span> <span class="token operator">=</span> ? ERESTARTSYS <span class="token punctuation">(</span>To be restarted<span class="token punctuation">)</span>
</span><span class="code-line line-number" line="22">--- SIGTERM <span class="token punctuation">(</span>Terminated<span class="token punctuation">)</span> @ <span class="token number">0</span> <span class="token punctuation">(</span><span class="token number">0</span><span class="token punctuation">)</span> ---
</span><span class="code-line line-number" line="23">+++ killed by SIGTERM +++
</span></code><div onclick="copied(this)" data-code="oracle@orainst[orcl]:~
$strace ./test
execve(&#x22;./test&#x22;, [&#x22;./test&#x22;], [/* 41 vars */]) = 0
uname({sys=&#x22;Linux&#x22;, node=&#x22;orainst.desktop.mycompany.com&#x22;, ...}) = 0
brk(0) = 0x9ae2000
old_mmap(NULL, 65900, PROT_READ, MAP_PRIVATE, 3, 0) = 0xbf5ef000
close(3) = 0
open(&#x22;/lib/tls/libc.so.6&#x22;, O_RDONLY) = 3
read(3, &#x22;\177ELF\1\1\1\0\0\0\0\0\0\0\0\0\3\0\3\0\1\0\0\0\200X\1&#x22;..., 512) = 512
fstat64(3, {st_mode=S_IFREG|0755, st_size=1571692, ...}) = 0
old_mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0xbf5ee000
old_mmap(NULL, 1275340, PROT_READ|PROT_EXEC, MAP_PRIVATE, 3, 0) = 0x2e9000
old_mmap(0x41b000, 12288, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_FIXED, 3, 0x132000) = 0x41b000
old_mmap(0x41e000, 9676, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_FIXED|MAP_ANONYMOUS, -1, 0) = 0x41e000
close(3) = 0
set_thread_area({entry_number:-1 -> 6, base_addr:0xbf5ee740, limit:1048575, seg_32bit:1, contents:0, read_exec_only:0, limit_in_pages:1, seg_not_present:0, useable:1}) = 0
munmap(0xbf5ef000, 65900) = 0
fstat64(0, {st_mode=S_IFCHR|0620, st_rdev=makedev(136, 0), ...}) = 0
mmap2(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0xbf5ff000
read(0, 0xbf5ff000, 1024) = ? ERESTARTSYS (To be restarted)
--- SIGTERM (Terminated) @ 0 (0) ---
+++ killed by SIGTERM +++
" class="copied"><svg class="octicon-copy" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M0 6.75C0 5.784.784 5 1.75 5h1.5a.75.75 0 010 1.5h-1.5a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-1.5a.75.75 0 011.5 0v1.5A1.75 1.75 0 019.25 16h-7.5A1.75 1.75 0 010 14.25v-7.5z"></path><path fill-rule="evenodd" d="M5 1.75C5 .784 5.784 0 6.75 0h7.5C15.216 0 16 .784 16 1.75v7.5A1.75 1.75 0 0114.25 11h-7.5A1.75 1.75 0 015 9.25v-7.5zm1.75-.25a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-7.5a.25.25 0 00-.25-.25h-7.5z"></path></svg><svg class="octicon-check" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M13.78 4.22a.75.75 0 010 1.06l-7.25 7.25a.75.75 0 01-1.06 0L2.22 9.28a.75.75 0 011.06-1.06L6 10.94l6.72-6.72a.75.75 0 011.06 0z"></path></svg></div></pre>
<p>trace中很清楚的告诉你test进程”+++ killed by SIGTERM +++”。</p>
<p><strong>系统调用统计</strong></p>
<p>strace不光能追踪系统调用通过使用参数-c它还能将进程所有的系统调用做一个统计分析给你下面就来看看strace的统计这次我们执行带-c参数的strace</p>
<p>strace -c ./test</p>
<p>最后能得到这样的trace结果</p>
<pre class="language-shell"><code class="language-shell code-highlight"><span class="code-line line-number" line="1">oracle@orainst<span class="token punctuation">[</span>orcl<span class="token punctuation">]</span>:~
</span><span class="code-line line-number" line="2"><span class="token variable">$strace</span> <span class="token parameter variable">-c</span> ./test
</span></code><div onclick="copied(this)" data-code="oracle@orainst[orcl]:~
$strace -c ./test
" class="copied"><svg class="octicon-copy" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M0 6.75C0 5.784.784 5 1.75 5h1.5a.75.75 0 010 1.5h-1.5a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-1.5a.75.75 0 011.5 0v1.5A1.75 1.75 0 019.25 16h-7.5A1.75 1.75 0 010 14.25v-7.5z"></path><path fill-rule="evenodd" d="M5 1.75C5 .784 5.784 0 6.75 0h7.5C15.216 0 16 .784 16 1.75v7.5A1.75 1.75 0 0114.25 11h-7.5A1.75 1.75 0 015 9.25v-7.5zm1.75-.25a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-7.5a.25.25 0 00-.25-.25h-7.5z"></path></svg><svg class="octicon-check" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M13.78 4.22a.75.75 0 010 1.06l-7.25 7.25a.75.75 0 01-1.06 0L2.22 9.28a.75.75 0 011.06-1.06L6 10.94l6.72-6.72a.75.75 0 011.06 0z"></path></svg></div></pre>
<pre class="language-shell"><code class="language-shell code-highlight"><span class="code-line line-number" line="1">execve<span class="token punctuation">(</span><span class="token string">"./test"</span>, <span class="token punctuation">[</span><span class="token string">"./test"</span><span class="token punctuation">]</span>, <span class="token punctuation">[</span>/* <span class="token number">41</span> vars */<span class="token punctuation">]</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">0</span>
</span><span class="code-line line-number" line="2">% <span class="token function">time</span> seconds usecs/call calls errors syscall
</span><span class="code-line line-number" line="3">------ ----------- ----------- --------- --------- ----------------
</span><span class="code-line line-number" line="4"> <span class="token number">45.90</span> <span class="token number">0.000140</span> <span class="token number">5</span> <span class="token number">27</span> <span class="token number">25</span> <span class="token function">open</span>
</span><span class="code-line line-number" line="5"> <span class="token number">34.43</span> <span class="token number">0.000105</span> <span class="token number">4</span> <span class="token number">24</span> <span class="token number">21</span> stat64
</span><span class="code-line line-number" line="6"> <span class="token number">7.54</span> <span class="token number">0.000023</span> <span class="token number">5</span> <span class="token number">5</span> old_mmap
</span><span class="code-line line-number" line="7"> <span class="token number">2.62</span> <span class="token number">0.000008</span> <span class="token number">8</span> <span class="token number">1</span> munmap
</span><span class="code-line line-number" line="8"> <span class="token number">1.97</span> <span class="token number">0.000006</span> <span class="token number">6</span> <span class="token number">1</span> <span class="token function">uname</span>
</span><span class="code-line line-number" line="9"> <span class="token number">1.97</span> <span class="token number">0.000006</span> <span class="token number">2</span> <span class="token number">3</span> fstat64
</span><span class="code-line line-number" line="10"> <span class="token number">1.64</span> <span class="token number">0.000005</span> <span class="token number">3</span> <span class="token number">2</span> <span class="token number">1</span> <span class="token builtin class-name">read</span>
</span><span class="code-line line-number" line="11"> <span class="token number">1.31</span> <span class="token number">0.000004</span> <span class="token number">2</span> <span class="token number">2</span> close
</span><span class="code-line line-number" line="12"> <span class="token number">0.98</span> <span class="token number">0.000003</span> <span class="token number">3</span> <span class="token number">1</span> brk
</span><span class="code-line line-number" line="13"> <span class="token number">0.98</span> <span class="token number">0.000003</span> <span class="token number">3</span> <span class="token number">1</span> mmap2
</span><span class="code-line line-number" line="14"> <span class="token number">0.66</span> <span class="token number">0.000002</span> <span class="token number">2</span> <span class="token number">1</span> set_thread_area
</span><span class="code-line line-number" line="15">------ ----------- ----------- --------- --------- ----------------
</span><span class="code-line line-number" line="16"><span class="token number">100.00</span> <span class="token number">0.000305</span> <span class="token number">68</span> <span class="token number">47</span> total
</span></code><div onclick="copied(this)" data-code="execve(&#x22;./test&#x22;, [&#x22;./test&#x22;], [/* 41 vars */]) = 0
% time seconds usecs/call calls errors syscall
------ ----------- ----------- --------- --------- ----------------
45.90 0.000140 5 27 25 open
34.43 0.000105 4 24 21 stat64
7.54 0.000023 5 5 old_mmap
2.62 0.000008 8 1 munmap
1.97 0.000006 6 1 uname
1.97 0.000006 2 3 fstat64
1.64 0.000005 3 2 1 read
1.31 0.000004 2 2 close
0.98 0.000003 3 1 brk
0.98 0.000003 3 1 mmap2
0.66 0.000002 2 1 set_thread_area
------ ----------- ----------- --------- --------- ----------------
100.00 0.000305 68 47 total
" class="copied"><svg class="octicon-copy" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M0 6.75C0 5.784.784 5 1.75 5h1.5a.75.75 0 010 1.5h-1.5a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-1.5a.75.75 0 011.5 0v1.5A1.75 1.75 0 019.25 16h-7.5A1.75 1.75 0 010 14.25v-7.5z"></path><path fill-rule="evenodd" d="M5 1.75C5 .784 5.784 0 6.75 0h7.5C15.216 0 16 .784 16 1.75v7.5A1.75 1.75 0 0114.25 11h-7.5A1.75 1.75 0 015 9.25v-7.5zm1.75-.25a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-7.5a.25.25 0 00-.25-.25h-7.5z"></path></svg><svg class="octicon-check" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M13.78 4.22a.75.75 0 010 1.06l-7.25 7.25a.75.75 0 01-1.06 0L2.22 9.28a.75.75 0 011.06-1.06L6 10.94l6.72-6.72a.75.75 0 011.06 0z"></path></svg></div></pre>
<p>这里很清楚的告诉你调用了那些系统函数,调用次数多少,消耗了多少时间等等这些信息,这个对我们分析一个程序来说是非常有用的。</p>
<h3 id="常用参数说明"><a class="anchor" aria-hidden="true" tabindex="-1" href="#常用参数说明"><span class="octicon octicon-link"></span></a>常用参数说明</h3>
<p>除了-c参数之外strace还提供了其他有用的参数给我们让我们能很方便的得到自己想要的信息下面就对那些常用的参数一一做个介绍。</p>
<p><strong>重定向输出</strong></p>
<p>参数-o用在将strace的结果输出到文件中如果不指定-o参数的话默认的输出设备是STDERR也就是说使用”-o filename”和” 2>filename”的结果是一样的。</p>
<pre class="language-shell"><code class="language-shell code-highlight"><span class="code-line line-number" line="1"><span class="token comment"># 这两个命令都是将strace结果输出到文件test.txt中</span>
</span><span class="code-line line-number" line="2"><span class="token function">strace</span> <span class="token parameter variable">-c</span> <span class="token parameter variable">-o</span> test.txt ./test
</span><span class="code-line line-number" line="3"><span class="token function">strace</span> <span class="token parameter variable">-c</span> ./test <span class="token operator"><span class="token file-descriptor important">2</span>></span>test.txt
</span></code><div onclick="copied(this)" data-code="# 这两个命令都是将strace结果输出到文件test.txt中
strace -c -o test.txt ./test
strace -c ./test 2>test.txt
" class="copied"><svg class="octicon-copy" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M0 6.75C0 5.784.784 5 1.75 5h1.5a.75.75 0 010 1.5h-1.5a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-1.5a.75.75 0 011.5 0v1.5A1.75 1.75 0 019.25 16h-7.5A1.75 1.75 0 010 14.25v-7.5z"></path><path fill-rule="evenodd" d="M5 1.75C5 .784 5.784 0 6.75 0h7.5C15.216 0 16 .784 16 1.75v7.5A1.75 1.75 0 0114.25 11h-7.5A1.75 1.75 0 015 9.25v-7.5zm1.75-.25a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-7.5a.25.25 0 00-.25-.25h-7.5z"></path></svg><svg class="octicon-check" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M13.78 4.22a.75.75 0 010 1.06l-7.25 7.25a.75.75 0 01-1.06 0L2.22 9.28a.75.75 0 011.06-1.06L6 10.94l6.72-6.72a.75.75 0 011.06 0z"></path></svg></div></pre>
<p><strong>对系统调用进行计时</strong></p>
<p>strace可以使用参数-T将每个系统调用所花费的时间打印出来每个调用的时间花销现在在调用行最右边的尖括号里面。</p>
<pre class="language-shell"><code class="language-shell code-highlight"><span class="code-line line-number" line="1">oracle@orainst<span class="token punctuation">[</span>orcl<span class="token punctuation">]</span>:~
</span><span class="code-line line-number" line="2"><span class="token variable">$strace</span> <span class="token parameter variable">-T</span> ./test
</span><span class="code-line line-number" line="3">
</span><span class="code-line line-number" line="4">// 这里只摘录部分结果
</span><span class="code-line line-number" line="5">read<span class="token punctuation">(</span><span class="token number">0</span>, <span class="token number">1</span>
</span><span class="code-line line-number" line="6"><span class="token string">"1<span class="token entity" title="\n">\n</span>"</span>, <span class="token number">1024</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">2</span> <span class="token operator">&#x3C;</span><span class="token number">2.67345</span><span class="token operator"><span class="token file-descriptor important">5</span>></span>
</span><span class="code-line line-number" line="7">fstat64<span class="token punctuation">(</span><span class="token number">1</span>, <span class="token punctuation">{</span>st_mode<span class="token operator">=</span>S_IFCHR<span class="token operator">|</span>0620, <span class="token assign-left variable">st_rdev</span><span class="token operator">=</span>makedev<span class="token punctuation">(</span><span class="token number">136</span>, <span class="token number">0</span><span class="token punctuation">)</span>, <span class="token punctuation">..</span>.<span class="token punctuation">}</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">0</span> <span class="token operator">&#x3C;</span><span class="token number">0.00001</span><span class="token operator"><span class="token file-descriptor important">4</span>></span>
</span><span class="code-line line-number" line="8">mmap2<span class="token punctuation">(</span>NULL, <span class="token number">4096</span>, PROT_READ<span class="token operator">|</span>PROT_WRITE, MAP_PRIVATE<span class="token operator">|</span>MAP_ANONYMOUS, -1, <span class="token number">0</span><span class="token punctuation">)</span> <span class="token operator">=</span> 0xbf5fe000 <span class="token operator">&#x3C;</span><span class="token number">0.00001</span><span class="token operator"><span class="token file-descriptor important">7</span>></span>
</span><span class="code-line line-number" line="9">write<span class="token punctuation">(</span><span class="token number">1</span>, <span class="token string">"000000001<span class="token entity" title="\n">\n</span>"</span>, <span class="token number">10000000001</span>
</span><span class="code-line line-number" line="10"><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">10</span> <span class="token operator">&#x3C;</span><span class="token number">0.00001</span><span class="token operator"><span class="token file-descriptor important">6</span>></span>
</span><span class="code-line line-number" line="11">munmap<span class="token punctuation">(</span>0xbf5fe000, <span class="token number">4096</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">0</span> <span class="token operator">&#x3C;</span><span class="token number">0.00002</span><span class="token operator"><span class="token file-descriptor important">0</span>></span>
</span><span class="code-line line-number" line="12">exit_group<span class="token punctuation">(</span><span class="token number">0</span><span class="token punctuation">)</span> <span class="token operator">=</span> ?
</span></code><div onclick="copied(this)" data-code="oracle@orainst[orcl]:~
$strace -T ./test
// 这里只摘录部分结果
read(0, 1
&#x22;1\n&#x22;, 1024) = 2 <2.673455>
fstat64(1, {st_mode=S_IFCHR|0620, st_rdev=makedev(136, 0), ...}) = 0 <0.000014>
mmap2(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0xbf5fe000 <0.000017>
write(1, &#x22;000000001\n&#x22;, 10000000001
) = 10 <0.000016>
munmap(0xbf5fe000, 4096) = 0 <0.000020>
exit_group(0) = ?
" class="copied"><svg class="octicon-copy" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M0 6.75C0 5.784.784 5 1.75 5h1.5a.75.75 0 010 1.5h-1.5a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-1.5a.75.75 0 011.5 0v1.5A1.75 1.75 0 019.25 16h-7.5A1.75 1.75 0 010 14.25v-7.5z"></path><path fill-rule="evenodd" d="M5 1.75C5 .784 5.784 0 6.75 0h7.5C15.216 0 16 .784 16 1.75v7.5A1.75 1.75 0 0114.25 11h-7.5A1.75 1.75 0 015 9.25v-7.5zm1.75-.25a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-7.5a.25.25 0 00-.25-.25h-7.5z"></path></svg><svg class="octicon-check" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M13.78 4.22a.75.75 0 010 1.06l-7.25 7.25a.75.75 0 01-1.06 0L2.22 9.28a.75.75 0 011.06-1.06L6 10.94l6.72-6.72a.75.75 0 011.06 0z"></path></svg></div></pre>
<p><strong>系统调用的时间</strong></p>
<p>这是一个很有用的功能strace会将每次系统调用的发生时间记录下来只要使用-t/tt/ttt三个参数就可以看到效果了具体的例子可以自己去尝试。</p>
<table>
<thead>
<tr>
<th>参数名</th>
<th>输出样式</th>
<th>说明</th>
</tr>
</thead>
<tbody>
<tr>
<td>-t</td>
<td>10:33:04 exit_group(0)</td>
<td>输出结果精确到秒</td>
</tr>
<tr>
<td>-tt</td>
<td>10:33:48.159682 exit_group(0)</td>
<td>输出结果精确到微妙</td>
</tr>
<tr>
<td>-ttt</td>
<td>1262169244.788478 exit_group(0)</td>
<td>精确到微妙而且时间表示为unix时间戳</td>
</tr>
</tbody>
</table>
<p><strong>截断输出</strong></p>
<p>-s参数用于指定trace结果的每一行输出的字符串的长度下面看看test程序中-s参数对结果有什么影响现指定-s为20然后在read的是是很我们输入一个超过20个字符的数字串</p>
<pre class="language-shell"><code class="language-shell code-highlight"><span class="code-line line-number" line="1"><span class="token function">strace</span> <span class="token parameter variable">-s</span> <span class="token number">20</span> ./test
</span><span class="code-line line-number" line="2">
</span><span class="code-line line-number" line="3">read<span class="token punctuation">(</span><span class="token number">0</span>, <span class="token number">2222222222222222222222222</span> // 我们输入的2一共有25个
</span><span class="code-line line-number" line="4"><span class="token string">"22222222222222222222"</span><span class="token punctuation">..</span>., <span class="token number">1024</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">26</span> // 而我们看到的结果中2只有20个
</span></code><div onclick="copied(this)" data-code="strace -s 20 ./test
read(0, 2222222222222222222222222 // 我们输入的2一共有25个
&#x22;22222222222222222222&#x22;..., 1024) = 26 // 而我们看到的结果中2只有20个
" class="copied"><svg class="octicon-copy" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M0 6.75C0 5.784.784 5 1.75 5h1.5a.75.75 0 010 1.5h-1.5a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-1.5a.75.75 0 011.5 0v1.5A1.75 1.75 0 019.25 16h-7.5A1.75 1.75 0 010 14.25v-7.5z"></path><path fill-rule="evenodd" d="M5 1.75C5 .784 5.784 0 6.75 0h7.5C15.216 0 16 .784 16 1.75v7.5A1.75 1.75 0 0114.25 11h-7.5A1.75 1.75 0 015 9.25v-7.5zm1.75-.25a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-7.5a.25.25 0 00-.25-.25h-7.5z"></path></svg><svg class="octicon-check" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M13.78 4.22a.75.75 0 010 1.06l-7.25 7.25a.75.75 0 01-1.06 0L2.22 9.28a.75.75 0 011.06-1.06L6 10.94l6.72-6.72a.75.75 0 011.06 0z"></path></svg></div></pre>
<p><strong>trace一个现有的进程</strong></p>
<p>strace不光能自己初始化一个进程进行trace还能追踪现有的进程参数-p就是取这个作用的用法也很简单具体如下。</p>
<pre class="language-shell"><code class="language-shell code-highlight"><span class="code-line line-number" line="1"><span class="token function">strace</span> <span class="token parameter variable">-p</span> pid
</span></code><div onclick="copied(this)" data-code="strace -p pid
" class="copied"><svg class="octicon-copy" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M0 6.75C0 5.784.784 5 1.75 5h1.5a.75.75 0 010 1.5h-1.5a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-1.5a.75.75 0 011.5 0v1.5A1.75 1.75 0 019.25 16h-7.5A1.75 1.75 0 010 14.25v-7.5z"></path><path fill-rule="evenodd" d="M5 1.75C5 .784 5.784 0 6.75 0h7.5C15.216 0 16 .784 16 1.75v7.5A1.75 1.75 0 0114.25 11h-7.5A1.75 1.75 0 015 9.25v-7.5zm1.75-.25a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-7.5a.25.25 0 00-.25-.25h-7.5z"></path></svg><svg class="octicon-check" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M13.78 4.22a.75.75 0 010 1.06l-7.25 7.25a.75.75 0 01-1.06 0L2.22 9.28a.75.75 0 011.06-1.06L6 10.94l6.72-6.72a.75.75 0 011.06 0z"></path></svg></div></pre>
<h3 id="综合例子"><a class="anchor" aria-hidden="true" tabindex="-1" href="#综合例子"><span class="octicon octicon-link"></span></a>综合例子</h3>
<p>说了那么多的功能和参数现在我们来一个实用点的就是研究下Oracle的lgwr进程看看这个进程是不是像文档所说的那样没3s钟写一次log文件考虑到lgwr写日志的触发条件比较多我们需要找一个空闲的Oracle实例做这个实验。</p>
<p>我们先要得到lgwr进程的pid运行下面的命令</p>
<pre class="language-shell"><code class="language-shell code-highlight"><span class="code-line line-number" line="1"><span class="token function">ps</span> -ef<span class="token operator">|</span><span class="token function">grep</span> lgwr
</span><span class="code-line line-number" line="2">
</span><span class="code-line line-number" line="3">oracle <span class="token number">5912</span> <span class="token number">1</span> <span class="token number">0</span> Nov12 ? 00:14:56 ora_lgwr_orcl
</span></code><div onclick="copied(this)" data-code="ps -ef|grep lgwr
oracle 5912 1 0 Nov12 ? 00:14:56 ora_lgwr_orcl
" class="copied"><svg class="octicon-copy" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M0 6.75C0 5.784.784 5 1.75 5h1.5a.75.75 0 010 1.5h-1.5a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-1.5a.75.75 0 011.5 0v1.5A1.75 1.75 0 019.25 16h-7.5A1.75 1.75 0 010 14.25v-7.5z"></path><path fill-rule="evenodd" d="M5 1.75C5 .784 5.784 0 6.75 0h7.5C15.216 0 16 .784 16 1.75v7.5A1.75 1.75 0 0114.25 11h-7.5A1.75 1.75 0 015 9.25v-7.5zm1.75-.25a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-7.5a.25.25 0 00-.25-.25h-7.5z"></path></svg><svg class="octicon-check" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M13.78 4.22a.75.75 0 010 1.06l-7.25 7.25a.75.75 0 01-1.06 0L2.22 9.28a.75.75 0 011.06-1.06L6 10.94l6.72-6.72a.75.75 0 011.06 0z"></path></svg></div></pre>
<p>得到lgwr的pid是5912现在启动strace然后将trace的几个输出到lgwr.txt文件中执行下面的命令</p>
<pre class="language-shell"><code class="language-shell code-highlight"><span class="code-line line-number" line="1"><span class="token function">strace</span> <span class="token parameter variable">-tt</span> <span class="token parameter variable">-s</span> <span class="token number">10</span> <span class="token parameter variable">-o</span> lgwr.txt <span class="token parameter variable">-p</span> <span class="token number">5912</span>
</span></code><div onclick="copied(this)" data-code="strace -tt -s 10 -o lgwr.txt -p 5912
" class="copied"><svg class="octicon-copy" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M0 6.75C0 5.784.784 5 1.75 5h1.5a.75.75 0 010 1.5h-1.5a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-1.5a.75.75 0 011.5 0v1.5A1.75 1.75 0 019.25 16h-7.5A1.75 1.75 0 010 14.25v-7.5z"></path><path fill-rule="evenodd" d="M5 1.75C5 .784 5.784 0 6.75 0h7.5C15.216 0 16 .784 16 1.75v7.5A1.75 1.75 0 0114.25 11h-7.5A1.75 1.75 0 015 9.25v-7.5zm1.75-.25a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-7.5a.25.25 0 00-.25-.25h-7.5z"></path></svg><svg class="octicon-check" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M13.78 4.22a.75.75 0 010 1.06l-7.25 7.25a.75.75 0 01-1.06 0L2.22 9.28a.75.75 0 011.06-1.06L6 10.94l6.72-6.72a.75.75 0 011.06 0z"></path></svg></div></pre>
<p>过一会之后停止strace然后查看结果。由于输出的结果比较多为了方便我们只看Oracle写入log文件时用的pwrite函数的调用</p>
<pre class="language-shell"><code class="language-shell code-highlight"><span class="code-line line-number" line="1"><span class="token function">grep</span> pwrite<span class="token punctuation">\</span><span class="token punctuation">(</span><span class="token number">20</span> lgwr.txt
</span></code><div onclick="copied(this)" data-code="grep pwrite\(20 lgwr.txt
" class="copied"><svg class="octicon-copy" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M0 6.75C0 5.784.784 5 1.75 5h1.5a.75.75 0 010 1.5h-1.5a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-1.5a.75.75 0 011.5 0v1.5A1.75 1.75 0 019.25 16h-7.5A1.75 1.75 0 010 14.25v-7.5z"></path><path fill-rule="evenodd" d="M5 1.75C5 .784 5.784 0 6.75 0h7.5C15.216 0 16 .784 16 1.75v7.5A1.75 1.75 0 0114.25 11h-7.5A1.75 1.75 0 015 9.25v-7.5zm1.75-.25a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-7.5a.25.25 0 00-.25-.25h-7.5z"></path></svg><svg class="octicon-check" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M13.78 4.22a.75.75 0 010 1.06l-7.25 7.25a.75.75 0 01-1.06 0L2.22 9.28a.75.75 0 011.06-1.06L6 10.94l6.72-6.72a.75.75 0 011.06 0z"></path></svg></div></pre>
<p>等等为什么grep的时候用的是”pwrite(2″呢因为我知道我这个机器打开的当前的log文件的句柄编号都是2开始的。具体查找方法是先使用下面的语句找出当前活动的日志文件都有哪些</p>
<pre class="language-shell"><code class="language-shell code-highlight"><span class="code-line line-number" line="1"><span class="token keyword">select</span> member, <span class="token function">v</span><span class="token variable">$log</span>.status from <span class="token function">v</span><span class="token variable">$log</span>, <span class="token function">v</span><span class="token variable">$logfile</span>
</span><span class="code-line line-number" line="2">where <span class="token function">v</span><span class="token variable">$log</span>.group<span class="token comment">#=v$logfile.group#;</span>
</span></code><div onclick="copied(this)" data-code="select member, v$log.status from v$log, v$logfile
where v$log.group#=v$logfile.group#;
" class="copied"><svg class="octicon-copy" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M0 6.75C0 5.784.784 5 1.75 5h1.5a.75.75 0 010 1.5h-1.5a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-1.5a.75.75 0 011.5 0v1.5A1.75 1.75 0 019.25 16h-7.5A1.75 1.75 0 010 14.25v-7.5z"></path><path fill-rule="evenodd" d="M5 1.75C5 .784 5.784 0 6.75 0h7.5C15.216 0 16 .784 16 1.75v7.5A1.75 1.75 0 0114.25 11h-7.5A1.75 1.75 0 015 9.25v-7.5zm1.75-.25a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-7.5a.25.25 0 00-.25-.25h-7.5z"></path></svg><svg class="octicon-check" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M13.78 4.22a.75.75 0 010 1.06l-7.25 7.25a.75.75 0 01-1.06 0L2.22 9.28a.75.75 0 011.06-1.06L6 10.94l6.72-6.72a.75.75 0 011.06 0z"></path></svg></div></pre>
<p>得到</p>
<pre class="language-shell"><code class="language-shell code-highlight"><span class="code-line line-number" line="1">MEMBER STATUS
</span><span class="code-line line-number" line="2">-------------------------------------------------- ----------------
</span><span class="code-line line-number" line="3">/db/databases/orcl/redo-01-a/redo-t01-g03-m1.log INACTIVE
</span><span class="code-line line-number" line="4">/db/databases/orcl/redo-03-a/redo-t01-g03-m2.log INACTIVE
</span><span class="code-line line-number" line="5">/db/databases/orcl/redo-02-a/redo-t01-g02-m1.log CURRENT
</span><span class="code-line line-number" line="6">/db/databases/orcl/redo-04-a/redo-t01-g02-m2.log CURRENT
</span><span class="code-line line-number" line="7">/db/databases/orcl/redo-01-a/redo-t01-g01-m1.log INACTIVE
</span><span class="code-line line-number" line="8">/db/databases/orcl/redo-03-a/redo-t01-g01-m2.log INACTIVE
</span><span class="code-line line-number" line="9">/db/databases/orcl/redo-02-a/redo-t01-g04-m1.log INACTIVE
</span><span class="code-line line-number" line="10">/db/databases/orcl/redo-04-a/redo-t01-g04-m2.log INACTIVE
</span></code><div onclick="copied(this)" data-code="MEMBER STATUS
-------------------------------------------------- ----------------
/db/databases/orcl/redo-01-a/redo-t01-g03-m1.log INACTIVE
/db/databases/orcl/redo-03-a/redo-t01-g03-m2.log INACTIVE
/db/databases/orcl/redo-02-a/redo-t01-g02-m1.log CURRENT
/db/databases/orcl/redo-04-a/redo-t01-g02-m2.log CURRENT
/db/databases/orcl/redo-01-a/redo-t01-g01-m1.log INACTIVE
/db/databases/orcl/redo-03-a/redo-t01-g01-m2.log INACTIVE
/db/databases/orcl/redo-02-a/redo-t01-g04-m1.log INACTIVE
/db/databases/orcl/redo-04-a/redo-t01-g04-m2.log INACTIVE
" class="copied"><svg class="octicon-copy" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M0 6.75C0 5.784.784 5 1.75 5h1.5a.75.75 0 010 1.5h-1.5a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-1.5a.75.75 0 011.5 0v1.5A1.75 1.75 0 019.25 16h-7.5A1.75 1.75 0 010 14.25v-7.5z"></path><path fill-rule="evenodd" d="M5 1.75C5 .784 5.784 0 6.75 0h7.5C15.216 0 16 .784 16 1.75v7.5A1.75 1.75 0 0114.25 11h-7.5A1.75 1.75 0 015 9.25v-7.5zm1.75-.25a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-7.5a.25.25 0 00-.25-.25h-7.5z"></path></svg><svg class="octicon-check" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M13.78 4.22a.75.75 0 010 1.06l-7.25 7.25a.75.75 0 01-1.06 0L2.22 9.28a.75.75 0 011.06-1.06L6 10.94l6.72-6.72a.75.75 0 011.06 0z"></path></svg></div></pre>
<p>然后到/proc中去找打开文件的句柄</p>
<pre class="language-shell"><code class="language-shell code-highlight"><span class="code-line line-number" line="1">ll /proc/.5912/fd/
</span></code><div onclick="copied(this)" data-code="ll /proc/.5912/fd/
" class="copied"><svg class="octicon-copy" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M0 6.75C0 5.784.784 5 1.75 5h1.5a.75.75 0 010 1.5h-1.5a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-1.5a.75.75 0 011.5 0v1.5A1.75 1.75 0 019.25 16h-7.5A1.75 1.75 0 010 14.25v-7.5z"></path><path fill-rule="evenodd" d="M5 1.75C5 .784 5.784 0 6.75 0h7.5C15.216 0 16 .784 16 1.75v7.5A1.75 1.75 0 0114.25 11h-7.5A1.75 1.75 0 015 9.25v-7.5zm1.75-.25a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-7.5a.25.25 0 00-.25-.25h-7.5z"></path></svg><svg class="octicon-check" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M13.78 4.22a.75.75 0 010 1.06l-7.25 7.25a.75.75 0 01-1.06 0L2.22 9.28a.75.75 0 011.06-1.06L6 10.94l6.72-6.72a.75.75 0 011.06 0z"></path></svg></div></pre>
<p>得到</p>
<pre class="language-shell"><code class="language-shell code-highlight"><span class="code-line line-number" line="1">lrwx------ <span class="token number">1</span> oracle dba <span class="token number">64</span> Dec <span class="token number">30</span> <span class="token number">10</span>:55 <span class="token number">18</span> -<span class="token operator">></span> /db/databases/orcl/redo-01-a/redo-t01-g01-m1.log
</span><span class="code-line line-number" line="2">lrwx------ <span class="token number">1</span> oracle dba <span class="token number">64</span> Dec <span class="token number">30</span> <span class="token number">10</span>:55 <span class="token number">19</span> -<span class="token operator">></span> /db/databases/orcl/redo-03-a/redo-t01-g01-m2.log
</span><span class="code-line line-number" line="3">lrwx------ <span class="token number">1</span> oracle dba <span class="token number">64</span> Dec <span class="token number">30</span> <span class="token number">10</span>:55 <span class="token number">20</span> -<span class="token operator">></span> /db/databases/orcl/redo-02-a/redo-t01-g02-m1.log
</span><span class="code-line line-number" line="4">lrwx------ <span class="token number">1</span> oracle dba <span class="token number">64</span> Dec <span class="token number">30</span> <span class="token number">10</span>:55 <span class="token number">21</span> -<span class="token operator">></span> /db/databases/orcl/redo-04-a/redo-t01-g02-m2.log
</span><span class="code-line line-number" line="5">lrwx------ <span class="token number">1</span> oracle dba <span class="token number">64</span> Dec <span class="token number">30</span> <span class="token number">10</span>:55 <span class="token number">22</span> -<span class="token operator">></span> /db/databases/orcl/redo-01-a/redo-t01-g03-m1.log
</span><span class="code-line line-number" line="6">lrwx------ <span class="token number">1</span> oracle dba <span class="token number">64</span> Dec <span class="token number">30</span> <span class="token number">10</span>:55 <span class="token number">23</span> -<span class="token operator">></span> /db/databases/orcl/redo-03-a/redo-t01-g03-m2.log
</span><span class="code-line line-number" line="7">lrwx------ <span class="token number">1</span> oracle dba <span class="token number">64</span> Dec <span class="token number">30</span> <span class="token number">10</span>:55 <span class="token number">24</span> -<span class="token operator">></span> /db/databases/orcl/redo-02-a/redo-t01-g04-m1.log
</span><span class="code-line line-number" line="8">lrwx------ <span class="token number">1</span> oracle dba <span class="token number">64</span> Dec <span class="token number">30</span> <span class="token number">10</span>:55 <span class="token number">25</span> -<span class="token operator">></span> /db/databases/orcl/redo-04-a/redo-t01-g04-m2.log
</span></code><div onclick="copied(this)" data-code="lrwx------ 1 oracle dba 64 Dec 30 10:55 18 -> /db/databases/orcl/redo-01-a/redo-t01-g01-m1.log
lrwx------ 1 oracle dba 64 Dec 30 10:55 19 -> /db/databases/orcl/redo-03-a/redo-t01-g01-m2.log
lrwx------ 1 oracle dba 64 Dec 30 10:55 20 -> /db/databases/orcl/redo-02-a/redo-t01-g02-m1.log
lrwx------ 1 oracle dba 64 Dec 30 10:55 21 -> /db/databases/orcl/redo-04-a/redo-t01-g02-m2.log
lrwx------ 1 oracle dba 64 Dec 30 10:55 22 -> /db/databases/orcl/redo-01-a/redo-t01-g03-m1.log
lrwx------ 1 oracle dba 64 Dec 30 10:55 23 -> /db/databases/orcl/redo-03-a/redo-t01-g03-m2.log
lrwx------ 1 oracle dba 64 Dec 30 10:55 24 -> /db/databases/orcl/redo-02-a/redo-t01-g04-m1.log
lrwx------ 1 oracle dba 64 Dec 30 10:55 25 -> /db/databases/orcl/redo-04-a/redo-t01-g04-m2.log
" class="copied"><svg class="octicon-copy" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M0 6.75C0 5.784.784 5 1.75 5h1.5a.75.75 0 010 1.5h-1.5a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-1.5a.75.75 0 011.5 0v1.5A1.75 1.75 0 019.25 16h-7.5A1.75 1.75 0 010 14.25v-7.5z"></path><path fill-rule="evenodd" d="M5 1.75C5 .784 5.784 0 6.75 0h7.5C15.216 0 16 .784 16 1.75v7.5A1.75 1.75 0 0114.25 11h-7.5A1.75 1.75 0 015 9.25v-7.5zm1.75-.25a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-7.5a.25.25 0 00-.25-.25h-7.5z"></path></svg><svg class="octicon-check" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M13.78 4.22a.75.75 0 010 1.06l-7.25 7.25a.75.75 0 01-1.06 0L2.22 9.28a.75.75 0 011.06-1.06L6 10.94l6.72-6.72a.75.75 0 011.06 0z"></path></svg></div></pre>
<p>现在能看到我机器当前日志文件的句柄分别是20和21。</p>
<p>现在我们得到如下结果</p>
<pre class="language-shell"><code class="language-shell code-highlight"><span class="code-line line-number" line="1"><span class="token number">11</span>:13:55.603245 pwrite<span class="token punctuation">(</span><span class="token number">20</span>, <span class="token string">"<span class="token entity" title="\1">\1</span><span class="token entity" title="\&#x22;">\"</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span>J!"</span><span class="token punctuation">..</span>., <span class="token number">1536</span>, <span class="token number">4363264</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">1536</span>
</span><span class="code-line line-number" line="2"><span class="token number">11</span>:13:55.603569 pwrite<span class="token punctuation">(</span><span class="token number">21</span>, <span class="token string">"<span class="token entity" title="\1">\1</span><span class="token entity" title="\&#x22;">\"</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span>J!"</span><span class="token punctuation">..</span>., <span class="token number">1536</span>, <span class="token number">4363264</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">1536</span>
</span><span class="code-line line-number" line="3"><span class="token number">11</span>:13:55.606888 pwrite<span class="token punctuation">(</span><span class="token number">20</span>, <span class="token string">"<span class="token entity" title="\1">\1</span><span class="token entity" title="\&#x22;">\"</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span>M!"</span><span class="token punctuation">..</span>., <span class="token number">1536</span>, <span class="token number">4364800</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">1536</span>
</span><span class="code-line line-number" line="4"><span class="token number">11</span>:13:55.607172 pwrite<span class="token punctuation">(</span><span class="token number">21</span>, <span class="token string">"<span class="token entity" title="\1">\1</span><span class="token entity" title="\&#x22;">\"</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span>M!"</span><span class="token punctuation">..</span>., <span class="token number">1536</span>, <span class="token number">4364800</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">1536</span>
</span><span class="code-line line-number" line="5"><span class="token number">11</span>:13:55.607934 pwrite<span class="token punctuation">(</span><span class="token number">20</span>, <span class="token string">"<span class="token entity" title="\1">\1</span><span class="token entity" title="\&#x22;">\"</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span>P!"</span><span class="token punctuation">..</span>., <span class="token number">1536</span>, <span class="token number">4366336</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">1536</span>
</span><span class="code-line line-number" line="6"><span class="token number">11</span>:13:55.608199 pwrite<span class="token punctuation">(</span><span class="token number">21</span>, <span class="token string">"<span class="token entity" title="\1">\1</span><span class="token entity" title="\&#x22;">\"</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span>P!"</span><span class="token punctuation">..</span>., <span class="token number">1536</span>, <span class="token number">4366336</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">1536</span>
</span><span class="code-line line-number" line="7"><span class="token number">11</span>:13:55.610260 pwrite<span class="token punctuation">(</span><span class="token number">20</span>, <span class="token string">"<span class="token entity" title="\1">\1</span><span class="token entity" title="\&#x22;">\"</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span>S!"</span><span class="token punctuation">..</span>., <span class="token number">1536</span>, <span class="token number">4367872</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">1536</span>
</span><span class="code-line line-number" line="8"><span class="token number">11</span>:13:55.610530 pwrite<span class="token punctuation">(</span><span class="token number">21</span>, <span class="token string">"<span class="token entity" title="\1">\1</span><span class="token entity" title="\&#x22;">\"</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span>S!"</span><span class="token punctuation">..</span>., <span class="token number">1536</span>, <span class="token number">4367872</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">1536</span>
</span><span class="code-line line-number" line="9"><span class="token number">11</span>:14:00.602446 pwrite<span class="token punctuation">(</span><span class="token number">20</span>, <span class="token string">"<span class="token entity" title="\1">\1</span><span class="token entity" title="\&#x22;">\"</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span>V!"</span><span class="token punctuation">..</span>., <span class="token number">1536</span>, <span class="token number">4369408</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">1536</span>
</span><span class="code-line line-number" line="10"><span class="token number">11</span>:14:00.602750 pwrite<span class="token punctuation">(</span><span class="token number">21</span>, <span class="token string">"<span class="token entity" title="\1">\1</span><span class="token entity" title="\&#x22;">\"</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span>V!"</span><span class="token punctuation">..</span>., <span class="token number">1536</span>, <span class="token number">4369408</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">1536</span>
</span><span class="code-line line-number" line="11"><span class="token number">11</span>:14:00.606386 pwrite<span class="token punctuation">(</span><span class="token number">20</span>, <span class="token string">"<span class="token entity" title="\1">\1</span><span class="token entity" title="\&#x22;">\"</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span>Y!"</span><span class="token punctuation">..</span>., <span class="token number">1536</span>, <span class="token number">4370944</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">1536</span>
</span><span class="code-line line-number" line="12"><span class="token number">11</span>:14:00.606676 pwrite<span class="token punctuation">(</span><span class="token number">21</span>, <span class="token string">"<span class="token entity" title="\1">\1</span><span class="token entity" title="\&#x22;">\"</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span>Y!"</span><span class="token punctuation">..</span>., <span class="token number">1536</span>, <span class="token number">4370944</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">1536</span>
</span><span class="code-line line-number" line="13"><span class="token number">11</span>:14:00.607900 pwrite<span class="token punctuation">(</span><span class="token number">20</span>, <span class="token string">"<span class="token entity" title="\1">\1</span><span class="token entity" title="\&#x22;">\"</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\\">\\</span>"</span><span class="token punctuation">..</span>., <span class="token number">1024</span>, <span class="token number">4372480</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">1024</span>
</span><span class="code-line line-number" line="14"><span class="token number">11</span>:14:00.608161 pwrite<span class="token punctuation">(</span><span class="token number">21</span>, <span class="token string">"<span class="token entity" title="\1">\1</span><span class="token entity" title="\&#x22;">\"</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\\">\\</span>"</span><span class="token punctuation">..</span>., <span class="token number">1024</span>, <span class="token number">4372480</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">1024</span>
</span><span class="code-line line-number" line="15"><span class="token number">11</span>:14:00.608816 pwrite<span class="token punctuation">(</span><span class="token number">20</span>, <span class="token string">"<span class="token entity" title="\1">\1</span><span class="token entity" title="\&#x22;">\"</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span>^!"</span><span class="token punctuation">..</span>., <span class="token number">1024</span>, <span class="token number">4373504</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">1024</span>
</span><span class="code-line line-number" line="16"><span class="token number">11</span>:14:00.609071 pwrite<span class="token punctuation">(</span><span class="token number">21</span>, <span class="token string">"<span class="token entity" title="\1">\1</span><span class="token entity" title="\&#x22;">\"</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span>^!"</span><span class="token punctuation">..</span>., <span class="token number">1024</span>, <span class="token number">4373504</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">1024</span>
</span><span class="code-line line-number" line="17"><span class="token number">11</span>:14:00.611142 pwrite<span class="token punctuation">(</span><span class="token number">20</span>, <span class="token string">"<span class="token entity" title="\1">\1</span><span class="token entity" title="\&#x22;">\"</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span><span class="token variable"><span class="token variable">`</span><span class="token operator">!</span><span class="token string">"..., 1536, 4374528) = 1536
</span></span></span></span><span class="code-line line-number" line="18"><span class="token string"><span class="token variable"><span class="token string">11:14:00.611454 pwrite(21, "</span><span class="token punctuation">\</span><span class="token number">1</span><span class="token punctuation">\</span>"<span class="token punctuation">\</span><span class="token number">0</span><span class="token punctuation">\</span><span class="token number">0</span><span class="token variable">`</span></span>!"</span><span class="token punctuation">..</span>., <span class="token number">1536</span>, <span class="token number">4374528</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">1536</span>
</span><span class="code-line line-number" line="19"><span class="token number">11</span>:14:05.602804 pwrite<span class="token punctuation">(</span><span class="token number">20</span>, <span class="token string">"<span class="token entity" title="\1">\1</span><span class="token entity" title="\&#x22;">\"</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span>c!"</span><span class="token punctuation">..</span>., <span class="token number">1024</span>, <span class="token number">4376064</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">1024</span>
</span><span class="code-line line-number" line="20"><span class="token number">11</span>:14:05.603119 pwrite<span class="token punctuation">(</span><span class="token number">21</span>, <span class="token string">"<span class="token entity" title="\1">\1</span><span class="token entity" title="\&#x22;">\"</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span>c!"</span><span class="token punctuation">..</span>., <span class="token number">1024</span>, <span class="token number">4376064</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">1024</span>
</span><span class="code-line line-number" line="21"><span class="token number">11</span>:14:05.607731 pwrite<span class="token punctuation">(</span><span class="token number">20</span>, <span class="token string">"<span class="token entity" title="\1">\1</span><span class="token entity" title="\&#x22;">\"</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span>e!"</span><span class="token punctuation">..</span>., <span class="token number">1024</span>, <span class="token number">4377088</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">1024</span>
</span><span class="code-line line-number" line="22"><span class="token number">11</span>:14:05.608020 pwrite<span class="token punctuation">(</span><span class="token number">21</span>, <span class="token string">"<span class="token entity" title="\1">\1</span><span class="token entity" title="\&#x22;">\"</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span>e!"</span><span class="token punctuation">..</span>., <span class="token number">1024</span>, <span class="token number">4377088</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">1024</span>
</span><span class="code-line line-number" line="23"><span class="token number">11</span>:14:05.608690 pwrite<span class="token punctuation">(</span><span class="token number">20</span>, <span class="token string">"<span class="token entity" title="\1">\1</span><span class="token entity" title="\&#x22;">\"</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span>g!"</span><span class="token punctuation">..</span>., <span class="token number">1024</span>, <span class="token number">4378112</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">1024</span>
</span><span class="code-line line-number" line="24"><span class="token number">11</span>:14:05.608962 pwrite<span class="token punctuation">(</span><span class="token number">21</span>, <span class="token string">"<span class="token entity" title="\1">\1</span><span class="token entity" title="\&#x22;">\"</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span>g!"</span><span class="token punctuation">..</span>., <span class="token number">1024</span>, <span class="token number">4378112</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">1024</span>
</span><span class="code-line line-number" line="25"><span class="token number">11</span>:14:05.611022 pwrite<span class="token punctuation">(</span><span class="token number">20</span>, <span class="token string">"<span class="token entity" title="\1">\1</span><span class="token entity" title="\&#x22;">\"</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span>i!"</span><span class="token punctuation">..</span>., <span class="token number">1536</span>, <span class="token number">4379136</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">1536</span>
</span><span class="code-line line-number" line="26"><span class="token number">11</span>:14:05.611283 pwrite<span class="token punctuation">(</span><span class="token number">21</span>, <span class="token string">"<span class="token entity" title="\1">\1</span><span class="token entity" title="\&#x22;">\"</span><span class="token entity" title="\0">\0</span><span class="token entity" title="\0">\0</span>i!"</span><span class="token punctuation">..</span>., <span class="token number">1536</span>, <span class="token number">4379136</span><span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token number">1536</span>
</span></code><div onclick="copied(this)" data-code="11:13:55.603245 pwrite(20, &#x22;\1\&#x22;\0\0J!&#x22;..., 1536, 4363264) = 1536
11:13:55.603569 pwrite(21, &#x22;\1\&#x22;\0\0J!&#x22;..., 1536, 4363264) = 1536
11:13:55.606888 pwrite(20, &#x22;\1\&#x22;\0\0M!&#x22;..., 1536, 4364800) = 1536
11:13:55.607172 pwrite(21, &#x22;\1\&#x22;\0\0M!&#x22;..., 1536, 4364800) = 1536
11:13:55.607934 pwrite(20, &#x22;\1\&#x22;\0\0P!&#x22;..., 1536, 4366336) = 1536
11:13:55.608199 pwrite(21, &#x22;\1\&#x22;\0\0P!&#x22;..., 1536, 4366336) = 1536
11:13:55.610260 pwrite(20, &#x22;\1\&#x22;\0\0S!&#x22;..., 1536, 4367872) = 1536
11:13:55.610530 pwrite(21, &#x22;\1\&#x22;\0\0S!&#x22;..., 1536, 4367872) = 1536
11:14:00.602446 pwrite(20, &#x22;\1\&#x22;\0\0V!&#x22;..., 1536, 4369408) = 1536
11:14:00.602750 pwrite(21, &#x22;\1\&#x22;\0\0V!&#x22;..., 1536, 4369408) = 1536
11:14:00.606386 pwrite(20, &#x22;\1\&#x22;\0\0Y!&#x22;..., 1536, 4370944) = 1536
11:14:00.606676 pwrite(21, &#x22;\1\&#x22;\0\0Y!&#x22;..., 1536, 4370944) = 1536
11:14:00.607900 pwrite(20, &#x22;\1\&#x22;\0\0\\&#x22;..., 1024, 4372480) = 1024
11:14:00.608161 pwrite(21, &#x22;\1\&#x22;\0\0\\&#x22;..., 1024, 4372480) = 1024
11:14:00.608816 pwrite(20, &#x22;\1\&#x22;\0\0^!&#x22;..., 1024, 4373504) = 1024
11:14:00.609071 pwrite(21, &#x22;\1\&#x22;\0\0^!&#x22;..., 1024, 4373504) = 1024
11:14:00.611142 pwrite(20, &#x22;\1\&#x22;\0\0&#x60;!&#x22;..., 1536, 4374528) = 1536
11:14:00.611454 pwrite(21, &#x22;\1\&#x22;\0\0&#x60;!&#x22;..., 1536, 4374528) = 1536
11:14:05.602804 pwrite(20, &#x22;\1\&#x22;\0\0c!&#x22;..., 1024, 4376064) = 1024
11:14:05.603119 pwrite(21, &#x22;\1\&#x22;\0\0c!&#x22;..., 1024, 4376064) = 1024
11:14:05.607731 pwrite(20, &#x22;\1\&#x22;\0\0e!&#x22;..., 1024, 4377088) = 1024
11:14:05.608020 pwrite(21, &#x22;\1\&#x22;\0\0e!&#x22;..., 1024, 4377088) = 1024
11:14:05.608690 pwrite(20, &#x22;\1\&#x22;\0\0g!&#x22;..., 1024, 4378112) = 1024
11:14:05.608962 pwrite(21, &#x22;\1\&#x22;\0\0g!&#x22;..., 1024, 4378112) = 1024
11:14:05.611022 pwrite(20, &#x22;\1\&#x22;\0\0i!&#x22;..., 1536, 4379136) = 1536
11:14:05.611283 pwrite(21, &#x22;\1\&#x22;\0\0i!&#x22;..., 1536, 4379136) = 1536
" class="copied"><svg class="octicon-copy" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M0 6.75C0 5.784.784 5 1.75 5h1.5a.75.75 0 010 1.5h-1.5a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-1.5a.75.75 0 011.5 0v1.5A1.75 1.75 0 019.25 16h-7.5A1.75 1.75 0 010 14.25v-7.5z"></path><path fill-rule="evenodd" d="M5 1.75C5 .784 5.784 0 6.75 0h7.5C15.216 0 16 .784 16 1.75v7.5A1.75 1.75 0 0114.25 11h-7.5A1.75 1.75 0 015 9.25v-7.5zm1.75-.25a.25.25 0 00-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 00.25-.25v-7.5a.25.25 0 00-.25-.25h-7.5z"></path></svg><svg class="octicon-check" aria-hidden="true" viewBox="0 0 16 16" fill="currentColor" height="12" width="12"><path fill-rule="evenodd" d="M13.78 4.22a.75.75 0 010 1.06l-7.25 7.25a.75.75 0 01-1.06 0L2.22 9.28a.75.75 0 011.06-1.06L6 10.94l6.72-6.72a.75.75 0 011.06 0z"></path></svg></div></pre>
<style>markdown-style pre .copied {
display: flex;
position: absolute;
cursor: pointer;
color: #a5afbb;
top: 6px;
right: 6px;
border-radius: 5px;
background: #82828226;
padding: 6px;
font-size: 12px;
transition: all .3s;
}
markdown-style pre .copied:not(.active) {
visibility: hidden;
}
markdown-style pre:hover .copied {
visibility: visible;
}
markdown-style pre:hover .copied:hover {
background: #4caf50;
color: #fff;
}
markdown-style pre:hover .copied:active,
markdown-style pre .copied.active {
background: #2e9b33;
color: #fff;
}
markdown-style pre .copied .octicon-copy {
display: block;
}
markdown-style pre .copied .octicon-check {
display: none;
}
markdown-style pre .active .octicon-copy {
display: none;
}
markdown-style pre .active .octicon-check {
display: block;
}</style><script>/*! @uiw/copy-to-clipboard v1.0.12 | MIT (c) 2021 Kenny Wang | https://github.com/uiwjs/copy-to-clipboard.git */
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t():"function"==typeof define&&define.amd?define(t):(e="undefined"!=typeof globalThis?globalThis:e||self).copyTextToClipboard=t()}(this,(function(){"use strict";return function(e,t){const o=document.createElement("textarea");o.value=e,o.setAttribute("readonly",""),o.style={position:"absolute",left:"-9999px"},document.body.appendChild(o);const n=document.getSelection().rangeCount>0&&document.getSelection().getRangeAt(0);o.select();let c=!1;try{c=!!document.execCommand("copy")}catch(e){c=!1}document.body.removeChild(o),n&&document.getSelection&&(document.getSelection().removeAllRanges(),document.getSelection().addRange(n)),t&&t(c)}}));
function copied(target, str) {
target.classList.add('active');
copyTextToClipboard(target.dataset.code, function() {
setTimeout(() => {
target.classList.remove('active');
}, 2000);
});
}</script></markdown-style>
</div>
<!-- Linux命令行搜索引擎https://jaywcjlove.github.io/linux-command/ -->
<div class="footer ">
<a target="_blank" href="https://github.com/jaywcjlove/linux-command/new/master/command">添加命令</a> |
<a href="../hot.html">命令列表</a> |
<a href="https://github.com/jaywcjlove/oscnews" target="_blank">Chrome 插件</a> |
<a href="https://github.com/jaywcjlove/linux-command/releases" target="_blank">Alfred</a> |
<a href="https://jaywcjlove.github.io/linux-command/linux-command.docset.zip" target="_blank">Dash</a> |
<a href="https://github.com/roachsinai/krunner-linuxcommands" target="_blank">Krunner</a> |
<a href="http://jaywcjlove.gitee.io/linux-command/" target="_blank">开源中国Web版</a>
<br />
<a href="https://jaywcjlove.github.io/#/sponsor" target="_blank">打赏捐赠</a> |
<a href="https://github.com/jaywcjlove/linux-command" target="_blank">Github</a> |
<a href="https://jaywcjlove.github.io/linux-command/" target="_blank">短地址https://git.io/linux</a>
<br />
收藏本站请使用 Ctrl+D 或者Command+d
<br /> 共搜集到
<span id="commands_info">
610
</span> 个Linux命令超过 <a href="../contributors.html">50+</a> 贡献者
</div>
<script type="text/javascript" src="../js/dt.js?v=1740369652604"></script>
<script type="text/javascript" src="../js/index.js?v=1740369652604"></script>
</body>
</html>