The Pursuit of Happyness

반응형

예전에 node.js에서 Oracle DB를 연결해서 사용하는 프로젝트를 해봤었는데, Oracle 이 node.js 를 제대로 지원하지 못한다는 느낌을 강하게 받았었습니다.


그때는 node.js oracledb 모듈을 설치할 때, 컴파일 과정이 들어가면서 의존성이 있었기 때문에 은근히 번거로웠었는데, oracledb 2.0 부터는 그러한 과정들이 필요 없게되어서 상당히 편리해졌습니다.


다만 새로운 모듈의 특성상 Oracle 혹은 instant client 을 설치하고, 라이브러리 경로를 설정해 줘야지만 제대로 동작합니다. node.js oracledb 와 Oracle 혹은 instant client 의 설치순서는 상관이 없습니다. 런타임 시점에 라이브러리 경로만 인식되면 됩니다.


또 다른 장점으로는 상당히 많은 수정을 통해서 메모리 관리 등에서 훨씬 안정적인 모듈이 되었다는 것입니다.


--


이쯤에서 node.js oracledb 모듈을 설치해 보겠습니다.


테스트 환경은 CentOS 7.4.1708 , node.js 6.12.3 입니다.


1. 적당한 폴더를 생성합니다.

# mkdir test 


2. 폴더에서 node 프로젝트를 생성합니다. 프로젝트 정보는 적당히 입력합니다.

# npm init 


3. 다음 명령어로 oracledb 모듈을 설치합니다.

# npm install --save oracledb 

현재 2.0.15 버전으로 설치가 됩니다.


4. instant client 를 설치합니다. Oracle 다운로드 페이지에서 적당히 다운로드 받습니다.

http://www.oracle.com/technetwork/database/database-technologies/instant-client/downloads/index.html

아래 명령어로 설치를 합니다.

# rpm -ivh  oracle-instantclient12.2-basic-12.2.0.1.0-1.x86_64.rpm

혹은 yum install 명령어를 이용해도 설치가 됩니다.


5. 환경변수를 설정합니다.

# vi /etc/environment


다음의 두줄을 추가합니다 원래 instant client 만 설치할 경우 "/usr/lib/oracle/12.2/client64/network/admin" 경로는 존재하지 않는데, XE 등을 설치시의 tns 설정경로와 비슷하게 하기 위해서 "network/admin" 폴더를 생성해 주었습니다.

TNS_ADMIN=/usr/lib/oracle/12.2/client64/network/admin

LD_LIBRARY_PATH=/usr/lib/oracle/12.2/client64/lib


6. tnsnames.ora 파일을 생성합니다.

# touch /usr/lib/oracle/12.2/client64/network/admin/tnsnames.ora 

생성한 파일을 편집해서 tns 정보를 입력합니다.


7. oracledb에 연결해서 테스트하는 예제들 입니다.

https://github.com/oracle/node-oracledb/tree/master/examples


webapp.js 나 webapppromises.js 파일을 참조하시면 pool 설정 등에 대한 예시를 볼 수 있습니다.



반응형

반응형

윈도우에서 npm으로 oracledb 모듈을 설치하던 중에 다음과 같은 에러가 발생했습니다.


MSBUILD : error MSB4132: The tools version "2.0" is unrecognized. Available tools versions are "4.0".


모듈 설치를 위해서 Python 2.7 과 Visual Studio 2017 CE 를 설치해 두었는데, 위와 같은 에러가 발생했습니다.


(참고로 node oracledb를 설치하기 위해서는 Oracle Instant Client 혹은 XE 등이 필요하고, 그 외에 Python 과 C++ 컴파일러가 필요합니다.)



관련해서 검색을 하다가 아래 링크에서 답을 찾았습니다.


https://github.com/chjj/pty.js/issues/60



요점만 적어보면, 


1. 관리자 권한으로 명령 프롬프트를 실행합니다.


2. 다음 명령으로 빌드 관련 툴을 설치합니다.


 npm install --global --production windows-build-tools 


3. 다음 명령으로 빌드 툴에서 사용할 visual studio 버전을 설정합니다.


 npm config set msvs_version 2015 --global


