Microsoft MVP성태의 닷넷 이야기
코어 할당 및 cpu 부하테스트 질문 [링크 복사], [링크+제목 복사],
조회: 11333
글쓴 사람
장성욱 (lozen77 at naver.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

안녕하세요 이 커뮤니티에서 코어 할당하는 문제와 cpu 부하테스트하는 것을 참조하여
원하는 코어에 cpu를 부하를 해보려고 했는데
지금 코드대로 하면 전체cpu 전체가 다 부하가 걸리더라구요..
그래서.. 이게 맞는건지 궁금합니다... process exploror를 이용해서 보면 코어 할당하는것은 다 됍니다.
그런데 cpu 부하코드를 넣으면 코어 8개 전체가 다 부하가 걸립니다...

namespace logtest
{
    public partial class Form1 : Form
    {

        public System.Timers.Timer timer1sec = new System.Timers.Timer();
        public System.Timers.Timer timer1sec2 = new System.Timers.Timer();

        public Form1()
        {
            
                        Thread t1 = new Thread((e) =>
                        {
                            SetIdealProcessor(3);
                            Console.WriteLine(AppDomain.GetCurrentThreadId());
                            timer1sec.Start();
                        });

                        t1.Start();

            timer1sec.Interval = 1000;
            timer1sec.Elapsed += new ElapsedEventHandler(timer1sec_Elapsed);
            InitializeComponent();

        }
        void SetIdealProcessor(int cpuNumber)
        {
            if (cpuNumber >= Environment.ProcessorCount)
            {
                cpuNumber = 0;
            }

            foreach (ProcessThread pthread in Process.GetCurrentProcess().Threads)
            {
                if (pthread.Id == AppDomain.GetCurrentThreadId())
                {
                    pthread.IdealProcessor = cpuNumber;
                    // pthread.ProcessorAffinity = new IntPtr(0x0F & (1 << cpuNumber));
                    break;
                }
            }
        }
        void timer1sec_Elapsed(object sender, ElapsedEventArgs e)
        {
           // SetIdealProcessor(0);

           // Console.WriteLine(AppDomain.GetCurrentThreadId());
            //Console.ReadLine();
            for (int i = 0; i < Environment.ProcessorCount; i++)
            {
                Thread t1 = new Thread(threadFunc);
                t1.IsBackground = true;
                t1.Start();
            }
        }

        private void threadFunc()
        {
            while (true)
            {
            }

        }






    }
}


[연관 글]






[최초 등록일: ]
[최종 수정일: 4/4/2022]


비밀번호

댓글 작성자
 



2022-04-04 08시38분
SetIdealProcessor 메서드는 코드를 보면 알겠지만, 현재 프로세스에 생성된 스레드에 대한 선호도를 바꾸는 것입니다. 그런데, timer_Elapsed에서는 다시 새로운 스레드를 생성하는 것이기 때문에 영향을 안 받는 것입니다.

그런 경우에는, threadFunc 내에서 진입 지점에 자신의 선호도를 스스로 변경하는 코드를 넣어주시면 됩니다.
정성태
2022-04-05 08시41분
[장성욱] 그런 경우에는, threadFunc 내에서 진입 지점에 자신의 선호도를 스스로 변경하는 코드를 넣어주시면 됩니다.
라고 하셨는데 구글링을 해봐도 그렇고, 책이나 문서를 찾아봐도 참고할만한 문서가 도저히 안나오는데 혹시 어떤것을 참고 하면 될까요..?
[guest]
2022-04-05 02시35분
@장성욱 님, 이렇게 말씀드리기 좀 조심스러운데요, 제가 그동안의 질문을 종합했을 때 너무 문제 해결에만 치중하시는 것 같습니다. 해당 코드 하나하나가 어떤 역할을 하는지 테스트를 해보면서 개별 메서드나 그런 것들이 어떤 동작을 하는 것인지 알아가야 합니다.

장성욱 님이 지금 질문하시는 것은, 가령 구구단 출력을 웹으로 검색해 보면 찾을 수 있지만, 그중에서 3단만 출력하는 것은 발견할 수 없다는 것과 유사합니다. 이미 제가 보여준 예제 코드나 글에 모든 정답이 있습니다. 3단만 출력하는 소스 코드를 검색하지 마시고, 구구단 출력을 하는 소스 코드를 잘 보시고 그것을 3단만 출력하도록 적절하게 조절하시면 됩니다.
정성태
2022-04-05 04시48분
[장성욱] 맞는 말씀입니다.. 하지만 제가 지금 이걸 한달이나 잡고있었어서.. 각각의 설명은 이해를 하겠습니다. 하지만 응용을 하려니까 응용이 안됩니다...
솔직히 말씀하신거에 답이있다고 하시는거에 열심히 찾아보고 있습니다만.. 당장 문제를 해결해야하는 이 시기에서 마음이 급해서 그랬습니다...
쓰레드 지정을 한것 까지는 이해가 가지만.. 이것을 또다시 쓰레드와 연결을 해줘야 한다는건데 도저히 이해가 가질않습니다... 해보지도않고 여쭤보는게 아니라서 절박하네요...
[guest]
2022-04-05 10시31분
간단합니다. 위의 소스 코드에서 threadFunc에 SetIdealProcessor만 다음과 같은 식으로 추가해 주면 됩니다.

private void threadFunc()
{
    SetIdealProcessor(3);
    while (true)
    {
    }
}
정성태
2022-04-06 08시59분
[장성욱] 감사합니다. 하지만 저방법도 해보았지만 3번 즉, 4번째 논리코어만 부하가 걸리지않습니다..
[guest]
2022-04-06 10시44분
아래와 같이,

// pthread.IdealProcessor = cpuNumber;
pthread.ProcessorAffinity = new IntPtr(1 << cpuNumber);

IdealProcessor를 사용하지 마시고 ProcessorAffinity를 사용하세요. IdealProcessor는 권고 수준인 반면 ProcessorAffinity는 강제 수준이라는 차이가 있습니다.

C# - IdealProcessor와 ProcessorAffinity의 차이점
; https://www.sysnet.pe.kr/2/0/13031
정성태

1  2  3  4  5  [6]  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5834guest2/24/20239597Python IDE - 비주얼스튜디오 [3]
5833무지남2/23/20238990Async 메서드 그리고 나서 Bool 메서드 [5]
5832김지우2/21/20239610event와 delegate의 차이 , event를 써야하는 이유 [1]
5831이우람2/20/202310438ref 전역변수가 pinned가 될수 있나요? [2]
5830냉수마찰2/19/20239863C# GridView에 Column별 데이터 추가하는 방법에 대해 [1]
5829수박942/19/202310828키움 API를 윈폼과 WPF의 네임스페이스 없이 콘솔이나 WinUI3에서 사용할 수 있는 방법이 있나요? [2]파일 다운로드1
5828김재영2/19/202310493장기적으로는 this 구문을 안쓰는게 맞을까요? [2]
5827lee2/18/202311394파이썬 설치 오류 질문입니다 [1]
5826Syong2/14/202311334Socket 관련 Leak (OverlappedAsyncResult, OverlappedData) 관련 문의 [7]파일 다운로드1
5825박성원2/14/202310921Listview 컨트롤의 화면 전환 시 갱신 속도 [1]
5823검은콩2/13/202312443catch(Exception ex)의 line번호를 쉽게 알 수 없는지요? [7]
5822김지우2/11/202312495책을 보면서 sync, async 이해가 되지 않는 부분이 있습니다. [5]파일 다운로드2
5821검은콩2/9/202310014Async 신뢰성과 소켓데이터 [4]
5820차가워2/8/202310020다른 프로세스 실행 후 포커스 가져오기 [3]
5819취준생2/7/202310067WPF 관련 실무가 궁금합니다. [3]
5818윤길2/7/20239129ObservableCollection 에서 INotifyPropertyChanged 구현해야하나요? [2]
5817흰털너부리2/7/20239199배포 시 winform 실행 콘솔로그 보는 방법 [1]
5816흰털너부리2/6/20239184.net core json array validation 질문 드립니다. [1]
5815김재영2/6/20239231종단간 암호화에 대해 시나리오인데 타당한 시나리오일까요? [2]
5814한예지 donator2/6/202310219decompile? [9]
5813김재영2/5/202310032openssl genrsa 2048시 키 생성이 다르게 됩니다. - 파일첨부 [4]파일 다운로드1
5812김재영2/5/202310412openssl genrsa 2048시 키 생성이 다르게 됩니다. [2]
5811치르바2/3/202310186MiniDumpWriteDump API로 덤프수집을 했는데요.. [3]
5810이건우1/31/202310610윈도우서비스를 통한 웹통신관련 질문입니다 [3]
5809이상훈1/31/202310940다채널 영상 디스플레이어 개발 관련 질문입니다. [3]
5808근우1/30/202310733WPF 에서 UserControl 과 ControlTemplate 의 차이점은 무엇인가요? [6]
1  2  3  4  5  [6]  7  8  9  10  11  12  13  14  15  ...