Microsoft MVP성태의 닷넷 이야기
Linux: 13. node.js에서 syslog로 출력하는 방법 [링크 복사], [링크+제목 복사],
조회: 11461
글쓴 사람
정성태 (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

비밀번호

댓글 작성자
 




... 31  32  [33]  34  35  36  37  38  39  40  41  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
12811정성태8/27/20218824Linux: 44. 윈도우 개발자를 위한 리눅스 fork 동작 방식 설명 (파이썬 코드)
12810정성태8/27/20217631.NET Framework: 1107. .NET Core/5+에서 동적 컴파일한 C# 코드를 (Breakpoint도 활용하며) 디버깅하는 방법 - #line 지시자파일 다운로드1
12809정성태8/26/20218285.NET Framework: 1106. .NET Core/5+에서 C# 코드를 동적으로 컴파일/사용하는 방법 [1]파일 다운로드1
12808정성태8/25/20219518오류 유형: 758. go: ...: missing go.sum entry; to add it: go mod download ...
12807정성태8/25/20219472.NET Framework: 1105. C# 10 - (9) 비동기 메서드가 사용할 AsyncMethodBuilder 선택 가능파일 다운로드1
12806정성태8/24/20217090개발 환경 구성: 601. PyCharm - 다중 프로세스 디버깅 방법
12805정성태8/24/20218349.NET Framework: 1104. C# 10 - (8) 분해 구문에서 기존 변수의 재사용 가능파일 다운로드1
12804정성태8/24/20219098.NET Framework: 1103. C# 10 - (7) Source Generator V2 APIs
12803정성태8/23/20218752개발 환경 구성: 600. pip cache 디렉터리 옮기는 방법
12802정성태8/23/20219016.NET Framework: 1102. .NET Conf Mini 21.08 - WinUI 3 따라해 보기 [1]
12801정성태8/23/20218516.NET Framework: 1101. C# 10 - (6) record class 타입의 ToString 메서드를 sealed 처리 허용파일 다운로드1
12800정성태8/22/20218756개발 환경 구성: 599. PyCharm - (반대로) 원격 프로세스가 PyCharm에 디버그 연결하는 방법
12799정성태8/22/20218787.NET Framework: 1100. C# 10 - (5) 속성 패턴의 개선파일 다운로드1
12798정성태8/21/202110146개발 환경 구성: 598. PyCharm - 원격 프로세스를 디버그하는 방법
12797정성태8/21/20217853Windows: 197. TCP의 MSS(Maximum Segment Size) 크기는 고정된 것일까요?
12796정성태8/21/20218503.NET Framework: 1099. C# 10 - (4) 상수 문자열에 포맷 식 사용 가능파일 다운로드1
12795정성태8/20/20219156.NET Framework: 1098. .NET 6에 포함된 신규 BCL API - 스레드 관련
12794정성태8/20/20218611스크립트: 23. 파이썬 - WSGI를 만족하는 최소한의 구현 코드 및 PyCharm에서의 디버깅 방법 [1]
12793정성태8/20/20219285.NET Framework: 1097. C# 10 - (3) 개선된 변수 초기화 판정파일 다운로드1
12792정성태8/19/20219747.NET Framework: 1096. C# 10 - (2) 전역 네임스페이스 선언파일 다운로드1
12791정성태8/19/20218087.NET Framework: 1095. C# COM 개체를 C++에서 사용하는 예제 [3]파일 다운로드1
12790정성태8/18/202110286.NET Framework: 1094. C# 10 - (1) 구조체를 생성하는 record struct파일 다운로드1
12789정성태8/18/20219367개발 환경 구성: 597. PyCharm - 윈도우 환경에서 WSL을 이용해 파이썬 앱 개발/디버깅하는 방법
12788정성태8/17/20217896.NET Framework: 1093. C# - 인터페이스의 메서드가 다형성을 제공할까요? (virtual일까요?)파일 다운로드1
12787정성태8/17/20218112.NET Framework: 1092. (책 내용 수정) "4.5.1.4 인터페이스"의 "인터페이스와 다형성"
12786정성태8/16/20219657.NET Framework: 1091. C# - Python range 함수 구현 (2) INumber<T>를 이용한 개선 [1]파일 다운로드1
... 31  32  [33]  34  35  36  37  38  39  40  41  42  43  44  45  ...