Microsoft MVP성태의 닷넷 이야기
VS.NET IDE: 202. Visual Studio 2022 + Copilot 기본 사용법 [링크 복사], [링크+제목 복사],
조회: 68
글쓴 사람
정성태 (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)
13939정성태5/29/20252664오류 유형: 958. NVIDIA Triton Inference Server - version `GLIBCXX_3.4.32' not found (required by /opt/tritonserver/backends/python/triton_python_backend_stub)
13938정성태5/29/20251953개발 환경 구성: 747. 파이썬 - WSL/docker에 구성한 Triton 예제 개발 환경
13937정성태5/24/20252039개발 환경 구성: 746. Windows + WSL2 환경에서 (tensorflow 등의) NVIDIA GPU 인식
13936정성태5/23/20251900개발 환경 구성: 745. Linux / WSL 환경에 Miniconda 설치하기
13935정성태5/20/20251892오류 유형: 957. 파이썬 - pip 사용 시 "ImportError: cannot import name 'html5lib' from 'pip._vendor'" 오류
13934정성태5/20/20252691스크립트: 77. 파이썬 - 'urllib.request' 모듈의 명시적/암시적 로딩 차이
13933정성태5/19/20251951오류 유형: 956. Visual Studio 2022가 17.12 버전부터 업데이트 되지 않는다면?
13932정성태5/18/20252288스크립트: 76. 파이썬 - Version 문자열 다루기(semver 패키지)
13931정성태5/17/20252724스크립트: 75. 파이썬 - Cython 기본 예제 및 컴파일
13930정성태5/17/20252241개발 환경 구성: 744. 파이썬 - Windows embeddable package 환경에서 외부 패키지 사용하는 방법(ex: UFO² 환경 구성)
13929정성태5/16/20252345오류 유형: 955. 파이썬 - "Windows embeddable package" REPL 환경에서 "NameError: name 'exit' is not defined"
13928정성태5/15/20252474오류 유형: 954. UFO² - "'Invalid URL (POST /v1/chat/completions/chat/completions)'"
13927정성태5/15/20252355오류 유형: 953. OpenAI - The API request of HOST_AGENT failed: OpenAI API request exceeded rate limit: Error code: 429
13926정성태5/14/20253010개발 환경 구성: 743. LLM과 윈도우의 만남 - Desktop AgentOS UFO² 기본 환경 구성
13925정성태5/12/20253040닷넷: 2333. C# - (Console 유형의 프로젝트에서) Clipboard 연동파일 다운로드1
13924정성태5/8/20252715닷넷: 2332. C# - (JetBrains Omea Reader 대상으로) 런타임 시에 메서드 가로채기 [2]파일 다운로드1
13923정성태5/5/20252084스크립트: 74. 파이썬 - C# - Python.NET의 RunSimpleScript, Exec, Eval 차이점파일 다운로드1
13922정성태5/3/20252507스크립트: 73. 파이썬 - Windows embeddable package 버전에서 tkinter 환경 구성
13921정성태5/3/20253094오류 유형: 952. 듀얼 채널 메모리 정렬을 지키지 않은 컴퓨터의 Windows 비정상 종료 현상(Blue Screen) [2]
13920정성태5/3/20253185오류 유형: 951. Typed DataSet 생성 중 "Failed to open a connection to the database" 오류
13919정성태5/2/20252660VS.NET IDE: 201. C# - Typed DataSet(XSD)를 위한 연결 문자열 암호화 [1]파일 다운로드1
13918정성태5/2/20253176VS.NET IDE: 200. C# - app.config 파일의 출력을 Configuration(Debug/Release)에 따라 제어하는 방법파일 다운로드1
13917정성태4/30/20252359VS.NET IDE: 199. Directory.Build.props에 정의한 속성에 대해 Condition 제약으로 값을 변경하는 방법
13916정성태4/23/20252007디버깅 기술: 221. WinDbg 분석 사례 - ASP.NET HttpCookieCollection을 다중 스레드에서 사용할 경우 무한 루프 현상 - 두 번째 이야기
13915정성태4/13/20253670닷넷: 2331. C# - 실행 시에 메서드 가로채기 (.NET 9)파일 다운로드1
13914정성태4/11/20254104디버깅 기술: 220. windbg 분석 사례 - x86 ASP.NET 웹 응용 프로그램의 CPU 100% 현상 (4)
1  [2]  3  4  5  6  7  8  9  10  11  12  13  14  15  ...