Microsoft MVP성태의 닷넷 이야기
오류 유형: 550. scp - sudo: no tty present and no askpass program specified [링크 복사], [링크+제목 복사],
조회: 21633
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

(시리즈 글이 2개 있습니다.)
.NET Framework: 812. pscp.exe 기능을 C#으로 제어하는 방법
; https://www.sysnet.pe.kr/2/0/11849

오류 유형: 550. scp - sudo: no tty present and no askpass program specified
; https://www.sysnet.pe.kr/2/0/11954




scp - sudo: no tty present and no askpass program specified

예전에 만들어 둔 scp 제어 프로그램을 보면,

pscp.exe 기능을 C#으로 제어하는 방법
; https://www.sysnet.pe.kr/2/0/11849

session.ExecuteCommand라는 기능을 통해 원격지 리눅스 머신에 명령어를 수행하는 것이 가능합니다. 그런데 간혹 sudo 권한으로 명령을 실행하고 싶을 수가 있는데, 그럴 때 해당 프로그램을 다음과 같은 식으로 실행하면,

string cmd = "sudo /usr/bin/dotnet";

session.ExecuteCommand(cmd);

원격지에서는 암호를 다시 입력받는 과정을 거치느라 잠시 후 오류가 발생합니다.

sudo: no tty present and no askpass program specified
Error: WinSCP.SessionRemoteException: Command 'sudo /usr/bin/dotnet'
failed with return code 1 and error message
sudo: no tty present and no askpass program specified.
   at WinSCP.OperationResultBase.Check()
   at Example.DoRunCommand(Session session, CommandArg arg, String password) in D:\dpapiscp\Program.cs:line 96
   at Example.Main(String[] args) in D:\dpapiscp\Program.cs:line 64

따라서 이 암호를 입력받는 것을 자동화해야 하는데요. 이를 위해 sudo 명령의 -S 옵션을 이용하면 됩니다. 그래서 다음과 같이 입력을 redirection 받을 수 있습니다.

string cmd = "echo pwct | sudo -S /usr/bin/dotnet"; // 암호가 pwct라고 가정

session.ExecuteCommand(cmd);




참고로, 원격에서 수행할 명령을 cmd.exe 창의 명령행을 통해 다음과 같이 전달하고 싶을 수 있습니다.

C:\temp> dpapiscp.exe echo pwct | sudo -S /usr/bin/dotnet

그런데, 위와 같이 입력하면 "|" 기호도 윈도우 shell은 파이프라인 기호로 인식하기 때문에 sudo를 명령어로 해석하게 되어 다음과 같은 오류가 발생합니다.

'sudo' is not recognized as an internal or external command, operable program or batch file.

따라서 이런 경우에는 인용 마크를 함께 써서 해결해야 합니다.

C:\temp> dpapiscp.exe "echo pwct | sudo -S /usr/bin/dotnet"




(2025-08-06 업데이트) 명령행에 '&' 기호를 추가했더니,

C:\temp> dpapiscp.exe "dotnet /app/corecorelin/publish/CoreCoreLin.dll &"

이런 오류가 발생합니다.

-bash: line 7: syntax error near unexpected token `;'
-bash: line 7: `dotnet /app/corecorelin/publish/CoreCoreLin.dll &  ; echo "WinSCP: this is end-of-file:$?"'
Error: WinSCP.SessionRemoteException: Connection has been unexpectedly closed. Server sent command exit status 2.
   at WinSCP.OperationResultBase.Check()
   at Example.DoRunCommand(Session session, CommandArg arg, String password)
   at Example.Main(String[] args)

아마도 winscp 내부에서 '&' 기호를 특수하게 사용하는 것 같은데... 어쩔 수 없습니다. 일단 저런 경우에는 coproc 명령으로 대체했습니다.

