Microsoft MVP성태의 닷넷 이야기
Linux: 13. node.js에서 syslog로 출력하는 방법 [링크 복사], [링크+제목 복사],
조회: 23114
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

node.js에서 syslog로 출력하는 방법

일단 node.js 개발 환경을 설치하고,

Ubuntu 16.04/18.04에서 node.js 최신 버전 설치 방법
; https://www.sysnet.pe.kr/2/0/11944

검색해 본 것 중에 다음의 모듈을 선택했습니다.

strongloop/modern-syslog
; https://github.com/strongloop/modern-syslog

$ sudo npm install modern-syslog

> modern-syslog@1.2.0 install /home/testusr/prjaux/node_modules/modern-syslog
> node-gyp rebuild

make: Entering directory '/home/testusr/prjaux/node_modules/modern-syslog/build'
  CXX(target) Release/obj.target/core/core.o
  SOLINK_MODULE(target) Release/obj.target/core.node
  COPY Release/core.node
make: Leaving directory '/home/testusr/prjaux/node_modules/modern-syslog/build'
/home/testusr/prjaux
└─┬ modern-syslog@1.2.0 
  └── nan@2.14.0 

npm WARN enoent ENOENT: no such file or directory, open '/home/testusr/prjaux/package.json'
npm WARN prjaux No description
npm WARN prjaux No repository field.
npm WARN prjaux No README data
npm WARN prjaux No license field.

그런데 실제 사용 시에는,

const syslog = require("modern-syslog")

syslog.info("test")

다음과 같은 오류가 발생합니다.

internal/modules/cjs/loader.js:805
  return process.dlopen(module, path.toNamespacedPath(filename));
                 ^

Error: The module '/home/testusr/prjaux/node_modules/modern-syslog/build/Release/core.node'
was compiled against a different Node.js version using
NODE_MODULE_VERSION 46. This version of Node.js requires
NODE_MODULE_VERSION 64. Please try re-compiling or re-installing
the module (for instance, using `npm rebuild` or `npm install`).
    at Object.Module._extensions..node (internal/modules/cjs/loader.js:805:18)
    at Module.load (internal/modules/cjs/loader.js:653:32)
    at tryModuleLoad (internal/modules/cjs/loader.js:593:12)
    at Function.Module._load (internal/modules/cjs/loader.js:585:3)
    at Module.require (internal/modules/cjs/loader.js:690:17)
    at require (internal/modules/cjs/helpers.js:25:18)
    at Object.<anonymous> (/home/testusr/prjaux/node_modules/modern-syslog/index.js:9:12)
    at Module._compile (internal/modules/cjs/loader.js:776:30)
    at Object.Module._extensions..js (internal/modules/cjs/loader.js:787:10)
    at Module.load (internal/modules/cjs/loader.js:653:32)
[nodemon] app crashed - waiting for file changes before starting...

메시지를 보면, NODE_MODULE_VERSION 46, NODE_MODULE_VERSION 64 차이라고 생각할 수 있으나... process.dlopen 측의 영향이 더 큰 것 같습니다. 어쨌든 이유는 정확히 알 수 없으나 sudo 권한으로 다음과 같이 실행해야 합니다.

$ sudo node app.js
TEST

혹시, sudo 권한 없이 syslog 출력을 할 수 있는 모듈을 알고 있다면 덧글 부탁드립니다. (C/C++에서 sudo가 필요 없었으니, node.js도 굳이 필요하진 않을 듯한데요. ^^)




참고로, 윈도우의 Ubuntu 스토어 앱에서는 /var/log/syslog 파일이 없습니다. 왜냐하면 서비스 자체가 기본적으로 실행되고 있지 않기 때문입니다. 그래서 미리 해당 서비스를 실행해 두어야 합니다.

$ service rsyslog status
 * rsyslogd is not running

$ sudo service rsyslog start
* Starting enhanced syslogd rsyslogd
[Ubuntu]
$ sudo tail -F /var/log/syslog

[CentOS 7]
$ sudo tail -F /var/log/messages




기타, syslog로 검색한 다른 패키지를 설치해봤더니,

Node-Syslog
; https://www.npmjs.com/package/node-syslog

이번엔 설치 단계에서 오류가 발생합니다.

$ npm install node-syslog

> node-syslog@1.2.0 install /home/testusr/prjaux/node_modules/node-syslog
> node-gyp rebuild

gyp WARN download NVM_NODEJS_ORG_MIRROR is deprecated and will be removed in node-gyp v4, please use NODEJS_ORG_MIRROR
gyp WARN download NVM_NODEJS_ORG_MIRROR is deprecated and will be removed in node-gyp v4, please use NODEJS_ORG_MIRROR
gyp WARN download NVM_NODEJS_ORG_MIRROR is deprecated and will be removed in node-gyp v4, please use NODEJS_ORG_MIRROR
make: Entering directory '/home/testusr/prjaux/node_modules/node-syslog/build'
  CXX(target) Release/obj.target/syslog/syslog.o
In file included from ../node-syslog.h:13:0,
                 from ../syslog.cc:1:
../compat.h:27:2: error: #error "Unsupported node.js version."
 #error "Unsupported node.js version."
  ^
../compat.h:62:53: error: ‘FunctionCallback’ has not been declared
                                                     FunctionCallback callback =
                                                     ^
...[생략]...

