Microsoft MVP성태의 닷넷 이야기
VS.NET IDE: 202. Visual Studio 2022 + Copilot 기본 사용법 [링크 복사], [링크+제목 복사],
조회: 71
글쓴 사람
정성태 (seongtaejeong at gmail.com)
홈페이지
첨부 파일
 

Visual Studio 2022 + Copilot 기본 사용법

근래 버전에서 "GitHub Copilot Chat" 기능이 비주얼 스튜디오에 통합돼 이런 창이 나타난 것을 보았을 텐데요, (참고로 저는 Microsoft MVP 혜택 중 하나인 Pro+ 버전을 사용하고 있습니다.)

vs_copilot_1.png

단순한 수준의 사용이라면, 그저 위의 화면에서 보이는 "Ask Copilot or use @workspace" 에디트 박스를 이용해 Copilot에 원하는 작업을 요청하는 식으로 이뤄집니다.

그중에서 특정 작업은 미리 정의된 유형으로 제공되기도 하는데요, '/' 키를 누르면 'doc', 'explain', 'fix', 'help', 'optimize', 'test' 명령어가 펼쳐집니다. (참고로, /clear, /generate, /new, /simplify, /feedback 명령어도 있다고 하는데, 아직은 Visual Studio Code 버전에서만 제공되는 것들입니다.)

사용법이야 이름만으로 이미 직관적이기도 하고, 약간의 실습을 해보면 알 수 있을 테니 생략합니다. ^^




명령어보다는 오히려, Copilot의 동작 모드인 "Ask", "Edit", "Agent" 모드에 대해 아는 것이 더 중요할 듯합니다. 그중에서 Edit 모드는 Visual Studio Code에서만 지원하므로 넘어가고, 기본적으로 Visual Studio 2022는 Ask 모드로 동작합니다. Agent 모드를 사용하려면 명시적으로 옵션에 들어가,

vs_copilot_2.png

"GitHub" / "Copilot"의 "Enable Agent mode in the chat pane" 옵션을 켜야 합니다.

vs_copilot_3.png

그러고 나면, "GitHub Copilot Chat" 창의 하단에 "Ask", "Agent" 모드를 선택할 수 있는 버튼이 나타나,

vs_copilot_4.png

원하는 옵션으로 실행할 수 있습니다. 다음은 ChatGPT가 알려주는 2가지 모드의 차이점인데요,

🧠 ASK 모드
* 목적: 일반적인 질문을 하거나 코드 자동 완성을 요청할 때 사용합니다.
* 맥락 인식: 제한적 – 현재 열려 있는 파일이나 선택된 코드에 초점을 맞춥니다.
* 동작 방식: 설명, 코드 생성, 오류 분석 등 도움말 제공자처럼 행동합니다.
* 예시:
    * "이 함수가 무슨 일을 하나요?"
    * "이 코드에 대한 단위 테스트를 만들어줘."
    * "이 에러 메시지를 설명해줘."

ASK 모드는 코드에 대해 질문하거나 요청할 수 있는 똑똑한 조수처럼 작동합니다.

🤖 Agent 모드
* 목적: 여러 파일에 걸친 복잡하고 목표 지향적인 작업 수행.
* 맥락 인식: 높음 – 프로젝트 전체를 분석하고 파일을 수정하거나 작업을 실행할 수 있습니다.
* 동작 방식: 스스로 판단하고 실행하는 코딩 에이전트처럼 행동합니다.
* 예시:
    * "프로젝트 내 모든 컨트롤러에 로깅을 추가해줘."
    * "이 모듈을 리팩터링하고 관련 import도 수정해줘."
    * "프로젝트 내 TODO 주석을 모두 처리해줘."

Agent 모드는 작업을 스스로 분석하고 처리할 수 있는 개발자 팀원처럼 작동합니다.

약간 다른 관점의 차이도 추가 설명하자면, Ask 모드는 의미 그대로 사용자가 질문한 내용에 따라 Copilot이 답변을 해주는 정도인 반면, Agent 모드는 좀 더 능동적으로 시스템에 접근해 변경까지 가할 수 있게 해줍니다. 실제 사례를 통해 그 차이점을 알아볼까요? ^^