C:\temp> dpapiscp.exe "coproc dotnet /app/corecorelin/publish/CoreCoreLin.dll"




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







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

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)
1797정성태11/4/201421225오류 유형: 255. 이벤트 로그 - The Adobe Flash Player Update Service service entered the stopped state.
1796정성태10/30/201428539개발 환경 구성: 249. Visual Studio 2013에서 Mono 컴파일하는 방법
1795정성태10/29/201430307개발 환경 구성: 248. Lync 2013 서버 설치 방법
1794정성태10/29/201425950개발 환경 구성: 247. "Microsoft Office 365 Enterprise E3" 서비스에 대한 간략 소개
1793정성태10/27/201426970.NET Framework: 474. C# - chromiumembedded 사용 - 두 번째 이야기 [2]파일 다운로드1
1792정성태10/27/201427100.NET Framework: 473. WebClient 객체에 쿠키(Cookie)를 사용하는 방법
1791정성태10/22/201426562VC++: 83. G++ - 템플릿 클래스의 iterator 코드 사용에서 발생하는 컴파일 오류 [5]
1790정성태10/22/201421261오류 유형: 254. NETLOGON Service is paused on [... AD Server...]
1789정성태10/22/201425159오류 유형: 253. 이벤트 로그 - The client-side extension could not remove user policy settings for '...'
1788정성태10/22/201426455VC++: 82. COM 프로그래밍에서 HRESULT 타입의 S_FALSE는 실패일까요? 성공일까요? [2]
1787정성태10/22/201435229오류 유형: 252. COM 개체 등록시 0x8002801C 오류가 발생한다면?
1786정성태10/22/201436702디버깅 기술: 65. 프로세스 비정상 종료 시 "Debug Diagnostic Tool"를 이용해 덤프를 남기는 방법 [3]파일 다운로드1
1785정성태10/22/201426033오류 유형: 251. 이벤트 로그 - Load control template file /_controltemplates/TaxonomyPicker.ascx failed [1]
1784정성태10/22/201432859.NET Framework: 472. C/C++과 C# 사이의 메모리 할당/해제 방법파일 다운로드1
1783정성태10/21/201426877VC++: 81. 프로그래밍에서 borrowing의 개념
1782정성태10/21/201423905오류 유형: 250. 이벤트 로그 - Application Server job failed for service instance Microsoft.Office.Server.Search.Administration.SearchServiceInstance
1781정성태10/21/201424980디버깅 기술: 64. new/delete의 짝이 맞는 경우에도 메모리 누수가 발생한다면?
1780정성태10/15/201428504오류 유형: 249. The application-specific permission settings do not grant Local Activation permission for the COM Server application with CLSID
1779정성태10/15/201423644오류 유형: 248. Active Directory에서 OU가 지워지지 않는 경우
1778정성태10/10/201422096오류 유형: 247. The Netlogon service could not create server share C:\Windows\SYSVOL\sysvol\[도메인명]\SCRIPTS.
1777정성태10/10/201425064오류 유형: 246. The processing of Group Policy failed. Windows attempted to read the file \\[도메인]\sysvol\[도메인]\Policies\{...GUID...}\gpt.ini
1776정성태10/10/201421866오류 유형: 245. 이벤트 로그 - Name resolution for the name _ldap._tcp.dc._msdcs.[도메인명]. timed out after none of the configured DNS servers responded.
1775정성태10/9/201423446오류 유형: 244. Visual Studio 디버깅 (2) - Unable to break execution. This process is not currently executing the type of code that you selected to debug.
1774정성태10/9/201429912개발 환경 구성: 246. IIS 작업자 프로세스의 20분 자동 재생(Recycle)을 끄는 방법
1773정성태10/8/201433473.NET Framework: 471. 웹 브라우저로 다운로드가 되는 파일을 왜 C# 코드로 하면 안되는 걸까요? [1]
1772정성태10/3/201422324.NET Framework: 470. C# 3.0의 기본 인자(default parameter)가 .NET 1.1/2.0에서도 실행될까? [3]
... 121  122  123  124  125  126  127  128  129  130  131  132  133  [134]  135  ...