Microsoft MVP성태의 닷넷 이야기
Linux: 13. node.js에서 syslog로 출력하는 방법 [링크 복사], [링크+제목 복사],
조회: 18880
글쓴 사람
정성태 (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)
11908정성태5/22/201919811.NET Framework: 836. C# - Python range 함수 구현파일 다운로드1
11907정성태5/22/201916575오류 유형: 541. msbuild - MSB4024 The imported project file "...targets" could not be loaded
11906정성태5/21/201916781.NET Framework: 835. .NET Core/C# - 리눅스 syslog에 로그 남기는 방법
11905정성태5/21/201917363.NET Framework: 834. C# - 폴더 경로 문자열에서 "..", "." 표기를 고려한 최종 문자열을 얻는 방법 - 두 번째 이야기
11904정성태5/21/201925731.NET Framework: 833. C# - Open Hardware Monitor를 이용한 CPU 온도 정보 [1]파일 다운로드1
11903정성태5/21/201919554오류 유형: 540. .NET Core - System.PlatformNotSupportedException: The named version of this synchronization primitive is not supported on this platform.
11902정성태5/21/201917740오류 유형: 539. mstest 실행 시 "The directory name is invalid." 오류 발생
11901정성태5/21/201919617오류 유형: 538. msbuild 오류 - Could not find a part of the path '%LOCALAPPDATA%\Temp\2\.NETFramework,Version=v4.0.AssemblyAttributes.cs'
11900정성태5/18/201918556오류 유형: 537. "sfc /scannow" 실행 중 시스템이 부팅되는 현상
11899정성태5/17/201919410Linux: 9. Linux에서 윈도우의 OutputDebugString 대신 사용할 수 있는 syslog [1]
11898정성태5/16/201921212VC++: 130. C++ string의 c_str과 data 함수의 차이점 [3]
11897정성태5/16/201928194오류 유형: 536. Visual Studio - "Developer Pack"을 설치했는데도 "대상 프레임워크" 목록에 나오지 않는 경우 [2]
11896정성태5/15/201923086개발 환경 구성: 440. C#, C++ - double의 Infinity, NaN 표현 방식파일 다운로드1
11895정성태5/12/201920957.NET Framework: 832. ML.NET Model Builder - 회귀(Regression), 다중 분류(Multi-class classification) 예제파일 다운로드1
11894정성태5/10/201922673VS.NET IDE: 135. Visual Studio - ML.NET Model Builder 소개 [5]
11893정성태5/10/201919602오류 유형: 535. C# 6.0 이상의 문법을 컴파일 시 오류가 발생한다면?
11892정성태5/10/201919430웹: 38. HTTP Cookie의 expires 시간 형식(RFC7231)
11891정성태5/9/201922513.NET Framework: 831. (번역글) .NET Internals Cookbook Part 12 - Memory structure, attributes, handles
11890정성태5/8/201917586개발 환경 구성: 439. "Visual Studio Enterprise is required to execute the test." 메시지와 관련된 코드 기록
11889정성태5/8/201918324개발 환경 구성: 438. mstest, QTAgent의 로그 파일 설정 방법
11888정성태5/8/201935673.NET Framework: 830. C# - 비동기 호출을 취소하는 CancellationToken의 간단한 예제 코드 [1]파일 다운로드1
11887정성태5/8/201921258.NET Framework: 829. C# - yield 문을 사용할 수 있는 메서드의 조건
11886정성태5/7/201919117오류 유형: 534. mstest.exe 실행 시 "Visual Studio Enterprise is required to execute the test." 오류 [2]
11885정성태5/7/201915991오류 유형: 533. mstest.exe 실행 시 "File extension specified '.loadtest' is not a valid test extension." 오류 발생
11884정성태5/5/201920824.NET Framework: 828. C# DLL에서 Win32 C/C++처럼 dllexport 함수를 제공하는 방법 - 두 번째 이야기
11883정성태5/3/201926013.NET Framework: 827. C# - 인터넷 시간 서버로부터 받은 시간을 윈도우에 적용하는 방법파일 다운로드1
... 76  77  78  79  80  [81]  82  83  84  85  86  87  88  89  90  ...