Visual Studio를 열고 새로운 솔루션을 생성한 다음, (솔루션이 있어야 workspace 문맥을 Copilot이 판단할 수 있습니다.) 그 상태에서 새롭게 콘솔 프로젝트를 추가한다고 가정해 보겠습니다. 이때 Ask 모드에서 "새 콘솔 프로젝트 생성"이라고 명령하면 단순히 그 방법을 설명해 줍니다.

vs_copilot_5.png

반면, Agent 모드로 동일하게 지시를 하면,

vs_copilot_6.png

이렇게 시스템을 변경할 수 있는 명령어를 실행할지 여부를 묻고, "Allow this time" 버튼을 누르면 그 작업이 수행됩니다. 대충 그 차이점에 대한 감이 오시죠? ^^




Agent 모드에 대해 좀 더 볼까요? Agent 모드가 저런 식으로 실행할 수 있는 명령어는 사실 "Tools"에 미리 등록된 것으로,

vs_copilot_7.png

현재 Built-in 되어 있는 명령어는 다음과 같습니다.

  • edit_file
  • find_file
  • get_currentfile
  • get_errors
  • get_file
  • get_files_in_project
  • get_output_window_logs
  • get_projects_in_solution
  • run_build
  • run_command_in_terminal
  • text_search

즉, "새 콘솔 프로젝트 생성"이라는 명령어가 수행될 수 있었던 것은 위에서 "run_command_in_terminals" 도구가 등록돼 있기 때문에 가능한 것입니다. "run_command_in_terminals" 도구는 저 명령어를 대충 다음과 같은 명령어로 수행하는데요,

// PowerShell 명령어로 실행

try { dotnet new console -o c:\temp\test } finally { if ($?) { echo "40642de0a9054440a225fccbfcb27bb4=$?" } else { echo "40642de0a9054440a225fccbfcb27bb4=$?" } }

보는 바와 같이 결과를 echo로 받아 성공 여부를 Copilot 측에서 알 수 있도록 연동하고 있습니다.

도구 실행 시, Copilot으로 하여금 재차 묻는 것을 원치 않는다면 "Always allow"로 선택해 둬도 됩니다. 그렇게 되면 settings 메뉴의 "GitHub" / "Copilot" 범주의 "Tools" 패널에 등록되는데요, 따라서 향후 다시 묻게 만들고 싶다면 "Tools" 패널에서 해당 도구를 제거하면 됩니다.




이후, Copilot과의 연동은 여러분이 예상하는 것과 같습니다. 가령, 위에서 생성한 콘솔 프로젝트를 비주얼 스튜디오에서 로드해 Program.cs 파일을 열고, "Main을 포함한 유형으로 만들어"라고 지시하면 다음과 같이 코드 분석을 통해 변환할 코드를 제안합니다.

vs_copilot_8.png

예전 같았으면 저런 처리를 하려면 IDE 또는 Plug-in 등에서 관련 Refactoring 기능을 제공해야 했지만, 이제는 Copilot을 통해 자연어로 지시할 수 있게 된 것입니다.

또한 명령어를 저렇게 "GitHub Copilot Chat" 창으로만 입력하는 것은 불편하므로, 소스 코드 편집 창에서 곧바로 "Alt + '/'" 키를 눌러 "SQL 서버를 연결해 기본적인 CRUD 코드 생성"이라고 입력하면,

vs_copilot_9.png

보는 바와 같이 Copilot이 관련된 코드를 생성해 제안해 주고, 수락은 "Tab" 키를, 거절은 "Alt+Del" 키를 눌러 진행할 수 있습니다.




요즘 바이브 코딩이 이슈인데, 아쉽게도 대표 주자인 Claude의 경우, 별도의 콘솔 창을 띄워서 연동하는 방식인데다 윈도우 운영체제라면 WSL 환경으로 우회시켜야 하는 등의 불편함이 있습니다. 역시나... 이런 건 IDE에 통합되는 것이 가장 편할 텐데요, 위에서 다룬 바대로 Visual Studio + Copilot이 바로 그런 좋은 사례 중의 하나일 것입니다.




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







[최초 등록일: ]
[최종 수정일: 7/8/2025]

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

