Microsoft MVP성태의 닷넷 이야기
오류 유형: 947. sshd - Failed to start OpenSSH server daemon. [링크 복사], [링크+제목 복사],
조회: 5378
글쓴 사람
정성태 (seongtaejeong at gmail.com)
홈페이지
첨부 파일
 

sshd - Failed to start OpenSSH server daemon.

특정 서버에 어느 순간부터 ssh 접속을 시도했더니 오류가 발생합니다.

실제로 해당 서버에 물리적으로 접속해 보니 22번 대기 포트가 없었는데요, 재미있는 건 재부팅만 하면 22번 포트가 있다가도 클라이언트 측에서 다시 접속을 시도하면 데몬이 죽어버린다는 점입니다. (후에 알았는데, 이것은 순전히 잘못된 옵션의 우연한 동작이었습니다.) 게다가, 관련 메시지만 보면 이게 도대체 무슨 문제인지 알 수가 없습니다. ^^;

$ sudo systemctl status ssh
× ssh.service - OpenBSD Secure Shell server
     Loaded: loaded (/usr/lib/systemd/system/ssh.service; enabled; preset: enabled)
     Active: failed (Result: exit-code) since Wed 2025-02-05 22:52:55 KST; 7min ago
TriggeredBy: × ssh.socket
       Docs: man:sshd(8)
             man:sshd_config(5)
    Process: 1159 ExecStartPre=/usr/sbin/sshd -t (code=exited, status=255/EXCEPTION)
        CPU: 4ms

 ...[생략]... ubuntu22vm systemd[1]: Failed to start ssh.service - OpenBSD Secure Shell server.
 ...[생략]... ubuntu22vm systemd[1]: ssh.service: Scheduled restart job, restart counter is at 5.
 ...[생략]... ubuntu22vm systemd[1]: ssh.service: Start request repeated too quickly.
 ...[생략]... ubuntu22vm systemd[1]: ssh.service: Failed with result 'exit-code'.
 ...[생략]... ubuntu22vm systemd[1]: Failed to start ssh.service - OpenBSD Secure Shell server.
 ...[생략]... ubuntu22vm systemd[1]: Starting ssh.service - OpenBSD Secure Shell server...

$ sudo systemctl restart ssh.service
Job for sshd.service failed because the control process exited with error code.
See "systemctl status sshd.service" and "journalctl -xeu ssh.service" for details.

$ sudo journalctl -xeu sshd.service
...[생략]...

...[생략]... ubuntu22vm systemd[1]: ssh.service: Scheduled restart job, restart counter is at 5.
Subject: Automatic restarting of a unit has been scheduled
Defined-By: systemd
Support: http://www.ubuntu.com/support

Automatic restarting of the unit ssh.service has been scheduled, as the result for
the configured Restart= setting for the unit.
...[생략]... ubuntu22vm systemd[1]: ssh.service: Start request repeated too quickly.
...[생략]... ubuntu22vm systemd[1]: ssh.service: Failed with result 'exit-code'.
Subject: Unit failed
Defined-By: systemd
Support: http://www.ubuntu.com/support

The unit ssh.service has entered the 'failed' state with result 'exit-code'.
...[생략]... ubuntu22vm systemd[1]: Failed to start ssh.service - OpenBSD Secure Shell server.
Subject: A start job for unit ssh.service has failed
Defined-By: systemd
Support: http://www.ubuntu.com/support

A start job for unit ssh.service has finished with a failure.

The job identifier is 5734 and the job result is failed.

그러다, 혹시나 싶어 /usr/lib/systemd/system/ssh.service 파일에 명시된 "ExecStartPre=/usr/sbin/sshd -t" 설정대로 그냥 데몬을 명령행으로 실행했더니 ^^; 이제서야 제대로 된 오류 메시지가 나옵니다.

$ /usr/sbin/sshd -t
/etc/ssh/sshd_config: line 30: Bad configuration option: y#SyslogFacility
/etc/ssh/sshd_config: terminating, 1 bad configuration options

그러니까, 과거에 ssh_config 파일을 nano 에디터로 무심코 수정하다가 "Ctrl + X" + 'y' 키를 눌러 저장을 하면서 종료한다는 것이 절차가 꼬여 저런 식으로 저장된 것이었습니다.




참고로, 위의 오류 로그가 부실한 것은 유독 Ubuntu 서버에서만 그런 것 같습니다. 동일한 상황으로 CentOS 서버에서 테스트해보니 journalctl 로그에 해당 오류 원인을 정확하게 기록하고 있습니다.

$ sudo journalctl -xeu sshd.service
Feb 05 22:21:07 centos9 systemd[1]: Starting OpenSSH server daemon...
Subject: A start job for unit sshd.service has begun execution
Defined-By: systemd
Support: https://access.redhat.com/support

A start job for unit sshd.service has begun execution.