그리고 나서 창을 닫고 새 창을 열어서 다시 시도하니 설치가 잘 되었습니다.







반응형

반응형

실행환경 Ubuntu 14.04 LTS / node v0.10.25


이번에는 유저가 정의한 모듈을 사용하는 예제이다.

살펴볼 예제는 세율을 설정하고 아이템 가격을 입력하면 세금을 포함한 가격을 계산해 주는 모듈이다.


먼저 lib 라는 폴더를 만들고 거기에 tax.js라는 파일을 생성하여 다음과 같이 코딩한다.

var _taxRate = 0.10;

function roundTwoDecimals(amount) {
        return Math.round(amount*100) / 100;
}

exports.getTaxRate = function() {
        return _taxRate;
}

exports.setTaxRate = function(taxRate) {
        _taxRate = taxRate;
}

exports.calcTotalAmount = function(price) {
        return roundTwoDecimals( (1 + _taxRate) * price );
}

tax 라는 모듈을 이용해서 실행할 예제이다. moduletest.js 라는 파일을 만들어서 다음과 같이 코딩하자.

var tax = require('./lib/tax');
tax.setTaxRate(0.09);

var itemPrice = 10.00;
console.log("Tax Rate     :  " + (tax.getTaxRate()*100).toFixed(2) + "%");
console.log("Item Price   : $" + itemPrice.toFixed(2));
console.log("Total Amount : $" + (tax.calcTotalAmount(itemPrice)).toFixed(2));


nodejs moduletest 라고 실행하면 결과가 출력된다.

모듈을 만들 때 외부에서 접근이 가능하게 하기 위해서는 "exports" 로 정의해야 하며,

exports를 사용하지 않고 정의된 function 은 외부에서 사용이 불가능하다.

반응형

반응형

실행환경 Ubuntu 14.04 LTS / node v0.10.25


다음은 node.js 로 작성한 채팅 서버 코드.

chat.js라는 파일에 다음과 같이 코드를 작성해서 저장.

var net = require('net');
var sockets = [];

var server = net.createServer(
                function(socket) {
                        socket.name = socket.remoteAddress + ":" + socket.remotePort;
                        sockets.push(socket);
                        socket.write("Welcome " + socket.name + "\n");
                        broadcast(socket.name + " joined the chat\n", socket);

                        socket.on('data',
                                function(data) {
                                        broadcast(socket.name + "> " + data, socket);
                                }
                        );

                        socket.on('end',
                                function(data) {
                                        sockets.splice(sockets.indexOf(socket), 1);
                                        broadcast(socket.name + " left the chat.\n");
                                }
                        );
                }
);

function broadcast(message, sender) {
        sockets.forEach(
                function (socket) {
                        if (socket === sender) return;
                        socket.write(message);
                }
        );
}
server.listen(3000);

실행은 nodejs chat 이라고 입력하면 된다.

코드를 살펴보면, 이 채팅 서버는 3000번 포트로 작동한다.

클라이언트에서 접속하면 소켓 IP와 Port를 아이디로 할당하여 sockets 에 저장.

그리고 새로 접속한 클라이언트에게는 서버 Welcome 메시지를 전송하고, 기존의 클라이언트에게는 새로운 유저가 들어왔다는 메시지를 broadcast로  전송.

클라이언트가 끊고 나가는 경우 sockets에서 해당 소켓 정보를 삭제하고 남은 클라이언트 들에게 유저가 나갔다는 메시지를 전달.

 

테스트를 위해서 telnet 을 이용해서 접속을 한다.

telnet [서버IP] 3000

 

텔넷 창을 여러개 띄워서 상대방이 보낸 메시지가 제대로 오는지 확인한다.

반응형

반응형

실행환경 Ubuntu 14.04 LTS / node v0.10.25


다음은 클라이언트가 입력한 값을 그대로 돌려주는 Echo Server를 Node.js 스타일로 작성해 보겠다.

이번 예제에서는 소켓 연결을 위해서 net 모듈을 사용했으며, 3000번 포트로 동작하도록 하였다.

echo.js 라는 파일을 생성하여 아래와 같이 작성한다.

