Microsoft MVP성태의 닷넷 이야기
vs2022 preview net7 AOT 콘솔 실행 성능 [링크 복사], [링크+제목 복사],
조회: 12301
글쓴 사람
차가워 (like0430 at nate.com)
홈페이지
첨부 파일
 

안녕하세요.

11월 초에 발표된 preview NET7.0 AOT 콘솔을 사용해 봤는데요.
그들 말로는 NATIVE코드를 생성해서 성능 향상이 크다고 하는데요.
같은 코드를 윈11에서
닷넷프레임워크4.8콘솔과
NET7.0 콘솔 ILCompiler에서 돌려보니 둘의 성능 차이가 없는거 같네요.
제가 뭘 잘못 만진건지 모르겠네요.

선생님께서는 vs2022 preview net7 AOT 해보셨는지 궁금합니다.









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


비밀번호

댓글 작성자
 



2022-11-08 02시02분
문서에 따르면,

ReadyToRun Compilation
; https://learn.microsoft.com/en-us/dotnet/core/deploying/ready-to-run

r2r로 인해 실행 파일의 크기가 2~3배 증가할 수 있다고 합니다. 결국 초기 로딩 속도가 디스크 읽기 작업으로 느려지고, working set도 증가하는 부작용으로 인해 이것은 다시 로딩 속도에 영향을 미칩니다.

사실 R2R(Ready-to-Run)을 설정하는 가장 큰 이유가 초기 로딩 속도를 줄여보려는 것이므로, 가능한 자신의 애플리케이션 상황에 맞게 적절한 테스트를 해보시는 것도 좋겠습니다.

-----------------

그리고 r2r은 순수하게 JIT 컴파일을 생략하는 것으로 주로 로딩 속도에만 영향을 미칩니다. 따라서, 일단 JIT 컴파일 된 코드나, r2r된 코드나 그 이후의 성능은 동일합니다.

정성태
2022-11-08 04시37분
[차가워] 기존에 있던 r2r이랑은 다른 이번에 새로 적용된
native aot 라고 jit를 사용하지 않는 네이티브코드라고 하더라구요.
https://www.youtube.com/watch?v=sa3XsvSiMtk
[guest]
2022-11-08 04시46분
[guest]
2022-11-08 11시14분
r2r도 jit하지 않는 것은 마찬가지입니다. 단지 .NET 7에 포함된 native aot가 좀 더 확실히 native 코드를 생성하는 정도일 텐데요, 그렇다 해도 제가 위에서 언급한 조건은 동일하게 적용됩니다.
정성태
2022-11-10 11시19분
제가 해보니까,

.NET 7 - AOT(ahead-of-time) 컴파일
; https://www.sysnet.pe.kr/2/0/13162

PublishAot 옵션을 주고 배포한 경우 빨라졌는데요. 혹시 어떤 식으로 테스트하신 건가요? 테스트하신 예제 프로젝트를 올려주실 수 있나요?
정성태
2022-11-22 08시29분
[차가워] 윗글 링크에 나온 글 보고 따라해봤는데요.

사용환경은
윈11
Microsoft Visual Studio Enterprise 2022 (64-bit) - Preview
버전 17.5.0 Preview 1.0

1. net7으로 콘솔프로젝트 하나 만들어서
2. csproj파일에 다음과 같이 <PublishAot>true</PublishAot> 추가

<?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="Current" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
  <PropertyGroup>
    <_LastSelectedProfileId>C:\Users\lines...\PublishProfiles\FolderProfile.pubxml</_LastSelectedProfileId>
    <PublishAot>true</PublishAot>
  </PropertyGroup>
</Project>


3.게시버튼을 누르면 다음과 같은 에러가 나오네요.
오류 NETSDK1191    'PublishAot' 속성의 런타임 식별자를 유추할 수 없습니다. RID를 명시적으로 지정하세요.

제가 뭔가를 잘못한거 같은데 뭐가 잘못 된 건지 모르겠습니다.
[guest]
2022-11-22 11시33분
이상하군요, 해당 링크를 따라했으면,

https://www.sysnet.pe.kr/2/0/13162#publish_aot

csproj 파일의 내용이 "<Project Sdk="Microsoft.NET.Sdk">"로 시작했을 텐데요? 확실히 .NET 7 콘솔 프로젝트가 맞나요?

