質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

89.98%

C#ではなくコマンドプロンプトやバッチでCPU使用率と物理メモリ使用量、仮想メモリ使用量を1分毎に表示しサーバーの負荷率を履歴として取りたいと考えています。テキストファイルへの出力。

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 551

ShinyaKojima

score 12

いつもお世話になっております。

先日C#でCPU使用率やメモリ使用量1分毎に表示しテキストファイルへ出力という質問をさせていただき。実現することができました。
しかし、そのプログラムを報告したら C#ではなく コマンドプロンプトやバッチで処理できないの?と言われました・・・

私の中ではそのプログラムをタスクスケジューラで毎日動かして24時間データを取る予定だったのですが

今回はC#ではなくコマンドやバッチで
・現在日時、CPU使用率、物理メモリ使用量、仮想メモリ使用量を1分毎にテキストファイルへ書込み
・24時間データを1分毎に取り続ける。テキストのファイル名は当日の日付です。
・毎日24時間分のデータを取って1ファイルずつ増えていくイメージです。

C#では以下のように書いてます。

using System;
using System.Threading;
using System.Diagnostics;
using System.IO;

namespace CodeRecipe_Timer_CS
{
    class Program
    {
        static void Main(string[] args)
        {
            using (PerformanceCounter pc = new PerformanceCounter("Processor", "% Processor Time", "_Total", true))
            {

                TimerCallback tDelegate = new TimerCallback(GetCpuUsage);
                using (Timer oTimer = new Timer(tDelegate, pc, 0, 60000))
                {
                  Thread.Sleep(734400000);
                }
            }
            Console.WriteLine("Timer を停止しました。終了するには何かキーを押してください。");
            Console.Read();
        }
        static void GetCpuUsage(object state)
        {
            string today = DateTime.Now.ToString("yyyyMMdd");

            PerformanceCounter pc = state as PerformanceCounter;
            DateTime dtNow = DateTime.Now;
            System.Diagnostics.Process p = System.Diagnostics.Process.GetCurrentProcess();
            p.Refresh();

            if (pc != null)
            {
                //Console.WriteLine(String.Format("現在のCPU使用率は {0:f}% です。" + dtNow.ToString(), pc.NextValue()));
                //Console.WriteLine("物理メモリ使用量: {0}", p.WorkingSet64);
                //Console.WriteLine("仮想メモリ使用量: {0}", p.VirtualMemorySize64);
                File.AppendAllText(@"C:\検証用\検証データ\MLOG_RCV\" + today + ".txt", String.Format(dtNow.ToString() + "  "));
                File.AppendAllText(@"C:\検証用\検証データ\MLOG_RCV\" + today +".txt", String.Format("現在のCPU使用率は {0:f}% です。", pc.NextValue()));
                File.AppendAllText(@"C:\検証用\検証データ\MLOG_RCV\" + today + ".txt", String.Format(" 物理メモリ使用量: {0}", p.WorkingSet64));
                File.AppendAllText(@"C:\検証用\検証データ\MLOG_RCV\" + today + ".txt", String.Format(" 仮想メモリ使用量: {0}", p.VirtualMemorySize64) + Environment.NewLine);
            }

        }
    }
}


流れとしてはProcessor Time", "_Total"でCPUの使用率を取り出し

Timer oTimer = new Timer(tDelegate, pc, 0, 60000))
{
Thread.Sleep(734400000);
で60秒毎にデータを取るようにして24時間後に停止する
後半の
File.AppendAllText(@"C:\検証用\検証データ\MLOG_RCV\" + today + ".txt", String.Format(dtNow.ToString() + "  "));
File.AppendAllText(@"C:\検証用\検証データ\MLOG_RCV\" + today +".txt", String.Format
("現在のCPU使用率は {0:f}% です。", pc.NextValue()));
File.AppendAllText(@"C:\検証用\検証データ\MLOG_RCV\" + today + ".txt", String.Format(" 物理メモリ使用量: {0}", p.WorkingSet64));
File.AppendAllText(@"C:\検証用\検証データ\MLOG_RCV\" + today + ".txt", String.Format(" 仮想メモリ使用量: {0}", p.VirtualMemorySize64) + Environment.NewLine);
では現在の日時、CPU使用率、物理メモリ使用量、仮想メモリ使用量などを書き込み改行
という処理をしています。

同じ動作を実現させるためにはどのようなコマンドを入力すればよいのでしょうか?

バッチやコマンドプロンプトを扱ったことがなく

検索した結果
ファイル名に日付を指定するバッチ?

@echo off

echo %date%
echo %time%

set yyyy=%date:~0,4%
set mm=%date:~5,2%
set dd=%date:~8,2%

set filename=%yyyy%-%mm%%dd%-%hh%%mn%%ss%

echo test >> log_%filename%.txt
C:\> typeperf -sc 1440 -si 60 "\Processor(_Total)\% Processor Time" > typeperf.txt


※1分(60秒)間隔で1日(1440回)実行する場合の記述

@echo off
 :label01
 echo %date% %time%
 tasklist
ping localhost -n 60 > nul
 goto label01


メモリの使用量を60秒間隔で実行するバッチ

ですが これらの組み合わせかたや使い方がよく分かりません。

どうかご教授お願い致します。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • Y.H.

    2019/04/12 15:42

    [タスクマネージャ]や[リソースモニタ]ではなく
    「パフォーマンスモニター」ですよ。

    記事は古いですが基本的に使用方法は変わってません。
    この辺りを参照されると概要が把握できると思います。

    WIndowsXP/Vista/7/8/10 Server製品すべてに同じ形で存在します。
    データコレクタセットによる負荷状況記録 ( https://news.mynavi.jp/itsearch/article/hardware/924 )

    キャンセル

  • ShinyaKojima

    2019/04/12 17:33

    パフォーマンスモニターを使って.blgをcsvに変更したら良さそうですね
    一度自分で使ってみて操作に慣れてみようと思います。
    ありがとうございました。
    ベストアンサーに選びたいのですが、回答箇所が・・・(;^_^A
    新たに回答に記入していただけたらベストアンサーに選びたいと思います。

    キャンセル

  • Y.H.

    2019/04/12 17:36

    コメントに記載したものを回答として記載しました

    キャンセル

回答 1

checkベストアンサー

+3

目的が、作ることではなくCPU使用率、物理メモリ使用量、仮想メモリ使用量を監視および履歴を見ることなのであれば、Windows標準のパフォーマンスモニターでいいんじゃ?

記事は古いですが基本的に使用方法は変わってません。
この辺りを参照されると概要が把握できると思います。

WIndowsXP/Vista/7/8/10 Server製品すべてに同じ形で存在します。
(news.mynavi.jp)データコレクタセットによる負荷状況記録

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 89.98%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる
  • トップ
  • コマンドプロンプトに関する質問
  • C#ではなくコマンドプロンプトやバッチでCPU使用率と物理メモリ使用量、仮想メモリ使用量を1分毎に表示しサーバーの負荷率を履歴として取りたいと考えています。テキストファイルへの出力。