var net = require('net');
var server = net.createServer(
                function(socket) {
                        socket.on('data',
                                function(data) {
                                        socket.write(data);
                                }
                        );
                }
);
server.listen(3000);

실행은 nodejs echo 로 하면 되고, 확인을 위해서 telnet 등을 이용해서 서버에 3000 포트로 접속하면 입력한 값을 되돌려 주는 것을 확인 할 수 있다. 

여기서 socket.on 대신 socket.once 를 사용하면 한번 응답후에 연결을 종료시키도록 할 수 있다.

반응형

반응형

실행환경 Ubuntu 14.04 LTS / node v0.10.25


다음은 8080 포트로 작동하는 Node.js 로 작성한 http 서비스 코드이다.

Node 의 http, fs 서비스를 사용하였고, 요청한 파일이 있으면 내려보내주고, 아니면 간단한 에러를 출력하는데,

실제는 http 서비스의 header 등을 제대로 설정해 주는 것이 좋지만, 예제를 간단히 만들기 위해서 생략하고 파일만 전달하게 작성했다.

Node.js 에서는 많은 코드가 아래와 같이 callback 함수를 등록하는 형식으로 작성된다.

httptest.js 라는 파일을 생성하여 아래와 같이 입력하고 저장한다.


var http = require('http');
var fs = require('fs');

var server = http.createServer(
        function(req, res) {
                var filePath = './public';
                if (req.url == '/') {
                        filePath += '/index.html';
                } else {
                        filePath += req.url;
                }

                fs.exists(filePath,
                        function(exists) {
                                if (exists) {
                                        fs.readFile(filePath,
                                                function(err, data) {
                                                        if (err) {
                                                                res.end('Server Error');
                                                        } else {
                                                                res.end(data);
                                                        }
                                                }
                                        );
                                } else {
                                        res.end('File Not Exists');
                                }
                        }
                );
        }
);
server.listen(8080);


httptest.js 가 실행되는 위치에 public 이라는 이름의 폴더를 만들고 그 안에 필요한 파일들 (index.html 등) 을 넣어 두면 http 서비스가 작동한다. 

서버의 실행은 nodejs httptest 라고 입력하면 된다.

확인은 웹브라우져를 하나 열고 http://[서버 IP]:8080 식으로 입력하면 된다.


반응형

반응형

실행환경 Ubuntu 14.04 LTS / node v0.10.25


프로그래밍 책을 보면 대부분 시작은 Hello World 이다.

Node.js 는 수많은 모듈들을 이용해서 상당히 간결한 코드로 구현하는 경우가 많은데, 

Hello World는 정말 말 그대로 한 줄로 끝난다.

hello.js 라는 파일을 만들어서 다음과 같이 한줄 적고 저장하자.

console.log("Hello World");

긴 설명이 필요 없을 것 같은데, console.log 는 서버쪽에 로그를 남기는 명령어라고 생각하면 된다.

Ubuntu 서버에서는 다음의 명령어로 실행한다.

nodejs hello

확장자가 붙어 있지 않은 경우 자동으로 js 파일로 인식하므로 nodejs hello 라고만 입력하면 된다.





반응형

반응형

설치 환경 Ubuntu 14.04 LTS

Root 권한이라고 가정 (아니면 앞에  sudo 를 붙여주면 됨)


패키지 툴을 이용하는 경우 아래의 명령어만 실행하면 바로 설치가 됩니다.

apt-get install node npm

위의 문장을 실행하면 build-essential, libssl-dev 등의 패키지가 같이 설치되므로 별도로 설치할 필요가 없음


다음으로 Node 를 시작하게 되면 항상 만나게 되는 기본 용어 중에 npm 과 nvm 에 대해서 알아보겠습니다.

 npm

 node package manager

 node 프로그래밍시 사용하게 되는 패키지들을 추가할 때 사용하는 툴

 nvm

 node version manager

 node를 원하는 버전으로 설치하여 관리하기 위해 사용하는 버전 관리자


Ubuntu 에서는 node 실행시 node 대신 nodejs 라는 명령어를 써야한다.

설치가 완료되면 nodejs -v 혹은 nodejs --version 명령어로 설치된 패키지의 버전을 확인할 수 있다.



반응형