"Node-Syslog" 문서에 보면,

This module has been tested with:
node.js v0.8.16

0.8.16이라고 하는데, 엄청 옛날 버전인듯하고... 암튼 지원이 안 됩니다. 또 다른 것도 있지만 역시나 오류가 발생합니다.

$ sudo npm install syslog-node
npm WARN lifecycle unixlib@0.1.3~preinstall: cannot run in wd %s %s
 (wd=%s) unixlib@0.1.3 node-waf configure && node-waf build /home/kevin/prjaux/node_modules/.staging/unixlib-b6827233

> node-syslog@1.2.0 install /home/kevin/prjaux/node_modules/node-syslog
> node-gyp rebuild

make: Entering directory '/home/kevin/prjaux/node_modules/node-sysl
og/build'
  CXX(target) Release/obj.target/syslog/syslog.o
In file included from ../node-syslog.h:13:0,
                 from ../syslog.cc:1:
../compat.h:27:2: error: #error "Unsupported node.js version."
 #error "Unsupported node.js version."
  ^~~~~
../compat.h:62:53: error: ‘FunctionCallback’ has not been declared
                                                     FunctionCallback callback =
...[생략]...




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







[최초 등록일: ]
[최종 수정일: 6/25/2019]

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

비밀번호

댓글 작성자
 




... 151  152  153  154  155  156  157  158  159  160  161  162  163  [164]  165  ...
NoWriterDateCnt.TitleFile(s)
1040정성태5/21/201143680개발 환경 구성: 121. .NET 개발자가 처음 설치해 본 Apache + PHP [2]
1039정성태5/17/201136478.NET Framework: 212. Firebird 데이터베이스와 ADO.NET [2]파일 다운로드1
1038정성태5/16/201138044개발 환경 구성: 120. .NET 프로그래머에게도 유용한 Firebird 무료 데이터베이스 [2]
1037정성태5/11/201133034개발 환경 구성: 119. Visual Studio Professional 이하 버전에서도 TFS의 정적 코드 분석 정책 연동이 가능할까? [3]
1036정성태5/7/201199611오류 유형: 121. Access DB에 대한 32bit/64bit OLE DB Provider 관련 오류 [11]
1035정성태5/7/201133653오류 유형: 120. File cannot be opened. Ensure it is a valid Data Link file.
1034정성태5/2/201130382.NET Framework: 211. 파일 잠금 없이 .NET 어셈블리의 버전을 구하는 방법 [2]파일 다운로드1
1033정성태5/1/201136619웹: 19. IIS Express - appcmd.exe를 이용한 applicationHost.config 변경 [2]
1032정성태5/1/201133180웹: 18. IIS Express를 NT 서비스로 변경
1031정성태4/30/201134124웹: 17. IIS Express - "IIS Installed Versions Manager Interface"의 IIISExpressProcessUtility 구하는 방법 [1]파일 다운로드1
1030정성태4/30/201156931개발 환경 구성: 118. IIS Express - localhost 이외의 호스트 이름으로 접근하는 방법 [4]파일 다운로드1
1029정성태4/28/201145152개발 환경 구성: 117. XCopy에서 파일/디렉터리 확인 질문 없애기 [2]
1028정성태4/27/201142456오류 유형: 119. Visual Studio 2010 SP1 설치 후 Windows Phone 개발자 도구로 인한 재설치 문제 [3]
1027정성태4/25/201131516디버깅 기술: 40. 상황별 GetFunctionPointer 반환값 정리 - x86파일 다운로드1
1026정성태4/25/201150890디버깅 기술: 39. DebugDiag 1.1을 사용한 덤프 분석 [7]
1025정성태4/24/201132590개발 환경 구성: 116. IIS 7 관리자 - Active Directory Certification Authority로부터 SSL 사이트 인증서 받는 방법 [2]
1024정성태4/22/201133999오류 유형: 118. Windows 2008 서버에서 Event Viewer / PowerShell 실행 시 비정상 종료되는 문제 [1]
1023정성태4/20/201134452.NET Framework: 210. Windbg 환경에서 확인해 본 .NET 메서드 JIT 컴파일 전과 후 [1]
1022정성태4/19/201129603디버깅 기술: 38. .NET Disassembly 창에서의 F11(Step-into) 키 동작파일 다운로드1
1021정성태4/18/201131956디버깅 기술: 37. .NET 4.0 응용 프로그램의 Main 함수에 BreakPoint 걸기
1020정성태4/18/201133268오류 유형: 117. Failed to find runtime DLL (mscorwks.dll), 0x80004005
1019정성태4/17/201133963디버깅 기술: 36. Visual Studio의 .NET Disassembly 창의 call 호출에 사용되는 주소의 의미는? [1]파일 다운로드1
1018정성태4/16/201137789오류 유형: 116. 윈도우 업데이트 오류 - 0x8020000E
1017정성태4/14/201132436개발 환경 구성: 115. MSBuild - x86/x64, .NET 2/4, debug/release 빌드에 대한 배치 처리파일 다운로드1
1016정성태4/13/201148329개발 환경 구성: 114. Windows Thin PC 설치 [2]
1015정성태4/9/201133645.NET Framework: 209. AutoReset, ManualReset, Monitor.Wait의 차이파일 다운로드1
... 151  152  153  154  155  156  157  158  159  160  161  162  163  [164]  165  ...