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

비밀번호

댓글 작성자
 




... 76  77  78  79  80  81  82  [83]  84  85  86  87  88  89  90  ...
NoWriterDateCnt.TitleFile(s)
11856정성태3/25/201919513VS.NET IDE: 134. 마이크로소프트의 CoreCLR 프로파일러 리눅스 예제를 Visual Studio F5 원격 디버깅하는 방법 [1]파일 다운로드1
11855정성태3/25/201921627개발 환경 구성: 436. 페이스북 HTTPS 인증을 localhost에서 테스트하는 방법
11854정성태3/25/201917343VS.NET IDE: 133. IIS Express로 호스팅하는 사이트를 https로 접근하는 방법
11853정성태3/24/201920035개발 환경 구성: 435. 존재하지 않는 IP 주소에 대한 Dns.GetHostByAddress/gethostbyaddr/GetNameInfoW 실행이 느리다면? - 두 번째 이야기 [1]
11852정성태3/20/201919425개발 환경 구성: 434. 존재하지 않는 IP 주소에 대한 Dns.GetHostByAddress/gethostbyaddr/GetNameInfoW 실행이 느리다면?파일 다운로드1
11851정성태3/19/201923211Linux: 8. C# - 리눅스 환경에서 DllImport 대신 라이브러리 동적 로드 처리 [2]
11850정성태3/18/201922087.NET Framework: 813. C# async 메서드에서 out/ref/in 유형의 인자를 사용하지 못하는 이유
11849정성태3/18/201921551.NET Framework: 812. pscp.exe 기능을 C#으로 제어하는 방법파일 다운로드1
11848정성태3/17/201918187스크립트: 14. 윈도우 CMD - 파일이 변경된 경우 파일명을 변경해 복사하고 싶다면?
11847정성태3/17/201922717Linux: 7. 리눅스 C/C++ - 공유 라이브러리 동적 로딩 후 export 함수 사용 방법파일 다운로드1
11846정성태3/15/201921345Linux: 6. getenv, setenv가 언어/운영체제마다 호환이 안 되는 문제
11845정성태3/15/201921551Linux: 5. Linux 응용 프로그램의 (C++) so 의존성 줄이기(ReleaseMinDependency) [3]
11844정성태3/14/201922842개발 환경 구성: 434. Visual Studio 2019 - 리눅스 프로젝트를 이용한 공유/실행(so/out) 프로그램 개발 환경 설정 [1]파일 다운로드1
11843정성태3/14/201917794기타: 75. MSDN 웹 사이트를 기본으로 영문 페이지로 열고 싶다면?
11842정성태3/13/201916222개발 환경 구성: 433. 마이크로소프트의 CoreCLR 프로파일러 예제를 Visual Studio CMake로 빌드하는 방법 [1]파일 다운로드1
11841정성태3/13/201916520VS.NET IDE: 132. Visual Studio 2019 - CMake의 컴파일러를 기본 g++에서 clang++로 변경
11840정성태3/13/201918087오류 유형: 526. 윈도우 10 Ubuntu App 환경에서는 USB 외장 하드 접근 불가
11839정성태3/12/201922038디버깅 기술: 124. .NET Core 웹 앱을 호스팅하는 Azure App Services의 프로세스 메모리 덤프 및 windbg 분석 개요 [3]
11838정성태3/7/201925599.NET Framework: 811. (번역글) .NET Internals Cookbook Part 1 - Exceptions, filters and corrupted processes [1]파일 다운로드1
11837정성태3/6/201939622기타: 74. 도서: 시작하세요! C# 7.3 프로그래밍 [10]
11836정성태3/5/201923099오류 유형: 525. Visual Studio 2019 Preview 4/RC - C# 8.0 Missing compiler required member 'System.Range..ctor' [1]
11835정성태3/5/201921657.NET Framework: 810. C# 8.0의 Index/Range 연산자를 .NET Framework에서 사용하는 방법 및 비동기 스트림의 컴파일 방법 [3]파일 다운로드1
11834정성태3/4/201920518개발 환경 구성: 432. Visual Studio 없이 최신 C# (8.0) 컴파일러를 사용하는 방법
11833정성태3/4/201920996개발 환경 구성: 431. Visual Studio 2019 - CMake를 이용한 공유/실행(so/out) 리눅스 프로젝트 설정파일 다운로드1
11832정성태3/4/201916942오류 유형: 524. Visual Studio CMake - rsync: connection unexpectedly closed
11831정성태3/4/201916748오류 유형: 523. Visual Studio 2019 - 새 창으로 뜬 윈도우를 닫을 때 비정상 종료
... 76  77  78  79  80  81  82  [83]  84  85  86  87  88  89  90  ...