The job identifier is 277.
Feb 05 22:21:07 centos9 sshd[1008]: /etc/ssh/sshd_config: line 34: Bad configuration option: y#SyslogFacility
Feb 05 22:21:07 centos9 sshd[1008]: /etc/ssh/sshd_config: terminating, 1 bad configuration options
Feb 05 22:21:07 centos9 systemd[1]: sshd.service: Main process exited, code=exited, status=255/EXCEPTION
Subject: Unit process exited
Defined-By: systemd
Support: https://access.redhat.com/support

암튼, 이런 어이없는 상황의 연속으로 인해 리알못이라 몇 시간을 낭비한 것인지... ^^;




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







[최초 등록일: ]
[최종 수정일: 2/5/2025]

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

비밀번호

댓글 작성자
 




... 46  47  48  49  50  51  52  53  54  55  56  57  58  [59]  60  ...
NoWriterDateCnt.TitleFile(s)
12496정성태1/19/202118464.NET Framework: 1010. .NET Core 콘솔 프로젝트에서 Kestrel 호스팅 방법 [1]
12495정성태1/19/202120736웹: 40. IIS의 HTTP/2 지원 여부 - h2, h2c [1]
12494정성태1/19/202120091개발 환경 구성: 522. WSL 2 인스턴스와 호스트 측의 Hyper-V에 운영 중인 VM과 네트워크 연결을 하는 방법 [2]
12493정성태1/18/202118189.NET Framework: 1009. .NET 5에서의 네트워크 라이브러리 개선 (1) - HTTP 관련 [1]파일 다운로드1
12492정성태1/17/202117073오류 유형: 695. ASP.NET 0x80131620 Failed to bind to address
12491정성태1/16/202118617.NET Framework: 1008. 배열을 반환하는 C# COM 개체의 메서드를 C++에서 사용 시 메모리 누수 현상 [1]파일 다운로드1
12490정성태1/15/202117519.NET Framework: 1007. C# - foreach에서 열거 변수의 타입을 var로 쓰면 object로 추론하는 문제 [1]파일 다운로드1
12489정성태1/13/202120293.NET Framework: 1006. C# - DB에 저장한 텍스트의 (이모티콘을 비롯해) 유니코드 문자가 '?'로 보인다면? [1]
12488정성태1/13/202118852.NET Framework: 1005. C# - string 타입은 shallow copy일까요? deep copy일까요? [2]파일 다운로드1
12487정성태1/13/202117280.NET Framework: 1004. C# - GC Heap에 위치한 참조 개체의 주소를 알아내는 방법파일 다운로드1
12486정성태1/12/202119848.NET Framework: 1003. x64 환경에서 참조형의 기본 메모리 소비는 얼마나 될까요? [1]
12485정성태1/11/202119313Graphics: 38. C# - OpenCvSharp.VideoWriter에 BMP 파일을 1초씩 출력하는 예제 [2]파일 다운로드1
12484정성태1/9/202121573.NET Framework: 1002. C# - ReadOnlySequence<T> 소개파일 다운로드1
12483정성태1/8/202117620개발 환경 구성: 521. dotPeek - 훌륭한 역어셈블 소스 코드 생성 도구
12482정성태1/8/202119392.NET Framework: 1001. C# - 제네릭 타입/메서드에서 사용 시 경우에 따라 CS8377 컴파일 에러
12481정성태1/7/202119306.NET Framework: 1000. C# - CS8344 컴파일 에러: ref struct 타입의 사용 제한 메서드파일 다운로드1
12480정성태1/6/202122074.NET Framework: 999. C# - ArrayPool<T>와 MemoryPool<T> 소개파일 다운로드1
12479정성태1/6/202119347.NET Framework: 998. C# - OWIN 예제 프로젝트 만들기
12478정성태1/5/202122438.NET Framework: 997. C# - ArrayPool<T> 소개파일 다운로드1
12477정성태1/5/202123336기타: 79. github 코드 검색 방법 [1]
12476정성태1/5/202119030.NET Framework: 996. C# - 닷넷 코어에서 다른 스레드의 callstack을 구하는 방법파일 다운로드1
12475정성태1/5/202123521.NET Framework: 995. C# - Span<T>와 Memory<T> [1]파일 다운로드1
12474정성태1/4/202119921.NET Framework: 994. C# - (.NET Core 2.2부터 가능한) 프로세스 내부에서 CLR ETW 이벤트 수신 [1]파일 다운로드1
12473정성태1/4/202118851.NET Framework: 993. .NET 런타임에 따라 달라지는 정적 필드의 초기화 유무 [1]파일 다운로드1
12472정성태1/3/202118791디버깅 기술: 178. windbg - 디버그 시작 시 스크립트 실행
12471정성태1/1/202119596.NET Framework: 992. C# - .NET Core 3.0 이상부터 제공하는 runtimeOptions의 rollForward 옵션 [1]
... 46  47  48  49  50  51  52  53  54  55  56  57  58  [59]  60  ...