만약 다른 식으로 생성한 것이라면, 런타임 식별자를 알 수 없다는 것이니 억지로 "<RuntimeIdentifier>win-x64</RuntimeIdentifier>"를 넣는 것은 고려해 볼 수 있습니다.
정성태

... 91  [92]  93  94  95  96  97 
NoWriterDateCnt.TitleFile(s)
157이용휘4/20/20059275w3ip를 통해서 윈도우 미디어 화을을 올려놓을 서버..
158정성태4/20/20059702    답변글 [답변]: w3ip를 통해서 윈도우 미디어 화을을 올려놓을 서버..
155최성우4/18/200511377[질문(--),(__)]BHO로 자동 로그인 기능 구현.. 패스워드를 읽어오지를 못합니다.
156정성태4/19/200510081    답변글 [답변]: [질문(--),(__)]BHO로 자동 로그인 기능 구현.. 패스워드를 읽어오지를 못합니다.
161최성우4/21/200511169        답변글 [답변]: [답변]: [질문(--),(__)]BHO로 자동 로그인 기능 구현.. 패스워드를 읽어오지를 못합니다.
164정성태4/22/20059977            답변글 [답변]: [답변]: [답변]: [질문(--),(__)]BHO로 자동 로그인 기능 구현.. 패스워드를 읽어오지를 못합니다.
176최성우5/3/200510343                답변글 [답변]: [답변]: [답변]: [답변]: [질문(--),(__)]BHO로 자동 로그인 기능 구현.. 패스워드를 읽어오지를 못합니다.
146안연준4/14/200511044컴포넌트 안에 컴포넌트 삽입? 헐 ! -_-;;
147정성태4/14/20059925    답변글 [답변]: 컴포넌트 안에 컴포넌트 삽입? 헐 ! -_-;;
148안연준4/15/200510297        답변글 [답변]: [답변]: 컴포넌트 안에 컴포넌트 삽입? 헐 ! -_-;; [2]
142김용국4/13/200510090SmartClient 방식에서 이미지(바이너리)파일을 DataBased에 저장하기위한 방안에 대한 문의
143정성태4/14/20059698    답변글 [답변]: SmartClient 방식에서 이미지(바이너리)파일을 DataBased에 저장하기위한 방안에 대한 문의
141김종욱4/12/200510176웹하드 시스템을 ACTIVEX 로 짜고 있습니다
144정성태4/14/20059729    답변글 [답변]: 웹하드 시스템을 ACTIVEX 로 짜고 있습니다
149김종욱4/15/20059622        답변글 [답변]: [답변]: 웹하드 시스템을 ACTIVEX 로 짜고 있습니다 [1]
150정성태4/15/20059787            답변글 [답변]: [답변]: [답변]: 웹하드 시스템을 ACTIVEX 로 짜고 있습니다 [1]
151김종욱4/16/200510083                답변글 [답변]: [답변]: [답변]: [답변]: 웹하드 시스템을 ACTIVEX 로 짜고 있습니다
152정성태4/16/20059886                    답변글 [답변]: [답변]: [답변]: [답변]: [답변]: 웹하드 시스템을 ACTIVEX 로 짜고 있습니다
153김종욱4/18/200511619                        답변글 [답변]: [답변]: [답변]: [답변]: [답변]: [답변]: 웹하드 시스템을 ACTIVEX 로 짜고 있습니다
154정성태4/18/200510878                            답변글 [답변]: [답변]: [답변]: [답변]: [답변]: [답변]: [답변]: 웹하드 시스템을 ACTIVEX 로 짜고 있습니다 [3]
140안연준4/11/20059610Smart Client 에서 오프라인 글 중...의문점
145정성태4/14/20059461    답변글 [답변]: Smart Client 에서 오프라인 글 중...의문점 [1]
134김용국4/6/200514092c# .Net 에 대한 문의좀 ^^ [WinForm 에서 UserControl로 작성된 폼을 호출하려는데....]
135정성태4/6/200512144    답변글 [답변]: c# .Net 에 대한 문의좀 ^^ [WinForm 에서 UserControl로 작성된 폼을 호출하려는데....]
136김용국4/6/200510951        답변글 [답변]: [답변]: c# .Net 에 대한 문의좀 ^^ [WinForm 에서 UserControl로 작성된 폼을 호출하려는데....]
137정성태4/7/200510088            답변글 [답변]: [답변]: [답변]: c# .Net 에 대한 문의좀 ^^ [WinForm 에서 UserControl로 작성된 폼을 호출하려는데....]
... 91  [92]  93  94  95  96  97