No.1
- 回答日時:
AWKを使えば簡単でないですか?
PSの出力をAWKスクリプトに食わせてあげると
PIDはわかるんではないかと思います。
UNIX使いでないので、詳しい人のフォローをお願いします。
No.2
- 回答日時:
この表示結果は、psコマンドではないですね?
topですか?
UNIXだけではよくわかりません
商用のUNIXにも
Solaris
HP-UX
などいろいろとあります。
ちょっときついようかも知れませんが
何をもってプログラムが暴走したと判断するんでしょうか?
CPU Timeですか?
普通は、
ps -ef | grep xxx | grep -v grep
等を行い結果をファイルに出力してから、
shell(awk も含む) or pealなどを使って処理するのが一般的だと思います。
pealはちょっと知らないのですが
#Solarisは標準では入っていなかったような
awkなら
ps -ef | grep xxx | grep -v grep | awk '{ printf $2 }'
とすることでPIDが表示されると思いますので
後は、自分で処理を考えてください。
#これは、プロセスが1つの場合に有効です
#複数ある場合は、ファイルに出力してから
#1つずつプロセスをkillしてください
No.3ベストアンサー
- 回答日時:
数字を取り出すだけなら、出力を/\s+/でsplitすればよいのでは。
質問の出力に合わせて書くのなら、
test.pl
-------------------------------------------------------
$head = <>;# 一行目読み捨て。
while(<>){
@arr = split(/\s+/, $_);
print "USER: $arr[0]\n";
print "PID: $arr[1]\n";
print "START: $arr[8]\n";
}
-------------------------------------------------------
のようなPerlスクリプトに
ps -u | perl test.pl
とパイプでpsの出力を食わせるようにします。
どのUnixだろう。FreeBSDかなあ。
その後は研究してみてください。:)
No.4
- 回答日時:
いま、Linux環境でないため確認できませんが、
psって、
USER PID %CPU %MEM VSZ RSS TTY STAT START TIME
[%5s] [%5d] .....
てなぐあいにフォーマットが決まったような。
$ps_data = <DATA>;
$usr = substr($ps_data,0,5);
$pid = substr($ps_data,8,5);
$cpu = substr($ps_data,15,5);
if(条件){
system("kill -9 $pid");
}
しょぼいプログラムですが、こんな感じで良いでしょうか?
う~ん、今、実際にこのプログラムを実行できないから不安です(汗)
自分が実行したものだけにじっこうするならgetuidを使って比較してやっても良いでしょう。
しかし、CPUの値から暴走と判断するのは大変危険な気もしないではないですが。
僕は、作成中のプログラムにgetpidでPIDをファイルに吐かせて、
暴走した場合は(あくまでも自分で暴走したか判断しています。無限ループとか・・・プログラムが^Cでも終了できないような仕様になってるので・・・)、PIDがかかれているファイルをひろってsystemで殺してますけど。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) Excelにの以下の設定方法について教えてください! C列にデータ入力の設定をしています。(出、入を 3 2022/06/22 01:33
- Visual Basic(VBA) 3つのプロシージャをまとめたら実行時エラー発生で対応不能 6 2022/05/17 01:47
- PostgreSQL 数値が定期的にあらわれる文字列から、いくつめに出現した数値が指定して切り出したい 1 2023/06/08 13:12
- Java Java 南京錠 2 2023/02/04 11:46
- Excel(エクセル) エクセルのマクロ作成について教えてください 5 2023/02/20 00:39
- その他(ソフトウェア) F-BASICで計算中の実行が中途で勝手に止まり、大変困っています。 2 2023/03/02 16:15
- オープンソース Python openpyxlを使用したセル番地の使用について 1 2023/08/03 22:05
- Excel(エクセル) EXCELの「接続」のSQLのコマンド文字列にて、セルから任意の数値を利用したい 2 2023/03/09 16:43
- その他(プログラミング・Web制作) mariadbでのエラー 1 2022/11/15 12:31
- Excel(エクセル) Excel ピボットテーブルの表示方法を変更したいのですが、、、(合計値を下部に) 3 2023/06/18 21:10
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
perlをバージョンアップしたら...
-
ファイルアイコンの左下に緑の□...
-
perlプログラミング 空白行削除
-
perlの構文でカンマの意味が分...
-
英数文字列のうちの数値を4桁に...
-
テキストファイルで提出とは?
-
Perlのエラーについてご教授く...
-
AI sisterとは、偽物の人ですか?
-
perlのrequireの動き方について...
-
perlのプログラミング 部分入れ...
-
Strawberry Perl for Windows ...
-
arduino の割り込み処理について
-
アルファベットに付いて質問し...
-
#!/usr/bin/perlで書きだしたCG...
-
perlのflock関数でロックをかけ...
-
bashスクリプト
-
perlでリテラル値はメモリにど...
-
perlで2次元配列をサブルーチ...
-
Perlで時間の計算
-
perlについて
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
テキストファイルで提出とは?
-
openした後、closeしないでプロ...
-
perlをバージョンアップしたら...
-
INDIRECT 横に再度抽出したい
-
Perl の外部モジュールの利用方法
-
Perlで特定文字列から特定文字...
-
Perlのエラーについてご教授く...
-
bashスクリプト
-
Strawberry Perl for Windows ...
-
perlで2次元配列をサブルーチ...
-
TeraPadエディターの操作方法に...
-
アルファベットに付いて質問し...
-
perlのflock関数でロックをかけ...
-
ファイルアイコンの左下に緑の□...
-
perlプログラミング 空白行削除
-
Wallpaper Engineでおすすめの...
-
Perlで時間の計算
-
perlのrequireの動き方について...
-
perlでリテラル値はメモリにど...
-
画像が表示でnull; this.src
おすすめ情報