Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

C# - (.NET Framework를 위한) Oracle.ManagedDataAccess 패키지의 성능 카운터 설정 방법

지난 글에서 .NET Core 버전의 Oracle.ManagedDataAccess에 대한 성능 카운터를 다뤘는데요,

C# - Oracle.ManagedDataAccess.Core의 성능 카운터 설정 방법
; https://www.sysnet.pe.kr/2/0/13000

이번에는 .NET Framework에서 실행되는 Oracle.ManagedDataAccess 패키지를 위한 성능 카운터 사용법을 설명해 보겠습니다.

사실, 전체적인 방법은 "C# - Oracle.ManagedDataAccess.Core의 성능 카운터 설정 방법" 글에서 설명한 것과 같습니다.

단지, 차이점이라면 (Core 버전과는 달리) Oracle.ManagedDataAccess 패키지의 경우 OracleConfiguration 타입을 제공하지 않습니다. 대신 app.config에 OracleConfiguration.PerformanceCounters에서 설정하는 것과 유사한 설정을 제공하므로, 다음과 같은 식으로 대체할 수 있습니다.

<?xml version="1.0" encoding="utf-8"?>
<configuration>
    ...[생략]...
    <oracle.manageddataaccess.client>
        <version number="*">
            <settings>
                <setting name="PerformanceCounters" value="4095" />
            </settings>
        </version>
    </oracle.manageddataaccess.client>
</configuration>

또한, Core 버전의 경우 System.Diagnostics.PerformanceCounter 타입을 사용할 수 있도록 별도의 패키지 참조를 필요로 했지만, .NET Framework 환경에서는 System.dll에 PerformanceCounter 타입을 포함하고 있으므로 그 과정 자체가 필요 없습니다.




그다음, 이것을 성능 모니터링 도구에서 확인을 해야 하는데요, 이를 위해 역시 powershell 스크립트를 실행해야 합니다.

[설치]
register_odpm_perfmon_counters.ps1

[제거]
unregister_odpm_perfmon_counters.ps1

마찬가지로 위의 스크립트 파일도 nuget 패키지에 포함돼 있지만, 패키지 버전이 18.3.0 (어셈블리 버전 4.122.18.3) 버전 이하에는 없습니다. 따라서 그 상위의 버전을 설치하면 아래의 경로에서,

// Oracle.ManagedDataAccess 버전이 19.3.0인 경우

[솔루션 디렉터리]\packages\Oracle.ManagedDataAccess.19.3.0\PerfCounters

register_odpm_perfmon_counters.ps1 파일을 찾을 수 있습니다. 설치 후, 성능 모니터링 도구를 보면 다음과 같이 "ODP.NET, Managed Driver"라는 범주를 볼 수 있고,

odpnet_managed_perf_1.png

실행 중인 프로세스 중에 "성능 카운터를 활성화 + Oracle.ManagedDataAccess를 사용"한다면 위와 같이 "Instances of selected object"에 그 프로세스가 올라오게 됩니다.




참고로, 18.3.0 버전 이하에는 ps1 스크립트 파일만 nuget 패키지에 없는 것일 뿐 그냥 동일하게 상위 버전의 ps1 스크립트 파일을 실행해도 성능 카운터 연동에는 문제가 없습니다.




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






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

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 121  122  123  124  [125]  126  127  128  129  130  131  132  133  134  135  ...
NoWriterDateCnt.TitleFile(s)
10798정성태5/26/201522086기타: 53. 2015년 6월 10일 밤 10시 온라인 세미나 - 새로운 Windows 10 App을 개발하는 방법
10797정성태5/23/201521690VC++: 91. 자식 스레드에 자동 상속되는 TEB의 SubProcessTag 필드파일 다운로드1
10796정성태5/23/201532527오류 유형: 293. SQL Server Management Studio 실행 시 "Cannot find one or more components" 오류
10795정성태5/23/201530634오류 유형: 292. InstallUtil로 .NET 서비스 등록 시 오류 - Operation is not supported. (Exception from HRESULT: 0x80131515). [3]
10794정성태5/22/201525576개발 환경 구성: 267. (무료) 마이크로소프트 온라인 강좌 소개 - 네트워킹 기초 [1]
2925정성태5/14/201525130디버깅 기술: 73. PDB 기호 파일의 경로 구성 방식파일 다운로드1
2924정성태5/14/201528450VS.NET IDE: 100. 비주얼 스튜디오 원격 디버깅 시 'Unknown function' 콜스택이 나온다면?
2923정성태5/12/201587801기타: 52. 도서: 시작하세요! C# 6.0 프로그래밍: 기본 문법부터 실전 예제까지 [17]
2922정성태5/12/201524669오류 유형: 291. ssindex.cmd 실행 시 '...[tfs_collection_url]...' not found in srcsrv.ini 오류 발생
2921정성태5/9/201531042개발 환경 구성: 266. 인텔에서 구현한 최대 절전 모드 기능 - Intel® Rapid Start Technology
2920정성태5/9/201522134오류 유형: 290. 디스크 관리자의 파티션 축소 시, There is not enough space available on the disk(s) to complete this operation.
2919정성태5/9/201522050오류 유형: 289. Error: this template attempted to load component assembly 'NuGet.VisualStudio.Interop, ...'
2918정성태5/9/201540553Windows: 111. 복구(Recovery) 파티션 삭제하는 방법 [3]
2917정성태5/9/201530977오류 유형: 288. .NET Framework 4.6이 설치된 경우 "Intel® Rapid Storage Technology (Intel® RST) RAID Driver"가 설치 안 되는 문제 [5]
2916정성태5/9/201532062오류 유형: 287. 레지스트리 권한 오류 - Cannot edit [Registry key name]: Error writing the value's new contents.
2915정성태5/9/201531186개발 환경 구성: 265. TrustedInstaller 권한으로 프로그램 실행시키는 방법 [11]
2914정성태5/9/201528503DDK: 7. 정식 인증서가 있는 경우 Device Driver 서명하는 방법 [2]
2913정성태4/30/201526267.NET Framework: 511. Build 2015 행사에서 소개된 (맥/리눅스/윈도우 용 무료) Visual Studio Code 개발 도구 [8]
2912정성태4/29/201521996오류 유형: 286. VirtualBox에 Windows 8/2012 설치 시 "Error Code: 0x000000C4" 오류 발생
2911정성태4/29/201520650오류 유형: 285. Visual Studio 2015를 제거한 경우 Microsoft.VisualStudio.Web.PageInspector.Loader 어셈블리를 못 찾는 문제 [2]
2910정성태4/29/201524543오류 유형: 284. System.TypeLoadException: Could not load type 'System.Reflection.AssemblySignatureKeyAttribute' from assembly [1]
2909정성태4/29/201520676오류 유형: 283. WCF 연결 오류 - Expected record type 'PreambleAck'
2908정성태4/29/201528956오류 유형: 282. 원격에서 SQL 서버는 연결되지만, SQL Express는 연결되지 않는 경우
2907정성태4/29/201519058.NET Framework: 510. 제네릭(Generic) 인자에 대한 메타데이터 등록 확인
2906정성태4/28/201521625오류 유형: 281. DebugView로 인한 System.Diagnostics.Trace.WriteLine 멈춤(Hang) 현상
2905정성태4/27/201521977오류 유형: 280. HttpResponse.Headers.Add에서 "System.PlatformNotSupportedException: This operation requires IIS integrated pipeline mode." 예외 발생
... 121  122  123  124  [125]  126  127  128  129  130  131  132  133  134  135  ...