Microsoft MVP성태의 닷넷 이야기
개발 환경 구성: 691. WSL 2 (Ubuntu) + nginx 환경 설정 [링크 복사], [링크+제목 복사],
조회: 13024
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

(시리즈 글이 4개 있습니다.)
개발 환경 구성: 606. WSL Ubuntu 20.04에서 파이썬을 위한 uwsgi 설치 방법
; https://www.sysnet.pe.kr/2/0/12857

개발 환경 구성: 618. WSL Ubuntu 20.04에서 파이썬을 위한 uwsgi 설치 방법 (2)
; https://www.sysnet.pe.kr/2/0/12881

개발 환경 구성: 641. WSL 우분투 인스턴스에 파이썬 2.7 개발 환경 구성하는 방법
; https://www.sysnet.pe.kr/2/0/13013

개발 환경 구성: 691. WSL 2 (Ubuntu) + nginx 환경 설정
; https://www.sysnet.pe.kr/2/0/13479




WSL 2 (Ubuntu) + nginx 환경 설정

윈도우에서도 WSL 2 환경의 경우 다음과 같이 간단하게 nginx를 설치할 수 있습니다.

$ sudo apt-get install nginx -y

그런데, 리눅스 기준의 매뉴얼대로 서비스를 시작하면 이런 오류가 발생하는데요,

$ sudo systemctl start nginx
System has not been booted with systemd as init system (PID 1). Can't operate.
Failed to connect to bus: Host is down

이것은 "WSL 2가 기본적으로 systemd 지원"으로 설정돼 있지 않기 때문입니다. 따라서 "/etc/wsl.conf"에 systemd=true 설정을 해도 되겠지만, nginx 설치 시 systemd 환경이 아닌 경우 init.d에 (서비스) 파일이 대신 생성되므로,

$ cat /etc/init.d/nginx
#!/bin/sh

### BEGIN INIT INFO
# Provides:       nginx
# Required-Start:    $local_fs $remote_fs $network $syslog $named
# Required-Stop:     $local_fs $remote_fs $network $syslog $named
# Default-Start:     2 3 4 5
# Default-Stop:      0 1 6
# Short-Description: starts the nginx web server
# Description:       starts nginx using start-stop-daemon
### END INIT INFO

...[생략]...

그냥 service 명령어로 제어하면 됩니다.

$ sudo service nginx start

$ sudo service nginx status

$ sudo service nginx stop




동작 확인을 위해 WSL 2 환경 내에서 curl을 이용하면,

$ curl http://localhost
...[생략: nginx 응답]...

localhost에 대해 정상적으로 응답을 받게 될 것입니다. 반면, WSL을 호스팅하는 윈도우 측에서 curl을 실행하면,

c:\temp> curl http://localhost
...[생략: iis 응답]...

응답이 없거나, IIS를 설치했다면 (nginx가 아닌) IIS로부터 응답을 받게 될 것입니다. 이에 대해서는 전에 설명한 적이 있습니다.

WSL 2의 네트워크 통신 방법 - 두 번째 이야기
; https://www.sysnet.pe.kr/2/0/13256

따라서, 윈도우 측에서 WSL 2에 설치한 nginx에 요청을 전송하려면 IP를 직접 구해서 사용해야 합니다.

c:\temp> wsl hostname -I
172.19.132.144

c:\temp> curl http://172.19.132.144




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







[최초 등록일: ]
[최종 수정일: 12/11/2023]

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

비밀번호

댓글 작성자
 




... 166  167  [168]  169  170  171  172  173  174  175  176  177  178  179  180  ...
NoWriterDateCnt.TitleFile(s)
936정성태10/21/201034131DDK: 4. Device Driver 응용 프로그램의 빌드 스크립트 - 두 번째 이야기 [2]파일 다운로드1
935정성태10/17/201034943디버깅 기술: 28. Windbg - 윈도우 핸들 테이블 [3]
934정성태10/11/201038228디버깅 기술: 27. Windbg - Local Kernel Debug 모드 [2]
933정성태10/10/201030046.NET Framework: 184. 닷넷에서 호출 스택의 메서드에 대한 인자 값 확인이 가능할까? [2]파일 다운로드1
932정성태10/10/201033400DDK: 3. NT Legacy 드라이버를 이용하여 C#에서 Port 입출력파일 다운로드1
931정성태9/30/201028013오류 유형: 108. Net.Tcp Listener Adapter 서비스 시작 실패
930정성태9/30/201026871웹: 16. 윈도우 미디어 플레이어 - 일시 정지/시작을 스크립트에서 감지
929정성태9/17/201028294웹: 15. IE 9 - 작업 표시줄의 웹 사이트 바로가기 사용자 정의 - JumpLists [3]파일 다운로드1
928정성태9/16/201032139VC++: 42. 쓰기 전용 파일(예: 로그 파일)의 동기화 방법파일 다운로드1
927정성태9/14/201042548VC++: 41. UTF-8 포맷의 INI 파일에 대한 GetPrivateProfile... API 사용 불가 [2]
926정성태9/9/201031847Team Foundation Server: 41. 빌드 스크립트에 Code Coverage 추가 [1]파일 다운로드1
925정성태9/8/201035563Team Foundation Server: 40. Visual Studio 2010 - Code Coverage 결과를 외부 XML 파일로 출력하는 명령행 도구 제작 [1]파일 다운로드1
924정성태9/6/201025164개발 환경 구성: 88. SCVMM이 설치된 도메인에 참여하지 않은 Hyper-V 호스트 추가
923정성태9/5/201031717오류 유형: 107. SCVMM Agent 설치 오류 - Failed to configure the WS-Management service.
922정성태9/4/201040562오류 유형: 106. Hyper-V 가상 머신의 네트워크 끊김 현상
921정성태9/2/201034411DDK: 2. Device Driver 응용 프로그램의 빌드 스크립트 [2]파일 다운로드1
920정성태9/1/201039438오류 유형: 105. WMI - The RPC server is unavailable [2]
919정성태8/30/201045549DDK: 1. Visual Studio 2010 - Device Driver 제작- Hello World 예제 [3]파일 다운로드1
918정성태8/28/201031091개발 환경 구성: 87. Hyper-V의 네트워크 유형 (3)
917정성태8/26/201025980개발 환경 구성: 86. "Routing and Remote Access"의 "Routing" 기능 활성화 방법
916정성태8/25/201025111개발 환경 구성: 85. 가상 네트워크에 LAN 어댑터 보이거나 감추는 방법
915정성태8/24/201043476개발 환경 구성: 84. Hyper-V의 네트워크 유형 (2)
913정성태8/22/201032729오류 유형: 104. Hyper-V 관리자 - VM 생성 오류 (VHD 생성 오류)
912정성태8/20/201034190.NET Framework: 183. 구조체 포인터 인자에 대한 P/Invoke 정의파일 다운로드1
911정성태8/19/201031990오류 유형: 103. System.Reflection.TargetException파일 다운로드1
910정성태8/19/201042856개발 환경 구성: 83. Hyper-V의 네트워크 유형 (1)
... 166  167  [168]  169  170  171  172  173  174  175  176  177  178  179  180  ...