비밀번호

댓글 작성자
 




1  2  3  [4]  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13889정성태2/20/20255444닷넷: 2322. C# - 프로세스 메모리 중 Private Working Set 크기를 구하는 방법(성능 카운터, WMI) [1]파일 다운로드1
13888정성태2/17/20254425닷넷: 2321. Blazor에서 발생할 수 있는 async void 메서드의 부작용
13887정성태2/17/20255943닷넷: 2320. Blazor의 razor 페이지에서 code-behind 파일로 코드를 분리 및 DI 사용법
13886정성태2/15/20254153VS.NET IDE: 196. Visual Studio - Code-behind처럼 cs 파일을 그룹핑하는 방법
13885정성태2/14/20255769닷넷: 2319. ASP.NET Core Web API / Razor 페이지에서 발생할 수 있는 async void 메서드의 부작용
13884정성태2/13/20256140닷넷: 2318. C# - (async Task가 아닌) async void 사용 시의 부작용파일 다운로드1
13883정성태2/12/20255817닷넷: 2317. C# - Memory Mapped I/O를 이용한 PCI Configuration Space 정보 열람파일 다운로드1
13882정성태2/10/20254137스크립트: 70. 파이썬 - oracledb 패키지 연동 시 Thin / Thick 모드
13881정성태2/7/20254506닷넷: 2316. C# - Port I/O를 이용한 PCI Configuration Space 정보 열람파일 다운로드1
13880정성태2/5/20255993오류 유형: 947. sshd - Failed to start OpenSSH server daemon.
13879정성태2/5/20255886오류 유형: 946. Ubuntu - N: Updating from such a repository can't be done securely, and is therefore disabled by default.
13878정성태2/3/20255721오류 유형: 945. Windows - 최대 절전 모드 시 DRIVER_POWER_STATE_FAILURE 발생 (pacer.sys)
13877정성태1/25/20255006닷넷: 2315. C# - PCI 장치 열거 (레지스트리, SetupAPI)파일 다운로드1
13876정성태1/25/20256172닷넷: 2314. C# - ProcessStartInfo 타입의 Arguments와 ArgumentList파일 다운로드1
13875정성태1/24/20254533스크립트: 69. 파이썬 - multiprocessing 패키지의 spawn 모드로 동작하는 uvicorn의 workers
13874정성태1/24/20255945스크립트: 68. 파이썬 - multiprocessing Pool의 기본 프로세스 시작 모드(spawn, fork)
13873정성태1/23/20254376디버깅 기술: 217. WinDbg - PCI 장치 열거파일 다운로드1
13872정성태1/23/20253997오류 유형: 944. WinDbg - 원격 커널 디버깅이 연결은 되지만 Break (Ctrl + Break) 키를 눌러도 멈추지 않는 현상
13871정성태1/22/20254648Windows: 278. Windows - 윈도우를 다른 모니터 화면으로 이동시키는 단축키 (Window + Shift + 화살표)
13870정성태1/18/20255691개발 환경 구성: 741. WinDbg - 네트워크 커널 디버깅이 가능한 NIC 카드 지원 확대
13869정성태1/18/20254717개발 환경 구성: 740. WinDbg - _NT_SYMBOL_PATH 환경 변수에 설정한 경로로 심벌 파일을 다운로드하지 않는 경우
13868정성태1/17/20254287Windows: 277. Hyper-V - Windows 11 VM의 Enhanced Session 모드로 로그인을 할 수 없는 문제
13867정성태1/17/20256289오류 유형: 943. Hyper-V에 Windows 11 설치 시 "This PC doesn't currently meet Windows 11 system requirements" 오류
13866정성태1/16/20256732개발 환경 구성: 739. Windows 10부터 바뀐 device driver 서명 방법
13865정성태1/15/20255958오류 유형: 942. C# - .NET Framework 4.5.2 이하의 버전에서 HttpWebRequest로 https 호출 시 "System.Net.WebException" 예외 발생
13864정성태1/15/20255949Linux: 114. eBPF를 위해 필요한 SELinux 보안 정책
1  2  3  [4]  5  6  7  8  9  10  11  12  13  14  15  ...