2006년 4월 28일 금요일

Catalina.stop: java.net.ConnectException: Connection refused

Catalina.stop: java.net.ConnectException: Connection refused
java.net.ConnectException: Connection refused

at java.net.PlainSocketImpl.socketConnect(Native Method)
at java.net.PlainSocketImpl.doConnect(PlainSocketImpl.java:305)
at java.net.PlainSocketImpl.connectToAddress(PlainSocketImpl.java:171)
at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:158)
at java.net.Socket.connect(Socket.java:461)
at java.net.Socket.connect(Socket.java:411)
at java.net.Socket.(Socket.java:310)
at java.net.Socket.(Socket.java:125)
at org.apache.catalina.startup.Catalina.stopServer(Catalina.java:410)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:324)
at org.apache.catalina.startup.Bootstrap.stopServer(Bootstrap.java:336)
at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:427)

shutdown.sh 또는 catalina.sh stop을 실행했을 때 자주 발생되는 에러로..

위와 같은 에러가 발생할 때는 웹서버를 완전히 종료한 후에 다시 실행해보면 된다.

아마도 톰캣을 완전히 종료하지 않은 상태에서 start를 했거나, start를 하지 않은 상태에서 stop을 했기 때문으로 보인다.

[같은의견] http://blog.naver.com/tb/cs9505/20017787509

2006년 4월 27일 목요일

리눅스(레드햇 9.0)에서 Apache, MySQL, PHP, Tomcat 연동하기

리눅스(레드햇 9.0)에서 Apache, MySQL, PHP, Tomcat 연동하기

Copyright©2003 yekdm

이문서는 자유롭게 수정 및 배포가 가능합니다. 단 상업적 용도로 사용할 수 없습니다.

수정 및 배포 시 작성자의 이름 및 출처를 꼭 명시하기 바랍니다.

작성자 : 예크디엠(yekdm)

작성일 : 2003년 12월 22일 월요일

이메일 : yekdm@hotmail.com


들어가기에 앞서

이 문서에 작성된 글이 제 좁은 이해력을 바탕으로 한 것이기에 잘못된 부분을 많이 포함하고 있으리라 생각합니다. 부족하지만 공부하는데 도움이 되길 바랍니다.


설치환경

레드햇 9.0 (Kernel 2.4.20-8)


시스템 구성

Apache 2.0.48
MySQL 4.0.17
PHP 4.3.4
Zend Optimizer 2.1.0b
J2SDK 1.4.2
Tomcat 5.0.16
JK2 Connector 2.0.2

1. Mysql 설치

http://www.mysql.com/downloads/index.html 을 방문해서 Mysql database server & standard clients 부분의 Mysql 4.0으로 이동합니다. 문서에 적혀있는데로 Mysql 4.0이 현재 배포되고 있는 공식버전입니다.

http://www.mysql.com/downloads/mysql-4.0.html 로 이동하면 배포본이 바이너리 형식, RPM 형식, 소스 형식의 세가지로 이루어져있음을 알 수 있습니다.

0. 기존의 RPM 패키지 제거

레드햇 리눅스 기반의 시스템에서는 Mysql의 RPM 패키지가 설치되어있는지 먼저 확인합니다.

shell> rpm –qa | grep mysql

또는

shell> rpm –qa | grep MySQL

최근에 배포되고 있는 레드햇 9.0에서는 기본적으로 Mysql이 아닌 PostgreSQL을 기본 데이터베이스로 채택하고 있습니다. 따라서 레드햇 9.0 설치 후 Mysql 을 바로 설치할 경우에는 RPM 패키지를 제거할 필요가 없습니다.

레드햇 기반의 리눅스 배포본에서 Mysql 패키지를 포함하는 경우 Mysql RPM 패키지를 변경 적용함으로 Mysql 공식 사이트에서 제공하는 RPM 패키지와 이름 및 내용이 다를 수 있습니다.

RPM 패키지의 경우 업그레이드가 가능하나 Mysql 3.23 에서 Mysql 4.0 으로의 RPM 업그레이드는 이루어지지 않습니다.

기존에 설치되어있는 Mysql RPM 패키지를 제거합니다.

shell> rpm -e --nodeps [mysql 패키지명]

‘--nodeps’ 옵션은 RPM 삭제시 의존성 여부를 무시하기 위해 사용됩니다.

설치에 앞서 기존에 Mysql을 설치하여 운영했었다면 사용했던 데이터베이스를 백업 받아 놓습니다.

0. Mysql binary 설치

배포파일 mysql-standard-4.0.17-pc-linux-i686.tar.gz

받은 파일을 적당한 위치 (예: /usr/local/src) 로 이동시켜서 압축을 풀어줍니다.

shell> mv ./mysql-standard-4.0.17-pc-linux-i686.tar.gz /usr/local/src

shell> tar xvfz mysql-standard-4.0.17-pc-linux-i686.tar.gz

위의 명령을 실행시키면 현재 위치에 mysql-standard-4.0.17-pc-linux-i686 디렉토리가 생성되면서 압축이 풀립니다. 생성된 디렉토리를 /usr/local/share로 디렉토리명을 mysql로 변경하여 이동시킵니다.

shell> mv ./mysql-standard-4.0.17-pc-linux-i686 /usr/local/share/mysql

또는

shell> cp -r ./mysql-standard-4.0.17-pc-linux-i686 /usr/local/share/mysql

해당 디렉토리로 이동합니다.

shell> cd /usr/local/share/mysql

Mysql을 처음으로 설치하는 경우 아래의 명령을 실행합니다. 이것은 mysql의 grant table을 만들어줍니다.

shell> scripts/mysql_install_db

디렉토리 권한을 설정합니다.

shell> chown -R mysql .

shell> chgrp -R mysql .

Mysql 계정을 등록하지 않았을 경우 Mysql의 사용자 및 그룹 계정을 추가한다.

shell> /usr/sbin/groupadd mysql

shell> /usr/sbin/useradd -g mysql mysql

/etc/passwd 파일과 /etc/group 파일을 에디터로 열어서 mysql 계정이 등록된 것을 확인하고 변경할 사항이 있으면 변경합니다.

Mysql을 실행시킵니다.

shell> bin/mysqld_safe --user=mysql &


시스템 부팅시 자동적으로 Mysql을 실행하고자 할 경우에는 support-files/mysql.server 파일을 /etc/rc.d/init.d 디렉토리로 copy 합니다.

그리고 /etc/rc.d/rc0.d에는 K01mysql이라는 이름으로 /etc/rc.d/rc3.d에는 S90mysql이라는 이름으로 symbolic link를 만들어줍니다. 심볼릭 링크 파일명에서 앞의 S는 부팅시 서비스가 이루어지는 즉 실행되는 파일을 의미하고 K는 서비스가 이루어지지 않는 데몬임을 의미합니다. 그 뒤의 숫자는 임의로 변경가능합니다. 자세한 사항은 리눅스 부팅시 시스템의 초기화 과정을 공부함으로 알 수 있습니다.

기본적으로 mysql install directory는 /usr/local/mysql로 되어있습니다. 그러나 이 문서에서 처럼 /usr/local/share/mysql의 위치에 설치할 경우 즉, /usr/local/mysql이 아닌 다른 위치에 Mysql을 설치할 경우에는 다음의 내용이 기록된 my.cnf를 작성하여 /etc 디렉토리에 저장합니다.

[mysqld]

basedir=/usr/local/share/mysql

datadir=/usr/local/share/mysql/data

기존에 Mysql을 운영한 경우에는 저장된 데이터베이스가 있는 디렉토리를 datadir에 적어주면 사용했던 데이터베이스를 그대로 사용할 수 있습니다. RPM으로 설치되어 운영했을 때의 datadir은 /var/lib/mysql 이므로 datadir=/var/lib/mysql 로 설정해줍니다. 그러면 기존의 데이터를 그대로 사용할 수 있습니다.

이 외의 방법이 몇 가지 더 존재합니다. 추가적인 사항은 mysql.server 파일을 참고하기 바랍니다.


참고사항

- 설치에 필요한 도움말은 binary package에 포함되어 있는 INSTALL-BINARY 파일에 들어있습니다.

- binary package 형태로 설치할 경우 mysql의 실행파일들이 들어있는 bin 디렉토리(/usr/local/share/mysql/bin)를 PATH 설정해서 임의의 위치에서도 사용할 수 있도록 해야 합니다. 이 과정이 mysql.server 파일에서 이루어지는 것 같은데 Redhat 9.0에서는 이 실행파일로는 PATH가 설정되지 않았습니다. 만일 mysql.server만으로 PATH가 설정되지 않으면 /etc/profile 파일에서 PATH를 설정하도록 합니다.

- Mysql 3.23에서 데이터베이스를 운영하다가 4.X로 업그레이드 할 경우 데이터베이스 type이 다르므로 기존의 데이터베이스를 그대로 사용하기 위해서는 특별한 과정을 거쳐야 합니다. Mysql 3.23에서는 디폴트 데이터베이스 type이 ISAM이나 4.X에서는 MyISAM이므로 type을 변경하는 과정이 필요합니다. 자세한 사항은

http://www.mysql.com/documentation/mysql/bychapter/manual_Installing.html#Upgrading-from-3.23 문서를 참고하기 바랍니다.

0. Mysql RPM 설치 (적극 권장)

Mysql 사이트에서 배포되는 Mysql RPM package는 다음과 같습니다.

MySQL-server-4.0.17-0.i386.rpm
MySQL-Max-4.0.17-0.i386.rpm
MySQL-bench-4.0.17-0.i386.rpm
MySQL-client-4.0.17-0.i386.rpm
MySQL-devel-4.0.17-0.i386.rpm
MySQL-shared-4.0.17-0.i386.rpm
MySQL-embedded-4.0.17-0.i386.rpm
MySQL-shared-compat-4.0.17-0.i386.rpm

각각의 패키지에 대해 간단하게 설명하겠습니다.

MySQL-server-4.0.17-0.i386.rpm : Mysql Server,

MySQL-Max-4.0.17-0.i386.rpm : Mysql Max Server, MySQL-server RPM에서 제공하지 않는 추가적으로 확장된 기능을 제공하는 패키지, MySQL-server RPM을 먼저 설치해야 한다.

MySQL-bench-4.0.17-0.i386.rpm : Test와 Benchmark 프로그램, 펄과 DBD::mysql 모듈을 필요로 한다.

MySQL-client-4.0.17-0.i386.rpm : The standard MySQL client programs, Mysql을 이용하는 여러가지 프로그램 제공

MySQL-devel-4.0.17-0.i386.rpm : 펄 모듈과 같은 다른 Mysql client 프로그램들을 컴파일하기 위해서 필요한 library와 include 파일들을 제공

MySQL-shared-4.0.17-0.i386.rpm : 프로그래밍 언어 및 애플리케이션에서 Mysql을 load하고 사용하는데 필요한 공유 라이브러리 제공 (libmysqlclient.so*)

MySQL-embedded-4.0.17-0.i386.rpm : The embedded MySQL server library (from Mysql 4.0)

MySQL-shared-compat-4.0.17-0.i386.rpm : MySQL 3.23과 4.0 두 버전의 공유 라이브러리를 포함한다. MySQL 3.23 환경에서 애플리케이션을 사용하다가 MySQL을 4.0으로 라이브러리 의존성 문제없이 업그레이드를 하고자 할 때 MySQL-shared RPM 대신 설치한다. 이 패키지는 MySQL 4.0.13 부터 이용할 수 있다.

기본적으로 설치할 RPM은 MySQL-server와 MySQL-client 패키지입니다.

이 두 패키지를 Mysql 사이트에서 다운로드 받아 적당한 장소에 옮겨 놓습니다.

(나머지 RPM은 필요에 따라 추가적으로 설치합니다.)

shell> mv ./MySQL-server-4.0.17-0.i386.rpm /usr/local/src

shell> mv ./MySQL-client-4.0.17-0.i386.rpm /usr/local/src

RPM을 설치합니다.

shell> rpm -ivh MySQL-server-4.0.17-0.i386.rpm

shell> rpm -ivh MySQL-client-4.0.17-0.i386.rpm


Mysql 계정이 등록되어있지 않으면 다음과 같이 Mysql 계정을 등록합니다.

shell> /usr/sbin/groupadd mysql

shell> /usr/sbin/useradd -g mysql mysql

/etc/passwd 파일과 /etc/group 파일을 에디터로 열어서 mysql 계정이 등록된 것을 확인하고 변경할 사항이 있으면 변경합니다.

/etc/passwd

mysql:x:27:27:MySQL Server:/var/lib/mysql:/bin/bash

/etc/group

mysql:x:27:

RPM으로 설치한 경우에는 시스템 부팅시 Mysql을 자동으로 실행하기 위한 추가적인 작업이 필요없습니다. RPM으로 설치를 할 경우 RPM 설치 만으로 필요한 과정들이 대부분 이루어지기 때문에 매우 편하게 Mysql을 Install하여 사용할 수 있습니다.

다음의 명령을 실행하여 데이터베이스에 접속합니다.

shell> mysql mysql
또는
shell> mysql -u root -p mysql

참고사항

- http://www.mysql.com/documentation/mysql/bychapter/manual_Installing.html#Linux-RPM에 리눅스 RPM 설치가 설명되어있습니다. 참고하시기 바랍니다.

- RPM으로 설치했을 경우 실행파일들은 /usr/bin에 설치되고, 데이터베이스가 만들어지는 datadir는 /var/lib/mysql 입니다.


0. Mysql source 설치
(이 부분은 직접 실험해보지 않고, Mysql Document를 번역하여 옮겨놓았습니다.)

Mysql source install을 위해 다음과 같은 툴들이 필요하다.

* 압축을 풀기 위한 GNU gunzip, GNU tar. GNU tar 외에 다른 tar를 사용할 수 있으나 그 중 몇 가지는 긴 파일 이름으로 인한 문제를 일으킬 수 있다. e.g.) Sun tar

* ANSI C++ compiler. (gcc 2.95.2 및 이후버전, egcs 1.0.2 및 이후버전 또는 egcs 2.91.66, SGI C++, SunPro C++) gcc를 사용할 경우 libg++이 필요없다. gcc 2.7.X는 sql/sql_base.cc와 같이 완벽하게 작성된 C++파일을 컴파일하지 못하는 버그를 가지고 있다. 이 때에는 Mysql을 컴파일 할 수 있는 gcc로 업그레이드 해야한다. gcc 2.8.1은 몇몇 플랫폼에서 문제를 가지고 있다고 알려져 있다. 따라서 플랫폼에 다른 컴파일러가 있다면 gcc 2.8.1의 사용을 피해야 한다. Mysql version 3.23.X를 컴파일 할 때 gcc 2.95.2 및 이후버전을 권장한다.

* make 프로그램. GNU make 가 권장된다. make시 문제가 발생할 경우 GNU make 3.75 또는 이후버전으로 업그레이드하여 사용한다.

만일 gcc의 최신버전을 사용하고 있고 -fno-exceptions 옵션을 충분히 이해하고 있다면 이 옵션을 사용하는 것이 매우 중요하다. 그렇지않으면 불규칙적으로 충돌하는 바이너리 파일들을 컴파일 할 수도 있다. 따라서 -fno-exceptions를 따라 -felide-constructors와 -fno-rtti 를 사용하길 권장한다. 다음과 같이 명령어를 작성한다.

CFLAGS=”-03” CXX=gcc CXXFLAGS=”-03 -felide-constructors -fno-exceptions \

-fno-rtti” ./configure --prefix=/usr/local/mysql --enable-assembler \

--with-mysqld-ldflags=-all-static

위의 옵션들 중 --prefix 는 컴파일된 파일들이 위치하는 디렉토리 즉 설치 디렉토리를 설정해주는 옵션입니다. 만일 /usr/local/share/mysql의 위치에 Mysql을 설치하고자 할 경우 이 부분에 설치 디렉토리의 위치를 기록합니다.

위의 옵션으로 컴파일 할 경우 대부분의 시스템에서 빠르고 안정적인 바이너리를 제공할 것이다.

Mysql source 배포본은 2가지로 나뉩니다. 하나는 tarball형식으로 압축한 source이고 다른하나는 source RPM 패키지 입니다.

o. tarball(tar.gz) 형식

배포파일 mysql-4.0.17.tar.gz

Mysql 계정이 없을 경우 사용자 및 그룹 계정을 추가합니다.

shell> groupadd mysql

shell> useradd -g mysql mysql

적당한 위치에서 압축을 풉니다.

shell> mv ./mysql-4.0.17.tar.gz /usr/local/src

shell> cd /usr/local/src

shell> tar xvfz mysql-4.0.17.tar.gz

해당 디렉토리로 이동합니다.

shell> cd mysql-4.0.17

Mysql이 설치될 디렉토리를 지정하고 디폴트 Character Set을 한글로 설정합니다.

configure option에 대해 좀더 자세한 사항을 알고자 할 경우 이곳을 방문하시기 바랍니다.

http://www.mysql.com/documentation/mysql/bychapter/manual_Installing.html#configure_options

shell> ./configure --prefix=/usr/local/share/mysql --with-charset=euc_kr

컴파일과 인스톨을 진행합니다.

shell> make

shell> make install

Mysql이 설치된 디렉토리로 이동합니다.

shell> cd /usr/local/share/mysql

기존에 Mysql을 설치하지 않았을 경우 grant table을 만들어줍니다. 처음 설치시 꼭 필요한 과정입니다.

shell> scripts/mysql_install_db

Mysql 디렉토리의 권한을 설정합니다.

shell> chown -R root /usr/local/share/mysql

shell> chown -R mysql /usr/local/share/mysql/var

shell> chgrp -R mysql /usr/local/share/mysql

설정파일 support-files/my-medium.cnf 를 my.cnf라는 이름으로 /etc 디렉토리에 복사합니다.

shell> cp support-files/my-medium.cnf /etc/my.cnf

/etc/my.cnf 파일을 에디터로 열어 basedir과 datadir의 경로가 올바른지 확인합니다.

Mysql을 실행합니다.

shell> bin/mysqld_safe --user=mysql &

만일, 실행 후 프로세스가 계속 사라질 경우 mysql 디렉토리의 user 퍼미션을 모두 mysql로 변경합니다.

시스템 부팅시 자동적으로 Mysql을 실행하고자 할 경우에는 support-files/mysql.server 파일을 /etc/rc.d/init.d 디렉토리로 copy 합니다.

그리고 /etc/rc.d/rc0.d에는 K01mysql이라는 이름으로 /etc/rc.d/rc3.d에는 S90mysql이라는 이름으로 symbolic link를 만들어줍니다.


참고사항

- 좀더 자세한 사항들을 알고 싶을 경우

http://www.mysql.com/documentation/mysql/bychapter/manual_Installing.html#Installing_source 를 방문하기 바랍니다.

- 소스 패키지의 패치는 이 문서에서 다루지 않았습니다. 패치의 적용에 대해 알고싶으신 분은 http://www.mysql.com/documentation/mysql/bychapter/manual_Installing.html#Applying_patches 를 방문하여 참고하시기 바랍니다.

o. Source RPM 형식

배포파일 MySQL-4.0.17.src.rpm

다음의 명령으로 인스톨할 수 있는 binary RPM을 생성합니다.

shell> rpm --rebuild --clean MySQL-4.0.17.src.rpm

이 후 생성된 binary RPM으로 Mysql을 설치한다. 이 과정은 위에서 설명한 Mysql RPM 설치와 동일합니다.



2. Apache 설치

기존에 존재하는 RPM 패키지를 찾아서 삭제합니다.

shell> rpm -qa | grep httpd

shell> rpm -e [httpd RPM name]

현재 Apache 웹데몬이 실행되고 있다면 실행을 중지시킵니다.

shell> /etc/init.d/httpd stop

http://httpd.apache.org/download.cgi 에서 Apache 2.0.48을 다운로드 받습니다. 리눅스에서 설치할 Apache의 배포본은 모두 소스 형식으로 제공됩니다.

배포파일 httpd-2.0.48.tar.gz

적당한 위치에서 다운로드 받은 배포파일의 압축을 풉니다.

shell> mv httpd-2.0.48.tar.gz /usr/local/src

shell> tar xvfz httpd-2.0.48.tar.gz

생성된 디렉토리 httpd-2.0.48로 이동합니다.

shell> cd httpd-2.0.48

다음과 같은 옵션을 사용하여 configure를 진행합니다.

옵션, 모듈 및 DSO에 대한 자세한 사항은 이후 추가적으로 설명할 것입니다.

shell> ./configure --enable-layout=RedHat --enable-rule=SHARED_CORE --enable-modules=so --enable-so

이어서 컴파일과 인스톨을 실행합니다.

shell> make

shell> make install

위의 과정으로 설치를 진행하면 Apache의 root 디렉토리는 /usr이 되고, 웹서비스는 /var/www 디렉토리 밑에서 이루어지며, 설정파일들은 /etc/httpd 디렉토리에, 실행파일들은 /usr/sbin 디렉토리에 설치됩니다. 레드햇 기반의 리눅스는 기본적으로 웹서버로 Apache를 사용하기 때문에 리눅스 설치 후 추가적인 업그레이드 없이 Apache로 웹서버를 운영했을 경우 기존의 디렉토리 구조를 그대로 유지하게 됩니다. 이것은 configure 진행시 --enable-layout=RedHat이라는 옵션을 사용했기 때문입니다. 디렉토리에 대한 정보는 /usr/local/src/httpd-2.0.48/config.layout을 통해 확인하기 바랍니다. 더 자세한 사항은 설치 과정 설명을 마치고 보충하겠습니다.

다음으로 /etc/httpd/conf 디렉토리의 설정파일을 변경합니다.

설치 전에 웹서버를 운영하면서 사용된 설정파일들은 설치하면서 변경되지 않습니다. 설치시 생성된 파일들은 highperformance-std.conf, httpd-std.conf, ssl-std.conf 입니다. 이 세 파일들을 각각 highperformance.conf, httpd.conf, ssl.conf 로 이름을 변경하여 기존의 파일에 덮어씌웁니다.

/usr/sbin/apachectl 실행파일을 이용하여 웹데몬을 실행시켜봅니다.

Apache 설치 전 웹데몬을 중지시켰다면 다음과 같이 실행이 될 것입니다.

shell> /usr/sbin/apachectl start

httpd: Could not determine the server's fully qualified domain name, using 127.0

.0.1 for ServerName

이 메시지는 /etc/httpd/conf/httpd.conf 설정파일을 수정하지 않았기 때문에 표시되는 것입니다. 그러나 웹데몬은 잘 동작하고 인터넷을 통해 접속이 가능합니다. 만일 설치 전 웹데몬을 중지시키지 않았다면 위의 명령은 실행되지 않고 오류메세지를 나타냅니다. 이때에는 일일이 kill [PID] 명령으로 웹데몬 프로세스들을 중지시키고 실행시켜야 합니다. start 명령외에 stop과 restart 명령을 사용하여 웹데몬 가동을 중지시키거나 재시작할 수 있습니다.

shell> /usr/sbin/apachectl restart

shell> /usr/sbin/apachectl stop

부팅시 자동으로 httpd 데몬이 실행되도록 합니다.

/usr/sbin/apachectl 파일을 /etc/init.d 디렉토리에 httpd로 이름을 변경하여 복사합니다. 기존에 httpd 파일이 존재할 경우 덮어씌웁니다. 그리고 /etc/rc.d/rc0.d, /etc/rc.d/rc3.d, /etc/rc.d/rc5.d 디렉토리에 /etc/rc.d/init.d/httpd의 symbolic link 파일이 있는지 확인하고 없으면 link 파일을 생성합니다.

shell> ln -s /etc/rc.d/init.d/httpd /etc/rc.d/rc0.d/K90httpd

shell> ln -s /etc/rc.d/init.d/httpd /etc/rc.d/rc3.d/S89httpd

shell> ln -s /etc/rc.d/init.d/httpd /etc/rc.d/rc5.d/S89httpd

마지막으로 /etc/httpd/conf/httpd.conf 파일의 설정을 변경합니다.

기본적으로 변경해야할 부분은

#servername www.example.com:80

으로 #을 제거하고 www.example.com을 웹서버의 domain name으로 수정해 주거나 localhost로 적어줍니다.

servername yekdm.com:80
또는
servername localhost:80

뒤의 80이라는 숫자는 웹서버가 이용할 port 번호를 가리킵니다. 웹서버는 기본적으로 80번 port를 사용하며 특별한 경우가 아니라면 변경하지 않기를 바랍니다.

한글을 지원하기 위해서 AddDefaultCharset ISO-8859-1 부분을 찾아서 AddDefaultCharset utf8 또는 AddDefaultCharset euc_kr 로 변경합니다.

httpd.conf 설정파일은 Apache 웹서버를 시스템에 맞게 구동시키는데 매우 중요한 정보들을 담고 있습니다. Apache HTTP Server Version 2.0 문서 http://httpd.apache.org/docs-2.0/ 를 참고하시기 바랍니다.

위의 과정으로 Apache 웹서버의 설치가 끝났습니다. 그러나 아파치 웹서버는 관리자가 모듈들을 선택하여 서버에 포함할 기능을 결정할 수 있는 모듈화된 프로그램으로 모듈의 개념 및 사용법, 동적공유객체(DSO) 등을 이해하여야 아파치의 확장된 기능을 사용할 수 있습니다. 즉, PHP와 같은 프로그래밍 언어를 사용하고자 할 경우 또는 자바의 Servlet Container인 Tomcat과 Apache 웹서버와의 연동은 모듈을 통하여 이루어집니다.

전반적인 내용은 Apache HTTP Server Version 2.0 문서 http://httpd.apache.org/docs-2.0/ 에 있습니다. 여기서는 기본적으로 필요한 사항에 대해서만 설명하겠습니다.

* configure 옵션 (autoconf 출력옵션)

--help

모든 옵션과 사용법을 화면에 출력해줍니다. 실제로 configure가 이루어지지 않습니다.

--prefix=/usr/local/share/apache

Apache 웹서버가 설치될 디렉토리를 설정합니다. 이 문서에서는 RedHat에 포함된 Apache의 기본 디렉토리 구조를 따라가고자 이 옵션을 사용하지 않고 --enable-layout=RedHat이라는 옵션을 사용했습니다.

--enable-layout=RedHat

이 옵션을 통해 여러가지 플랫폼에 해당하는 적절한 디렉토리 구조를 따라 Apache를 설치할 수 있습니다. 각 플랫폼의 path layout은 config.layout 파일에 기록되어 있습니다.

--enable-rule=SHARED_CORE

Apache 컴파일시 rule을 지정합니다. SHARED_CORE는 DSO(Dynamic Shared Objects, 동적공유객체)를 사용할 수 있는 형태로 Apache를 컴파일하도록 하는 일종의 규칙입니다. 이 옵션을 지정해주면 DSO로 컴파일된 아파치에서 제공하지 않는 외부 모듈들을 선택적으로 사용할 수 있게 됩니다.

기본형은 --enable-rule=[RULE-NAME]으로 [RULE-NAME]에 해당하는 컴파일 규칙을 enable시킵니다. --help 옵션으로 나타나는 도움말에서는 이 옵션을 표시하고 있지 않습니다.

--enable-modules=so

mod_so(so_module)를 Apache에 컴파일하여 포함시킵니다.(모듈의 정적 컴파일)

기본형은 --enable-modules=[MODULE-LIST]로 공백으로 구분한 [MODULE-LIST]에 나와있는 모듈들을 컴파일하여 포함합니다.

--enable-so

Apache가 실행시 특별한 옵션없이 자동으로 동적공유객체(DSO-Dynamic Shared Objects)를 읽어들일 수 있도록 하기 위한 설정옵션입니다.

이외에 여러가지 옵션들이 제공됩니다. 추가적인 사항은 Apache HTTP Server Version 2.0 문서 http://httpd.apache.org/docs-2.0/ 을 찾아보거나 --help 옵션으로 확인하기 바랍니다.

* 모듈

Apache는 모듈화된 설계로 이루어진 프로그램입니다. 모듈은 특별한 기능을 수행하기 위한 작은 프로그램으로 이해할 수 있습니다. 즉, 모듈마다 각각의 역할이 다르기 때문에 핵심 구현부 또는 실행부에 추가적으로 포함시켜 원하는 기능을 선택적으로 사용할 수 있습니다. Apache의 핵심 기능을 구현하는 모듈은 core이고 core를 기반으로 모듈을 추가하여 확장된 기능을 사용할 수 있습니다. 모듈은 Apache 컴파일시 정적으로 포함시킬 수 있고, 또는 DSO mechanism에 의해 Apache 컴파일 이후 추가적으로 포함하여 사용할 수 있습니다. DSO(Dynamic Shared Objects)를 지원하기 위해서는 컴파일시 configure 옵션으로 --enable-rule=SHARED_CORE를 추가하여 DSO 지원 형식으로 Apache를 컴파일하여야 하며, mod_so 모듈을 컴파일시 포함시켜야 합니다. mod_so 모듈은 core를 제외하고 DSO가 될 수 없는 유일한 모듈로서 Apache 핵심에 정적으로 컴파일해야 하며, DSO로 컴파일된 모듈을 Apache에서 읽어들이기 위한 기능을 제공합니다. 따라서 configure 진행시 일반적으로 mod_so를 포함하도록 합니다. 나머지 모듈에 관하여는 Apache Document를 참고하기 바랍니다.

* 동적공유객체(DSO-Dynamic Shared Objects)

Apache가 동적으로 load할 수 있는 객체입니다. core와 mod_so를 제외한 다른 모든 아파치 모듈 소스를 DSO 형식의 모듈로 컴파일하여 Apache에서 load하여 사용할 수 있습니다. DSO로 사용할 아파치 모듈을 쉽게 만들기 위해서 apxs(Apache Extension Tool)라는 지원프로그램이 있습니다. 이 프로그램으로 아파치 배포본 소스 트리 없이, DSO 지원을 위한 플랫폼 특유의 컴파일러 옵션과 링커 옵션을 고려하지 않고 모듈 소스를 DSO 모듈로 쉽게 컴파일할 수 있습니다. PHP와 Tomcat 등 외부 프로그램에서 제공하는 DSO 모듈은 프로그램 configure시 apxs를 사용한 옵션을 통해 프로그램과 함께 컴파일되어 생성됩니다. 자세한 사항은 Apache Document 내의 동적공유객체(DSO) http://httpd.apache.org/docs-2.0/dso.html 문서를 참고하기 바랍니다.


참고사항

- 다음은 Apache HTTP Server Project 사이트에서 제공하는 문서입니다. 이 문서를 통해 Apache에 대해 더 유익한 정보들을 얻을 수 있습니다.

Apache HTTP Server Version 2.0 문서 http://httpd.apache.org/docs-2.0/



3. PHP 설치

http://www.php.net/downloads.php 에서 소스 배포본을 다운로드 받습니다. 사이트를 방문하면 알 수 있듯이 윈도우 외의 시스템에서는 소스 형식의 배포본 만을 제공합니다.

배포파일 php-4.3.4.tar.gz

PHP는 모든 버전이 Apache 1.3.X와 연동이 가능합니다.

Apache 2.0의 최신버전과 함께 설치할 버전으로 PHP 4.3.0 및 이후 버전을 사용해야 합니다. Apache 2.0의 SAPI-support는 PHP 4.2.0에서부터 시작되었습니다. PHP 4.2.3은 Apache 2.0.39에서 동작하므로 PHP 4.2.3과 다른 Apache 2.0 버전을 사용하지 말기 바랍니다. 권장되는 설치 버전은 Apache 2의 최신 버전과 함께 PHP 4.3.0 및 이후 버전을 사용하는 것입니다.

기존에 PHP가 RPM으로 설치되어있는지 확인한 후 설치되어 있으면 RPM을 제거합니다.

shell> rpm -qa | grep php

shell> rpm -e (--nodeps) [php RPM name]

배포파일을 적당한 위치로 옮긴 후 압축을 풀어줍니다.

shell> mv php-4.3.4.tar.gz /usr/local/src

shell> cd /usr/local/src

shell> tar xvfz php-4.3.4.tar.gz

압축을 풀면 php-4.3.4 디렉토리가 생성됩니다.

디렉토리 안으로 이동하여 configure를 실행시킵니다.

shell> cd ./php-4.3.4

shell> ./configure --with-apxs2=/usr/sbin/apxs --with-config-file-path=/etc --with-zlib --with-gd --with-mysql --with-mod-charset --with-language=korean --with-charset=euc_kr

위의 옵션으로 실행했을 때 libpng.(a|so)를 찾을 수 없다는 오류가 발생할 수 있습니다. 이 때에는 --with-gd 옵션을 제거하고 실행하거나 http://ftp.redhat.com/pub/redhat/linux/9/en/os/i386/RedHat/RPMS/ 에서 libpng-devel-1.2.2-16.i386.rpm을 다운로드 받아서 설치한 후 실행하기 바랍니다. GD는 PHP 자체적으로 그래픽을 지원하는 기능이므로 PHP로 그래픽을 구현하기 위해서 꼭 필요한 옵션입니다.

* configure options

--prefix=PRIFIX

설치 디렉토리 설정. 디폴트 설치 디렉토리는 /usr/local 입니다. 즉 이 옵션을 사용하지 않을 경우 /usr/local 디렉토리에 PHP가 설치됩니다.

--with-apxs2[=FILE]

Apache 2.0 에서 공유할 DSO 모듈을 build하기 위해 사용합니다. FILE은 Apache apxs tool이 있는 경로를 나타냅니다. 디폴트는 apxs입니다. Apache 1.3.X에서는 --with-apxs[=FILE] 옵션을 사용합니다.

--with-config-file-path=PATH

php.ini 설정파일이 위치하게 될 경로를 정해줍니다. 디폴트는 PRIFIX/lib에 위치하게 됩니다. (PRIFIX가 /usr/local이면 /usr/local/lib에 위치하게됩니다.)

--with-zlib[=DIR]

ZLIB support를 포함시킵니다. 시스템에 zlib 1.0.9 및 이후 버전이 설치되어있어야 합니다. 레드햇 9.0에서는 1.1.4-8 버전이 RPM으로 설치되어있습니다. 확인해보시기 바랍니다.

--with-gd[=DIR]

GD support를 포함시킵니다. DIR은 GD가 인스톨된 디렉토리의 경로명입니다. DIR을 셋팅해주지 않으면 번들용 GD 라이브러리가 사용됩니다.

--with-mysql[=DIR]

MySQL support를 포함시킵니다. DIR은 MySQL의 base directory로, 정의해주지 않으면 번들용 MySQL library가 사용됩니다.

--with-mod-charset

Russian Apache의 mod_charset 모듈에 대한 통신 테이블을 제공합니다. Apache의 mod_charset 모듈은 문서원본의 character-set과 문서를 클라이언트로 보내기 전에 변환할 character-set을 지정할 수 있는 역할을 제공합니다. Apache 2.0에서는 mod_charset_lite 모듈을 통해 실험적으로 구현하고 있습니다.

(XML support는 PHP 4.X 버전에서 자동으로 포함합니다.)

이 외의 옵션에 관해서는 configure --help 명령을 통해 확인해보거나, http://kr2.php.net/manual/kr/print/install.configure.php 문서를 참고하시기 바랍니다.

컴파일과 인스톨을 진행합니다.

shell> make

shell> make install

다음은 위의 과정으로 설치를 진행했을 경우의 설치 경로입니다.

PHP CLI binary : /usr/local/bin/
PHP CLI man page : /usr/local/man/man1/
Apache Shared module (libphp4.so) : /usr/lib/apache/
shared extensions : /usr/local/lib/php/extensions/no-debug-non-zts-20020429
PEAL environment : /usr/local/lib/php/
build environment : /usr/local/lib/php/build/
header files : /usr/local/include/php/
helper programs : /usr/local/bin/

php.ini-dist를 /etc에 php.ini 로 이름을 변경하여 복사합니다. 기존에 있던 php.ini 파일은 php.ini.rpmsave 파일로 이름이 변경되어 있습니다.

shell> cp php.ini-dist /etc/php.ini

마지막으로 Apache 웹서버와 PHP 모듈과의 연동을 위해서 /etc/httpd/conf/httpd.conf 파일을 수정해줍니다. PHP install(make install 과정)시 모듈을 load하는 부분이 httpd.conf 파일에 자동으로 추가됩니다. 다음 부분이 httpd.conf 파일에 기록되어 있는지 확인합니다.

LoadModule php4_module lib/apache/libphp4.so

이부분이 없을 경우 Dynamic Shared Object (DSO) Support 부분에 추가합니다.

AddType 부분으로 이동해서 다음을 추가합니다.

AddType application/x-httpd-php .php .phtml
AddType application/s-httpd-php-source .phps

DirectoryIndex 부분을 찾아 index.php와 index.phtml을 추가합니다.

DirectoryIndex index.html index.html.var index.php index.phtml

httpd 데몬을 재실행합니다. (Apache 웹서버를 재가동시킵니다.)

shell> /etc/init.d/httpd restart

/var/www/html 디렉토리 내에서 다음과 같은 코드를 작성하여 웹브라우저를 통해 확인해봅니다.

shell> vi phpinfo.php

^d

PHP를 재설치하거나, 업그레이드하거나 또는 패치할 경우 config.cache 파일을 삭제한 후 위와 동일한 과정으로 진행합니다.


참고사항

- 다음 문서를 참고하시기 바랍니다.

http://kr2.php.net/manual/kr/print/install.apache2.php
http://kr2.php.net/manual/kr/print/install.configure.php



4. Zend Optimizer 설치

Zend Optimizer - Zend Encoder와 Zend SafeGuard Suite에 의해 encoding된 파일을 실행시키며, PHP Application의 실행속도를 향상시키는 free software. runtime performance를 40%이상 향상시킬 수 있습니다.

http://zend.com/store/free_download.php?pid=13 에서 리눅스용 최신 버전을 다운로드 받습니다.

배포파일 ZendOptimizer-2[1].1.0b-Linux_glibc21-i386.tar.gz

배포파일을 적당한 위치로 옮겨서 압축을 풀어준다.

shell> mv ZendOptimizer-2[1].1.0b-Linux_glibc21-i386.tar.gz /usr/local/src
shell> tar xvfz ZendOptimizer-2[1].1.0b-Linux_glibc21-i386.tar.gz

ZendOptimizer-2.1.0b-Linux_glibc21-i386 디렉토리가 생성되어 압축이 풀립니다. 이 디렉토리로 이동합니다.

shell> cd ZendOptimizer-2.1.0b-Linux_glibc21-i386

다음의 명령을 실행시킵니다.

shell> ./install.sh

화면에 GUI 환경이 나타나면서 install이 진행됩니다. 각 과정은 자동으로 이루어지며 마지막으로 Apache 웹서버를 재구동시켜줍니다. 설치는 /usr/local/Zend 경로에서 이루어집니다. 기존의 /etc/php.ini 파일은 /etc/php.ini-zend_optimizer.bak 으로 이름이 변경되고 php.ini 파일이 /usr/local/Zend/etc 안에 생성되며 /etc 디렉토리 안에는 이 /usr/local/Zend/etc/php.ini 의 symbolic link 파일이 만들어져 실제 php.ini 파일과 연결됩니다. 모든 과정이 끝나면 Zend Optimizer가 성공적으로 설치된 것입니다. install을 진행하면서 화면에 나타난 글들을 주의깊게 읽어보시기 바랍니다.



5. J2SE 설치

http://java.sun.com/j2se/1.4.2/download.html 의 Download J2SE v 1.4.2_03에서 SDK를 다운로드 받습니다. 배포본 형태는 2가지로 하나는 RPM 파일을 만들어주는 binary 파일이고, 다른 하나는 배포파일이 있는 그 자리에서 압축을 풀어서 설치하는 바이너리 파일입니다. 레드햇 기반의 리눅스에서는 RPM 소스 형식의 배포본을 다운로드 받아서 설치하길 권장합니다.

0. RPM 소스 설치

배포파일 j2sdk-1_4_2_03-linux-i586-rpm.bin

적당한 위치로 배포파일을 옮겨서 파일을 실행시킵니다.
실행 전 배포파일의 퍼미션을 확인하여 실행가능한 퍼미션을 갖도록 설정을 합니다.

shell> mv j2sdk-1_4_2_03-linux-i586-rpm.bin /usr/local/src
shell> cd /usr/local/src
shell> chmod 755 j2sdk-1_4_2_03-linux-i586-rpm.bin
shell> ./j2sdk-1_4_2_03-linux-i586-rpm.bin

사용권 계약이 화면에 출력되면 y 또는 yes를 입력하여 동의합니다. 이 후 설치가 계속 진행되어 j2sdk-1_4_2_03-linux-i586.rpm 파일이 생성됩니다. 생성된 RPM 파일을 설치합니다.

shell> rpm -ivh j2sdk-1_4_2_03-linux-i586.rpm

/usr/java/j2sdk1.4.2_03 디렉토리가 생성되면서 이 곳에서 설치가 이루어집니다.

/etc/profile을 편집하여 PATH 설정을 해줍니다.

profile 첫부분에 다음을 추가해줍니다.

shell> vi /etc/profile

JAVA_HOME=/usr/java/j2sdk1.4.2_03

PATH=$PATH:$JAVA_HOME/bin

export JAVA_HOME

변경된 설정을 시스템에 적용시킵니다.

shell> source /etc/profile

임의의 위치에서 java를 실행시킵니다.

shell> java

JAVA option들이 화면에 출력되면 성공적으로 설치가 이루어진 것입니다.


0. binary 배포본 설치

배포파일 j2sdk-1_4_2_03-linux-i586.bin

설치할 경로로 파일을 옮깁니다. 여기서는 /usr/local/share 에 J2SE를 설치할 것 입니다.

shell> mv j2sdk-1_4_2_03-linux-i586.bin /usr/local/share
shell> cd /usr/local/share

퍼미션을 확인하여 파일이 실행가능하도록 권한을 설정합니다.

shell> chmod 755 j2sdk-1_4_2_03-linux-i586.bin

파일을 실행시켜서 J2SE를 설치합니다.

shell> ./ j2sdk-1_4_2_03-linux-i586.bin

먼저 화면에 사용권 계약이 출력됩니다. 사용권 계약에 동의하기 위해 y 또는 yes를 입력하면 압축이 풀리면서 SDK가 설치됩니다. 설치경로는 /usr/local/share/j2sdk1.4.2_03 입니다.

PATH를 설정해줍니다. PATH 설정은 /etc/profile을 편집하여 이루어집니다. /etc/profile을 에디터로 열어서 파일 첫부분에 다음을 추가합니다.

shell> vi /etc/profile

JAVA_HOME=/usr/local/share/j2sdk1.4.2_03

PATH=$PATH:$JAVA_HOME/bin

export JAVA_HOME

변경된 설정을 시스템에 적용시킵니다.

shell> source /etc/profile

임의의 위치에서 java를 실행시킵니다.

shell> java

JAVA option들이 화면에 출력되면 성공적으로 설치가 이루어진 것입니다


참고사항

- J2SE의 배포본은 JRE(Java Runtime Environment)와 SDK(Software Development Kit)로 나뉘어집니다. JRE는 자바로 개발된 소프트웨어를 실행시키는 데 필요한 패키지이고 SDK는 자바를 사용하여 소프트웨어를 개발하는 개발자들을 위한 패키지입니다. 따라서 개발을 목적으로 자바를 설치하려는 사람은 SDK를 다운로드 받아서 설치하기 바랍니다.

- /etc/profile은 로그인시 필요한 환경을 설정해주는 설정파일로 쉘스크립트로 이루어져있습니다. profile의 내용을 잘 이해하시는 분은 자바 실행파일이 위치한 JAVA_HOME/bin 디렉토리의 PATH가 잘 이루어지도록 임의로 변경할 수 있습니다. 자바는 PATH에 상관없이 배포파일을 실행시켜서 또는 배포파일을 실행시켜서 생성된 RPM을 설치함으로 install이 완료된 것입니다. PATH 설정은 설치된 자바를 임의의 위치에서 편리하게 사용 가능하도록 하기 위한 것입니다.

- 자바의 공식 사이트 http://java.sun.com 에서 더 많은 정보들을 얻을 수 있습니다.



6. Tomcat 설치

* Java Servlet Container

JVM 상에서 WEB 서비스를 위한 Java Servlet API를 구현하여 서비스 해주는 Java Program으로, Servlet Container는 Client의 http 요청을 웹서버를 통해 전달받아서 Application Servlet에 전달하고, Servlet의 http 응답 메시지를 웹서버에게 전달해서 Client로 돌려주는 역할을 한다.

* Servlet Container의 종류

1) Sun Microsystems 제공 Servlet Container

JSDK(Java Servlet Development Kit)
JSWDK(JavaServer Web Development Kit)
J2EE(Java2 SDK, Enterprise Edition)
Java Web Server(iPlanet Web Server)

2) Apache 제공 Servlet Container
Apache JServ, Tomcat

3) 기타 Servlet Container
JRun/JRun Pro, Resin, WebLogic, Web Sphere, IAS

* Tomcat
Tomcat은 Apache Software Foundation의 Jakarta 프로젝트의 일환으로 개발중인 소프트웨어입니다.
Tomcat은 Java Servlet과 Java Server Page를 사용할 수 있도록 하는 Servlet Container이며 독립적으로 웹서버의 기능을 수행합니다. 그러나 일반 html 문서도 Servlet Container를 통해 번역되므로 수행속도가 느리고 웹서버로서의 기능에 제한이 있으므로 보통 다양한 모듈과 막강한 기능을 가지고 있는 Apache 웹서버와 연동하여 사용합니다.

배포본은 binary와 source 형식으로 제공됩니다. 여기서는 바이너리 배포본의 설치만 설명합니다. The Apache Jakarta Project 홈페이지의 Downloads 부분에 있는 CVS repositories는 현재 개발중인 소스들을 확인하고 다운로드 받을 수 있는 페이지입니다. (CVS는 Concurrent Version System의 약어로 오픈소스 프로젝트에서 개발중인 소스의 버전을 관리해주는 시스템입니다. CVS에 대한 자세한 사항은 이 문서의 성격과 다르므로 언급하지 않겠습니다. 자세한 사항은 CVS 매뉴얼을 참고하기 바랍니다.)

0. 바이너리 설치

http://jakarta.apache.org/site/binindex.cgi에서 Tomcat 5.0.16의 tarball 형식의 배포본을 다운로드 받습니다.

배포파일 jakarta-tomcat-5.0.16.tar.gz

적당한 위치(설치하고자 하는 경로)에서 압축을 풀어줍니다. 바이너리 배포본은 압축을 풀어줌으로 기본적인 설치가 완료된 것입니다.

shell> cp jakarta-tomcat-5.0.16.tar.gz /usr/local/share
shell> cd /usr/local/share
shell> tar xvfz jakarta-tomcat-5.0.16.tar.gz

Jakarta-tomcat-5.0.16 디렉토리가 생성되고 압축이 풀립니다.
실행파일이 들어있는 디렉토리로 이동해서 Tomcat을 실행시켜봅니다.

shell> cd /usr/local/share/Jakarta-tomcat-5.0.16/bin
shell> ./startup.sh
또는
shell> ./catalina.sh start

Using CATALINA_BASE: /usr/local/share/jakarta-tomcat-5.0.16
Using CATALINA_HOME: /usr/local/share/jakarta-tomcat-5.0.16
Using CATALINA_TMPDIR: /usr/local/share/jakarta-tomcat-5.0.16/temp
Using JAVA_HOME: /usr/java/j2sdk1.4.2_03

위의 메시지가 나오면 Tomcat이 정상적으로 작동하는 것입니다. 클라이언트에서 웹브라우저를 통해 다음의 주소로 접속합니다.

http://localhost:8080 또는 http://설치한서버의주소:8080

정상적으로 Tomcat이 작동하고 있다면 브라우저에 Tomcat 관련 문서가 나타날 것입니다.

만일, 정상적으로 작동하지 않는다면 J2SE의 설치가 제대로 이루어지지 않았거나 PATH 설정이 올바르게 이루어지지 않아서입니다. /etc/profile을 에디터로 열어서 J2SE 설치 시 PATH 설정한 부분을 확인해 봅니다.

Tomcat은 bin 디렉토리의 catalina.sh 또는 startup.sh 파일을 실행시켜서 작동시킵니다.

shell> pwd
/usr/local/share/jakarta-tomcat-5.0.16/bin
shell> ./catalina.sh start
또는
shell> ./startup.sh

Tomcat의 Shut down은 catalina.sh 또는 shutdown.sh 파일을 이용합니다.

shell> ./catalina.sh stop
또는
shell> ./shutdown.sh

마지막으로 PATH를 설정해줍니다. PATH 설정은 /etc/profile을 편집하여 이루어집니다. /etc/profile을 에디터로 열어서 J2SE 설치 시 PATH 설정한 부분에 다음을 추가합니다.

shell> vi /etc/profile

JAVA_HOME=/usr/java/j2sdk1.4.2_03
CATALINA_HOME=/usr/local/share/jakarta-tomcat-5.0.16
PATH=$PATH:$JAVA_HOME/bin:$CATALINA_HOME/bin
export JAVA_HOME CATALINA_HOME

변경된 설정을 시스템에 적용시킵니다.

shell> source /etc/profile

PATH를 설정해주었으므로 임의의 위치에서 Tomcat을 실행시킬 수 있습니다.

Tomcat이 현재 운영 중이라면 Shut down을 하고 다시 실행시킵니다.

shell> ps -el
…………………………………………………………………………………………………….

0 S 0 1012 1 0 85 0 - 61602 schedu ? 00:00:12 java

…………………………………………………………………………………………………….

shell> catalina.sh stop
또는
shell> shutdown.sh

shell> catalina.sh start
또는
shell> startup.sh

설치가 완료되었습니다.



7. Tomcat Web Server Connector, JK2를 이용한 Apache2 웹서버와 Tomcat5의 연동

The Apache Jakarta Project 사이트에서 JK2 connector를 다운로드 받습니다. JK2의 binary 배포본은 Solaris와 WIN32용 만이 배포되고 있으므로 소스 형태의 배포본을 다운로드 받아야 합니다. http://jakarta.apache.org/site/sourceindex.cgi 에서 JK 2.0.2 Source Release tar.gz를 다운로드 받습니다.

배포파일 jakarta-tomcat-connectors-jk2-src-current.tar.gz

JK2 connector 소스를 컴파일 하면 얻을 수 있는 것이 mod_jk2.so 모듈입니다. Apache 웹서버와 Tomcat을 연동할 mod_jk2.so 모듈을 얻는 것이 컴파일의 목적입니다.

적당한 위치에서 압축을 풀어줍니다. 소스들을 컴파일하고 필요한 파일들을 이동시키면 더 이상 사용하지 않기 때문에 /usr/local/src에서 압축을 풀어주겠습니다.

shell> mv jakarta-tomcat-connectors-jk2-src-current.tar.gz /usr/local/src
shell> cd /usr/local/src
shell> tar xvfz jakarta-tomcat-connectors-jk2-src-current.tar.gz

압축이 풀리면 해당 디렉토리로 이동합니다. JK2 모듈을 얻기 위해서는 jakarta-tomcat-connectors-jk2-2.0.2-src/jk/native2로 이동합니다.

shell> cd /usr/local/src/jakarta-tomcat-connectors-jk2-2.0.2-src/jk/native2

다음과 같이 configure를 실행하고 make로 컴파일을 합니다.

shell> ./configure --with-apxs2=/usr/sbin/apxs
shell> make

configure 옵션(autoconf 출력옵션) --with-apxs2[=FILE]

Apache 2.0 에서 공유할 DSO 모듈을 build하기 위해 사용합니다. FILE은 Apache apxs tool이 있는 경로를 나타냅니다.

make 시 에러가 발생할 수 있습니다. 이것은 autoconf 실행 중 설정되는 Apache 홈디렉토리가 RedHat에서는 /usr이므로, 컴파일 중에 필요로 하는 libtool 실행파일을 /usr/build/ 경로에서 찾는데 RedHat에서는 /var/www/build/ 경로에 존재하기 때문입니다. 따라서 문제가 발생할 경우에는 /var/www/build 디렉토리를 /usr 디렉토리 밑으로 복사하기 바랍니다.

문제없이 완료되었다면, 현재 디렉토리를 기준으로 ../build/jk2/apache2/의 경로에 mod_jk2.so 파일이 만들어졌을 것입니다. 이 파일을 아파치 모듈이 있는 디렉토리로 복사합니다.

shell> pwd
/usr/local/src/jakarta-tomcat-connectors-jk2-2.0.2-src/jk/native2
shell> cd ../build/jk2/apache2
shell> ls
(mod_jk2.so 파일이 존재하는지 확인합니다.)
shell> cp mod_jk2.so /usr/lib/apache/
(레드햇에서는 아파치 모듈이 /usr/lib/apache 디렉토리에 위치합니다.)

/usr/local/src/jakarta-tomcat-connectors-jk2-2.0.2-src/jk/conf/workers2.properties 파일을 /etc/httpd/conf/ 위치로 복사합니다.

shell> cd /usr/local/src/jakarta-tomcat-connectors-jk2-2.0.2-src/jk/conf
shell> cp workers2.properties /etc/httpd/conf

이 파일은 Apache 웹서버에서 JK2 모듈을 사용할 때 필요한 여러가지 설정을 저장한 파일입니다. 이 파일 이외에 jk2.properties 파일이 중요한데, workers2.properties 파일이 Apache 쪽에서 JK2 모듈의 설정을 담당한다면, jk2.properties 파일은 Tomcat 쪽에서 JK2 모듈을 통한 웹서버와의 연결 설정을 담당합니다. Tomcat 5.0 버전에서는 JK2 connector를 처리할 수 있는 coyote connector가 기본설치 되어 있기 때문에 jk2.properties 파일을 Tomcat의 conf 디렉토리로 복사할 필요는 없습니다.

/etc/httpd/conf/httpd.conf 파일을 vi와 같은 편집기로 열어 LoadModule 부분을 찾아서 다음을 추가합니다.

LoadModule jk2_module lib/apache/mod_jk2.so

DirectoryIndex 부분을 찾아서 index.jsp를 추가합니다.

DirectoryIndex index.html index.html.var index.php index.phtml index.jsp

저장하고 편집기를 끝냅니다.

다음으로 /etc/httpd/conf 디렉토리에 복사해놓은 workers2.properties를 수정합니다. 아래의 설정 내용으로 구성합니다.

shell> cd /etc/httpd/conf
shell> vi worker2.properties

# Shared memory handling. Needs to be set.
[shm]
file=/var/log/httpd/shm.file
size=1048576

# Example socket channel, explicitly set port and host.
[channel.socket:localhost:8009]
port=8009
host=127.0.0.1

# define the worker
[ajp13:localhost:8009]
channel=channel.socket:localhost:8009

# Announce a "status" worker
[status:status]

# Uri mapping
[uri:/jsp-examples/*]
worker=ajp13:localhost:8009

[uri:/servlets-examples/*]
worker=ajp13:localhost:8009

[uri:/tomcat-docs/*]
worker=ajp13:localhost:8009

[uri:/*]
worker=ajp13:localhost:8009

[uri:/status/*]
worker=status:status

(위 설정내용은 포스데이타㈜ BPM 사업추진반 장윤기 대리님이 작성한 <아파치와 톰캣 연동 및 로드 발란싱 구현>에서 발췌하여 수정한 것입니다.)

/usr/local/share/jakarta-tomcat-5.0.16/conf/jk2.properties를 수정합니다.

shell> cd /usr/local/share/jakarta-tomcat-5.0.16/conf
shell> vi jk2.properties

## THIS FILE MAY BE OVERRIDEN AT RUNTIME. MAKE SURE TOMCAT IS STOPED
## WHEN YOU EDIT THE FILE.
## COMMENTS WILL BE _LOST_
## DOCUMENTATION OF THE FORMAT IN JkMain javadoc.
# Set the desired handler list
# handler.list=apr,request,channelJni
#
# Override the default port for the socketChannel
channelSocket.port=8009
# Default:
# channelUnix.file=${jkHome}/work/jk2.socket
# Just to check if the the config is working
# shm.file=${jkHome}/work/jk2.shm
shm.file=/var/log/httpd/jk2.shm
# In order to enable jni use any channelJni directive
# channelJni.disabled = 0
# And one of the following directives:
# apr.jniModeSo=/opt/apache2/modules/mod_jk2.so
# If set to inprocess the mod_jk2 will Register natives itself
# This will enable the starting of the Tomcat from mod_jk2
apr.jniModeSo=inprocess

(위 설정내용은 포스데이타㈜ BPM 사업추진반 장윤기 대리님이 작성한 <아파치와 톰캣 연동 및 로드 발란싱 구현>에서 발췌하여 수정한 것입니다.)

모든 설정이 끝났습니다. 실행시키기 전에 /usr 디렉토리에서 /etc/httpd/conf 디렉토리에 연결된 링크 파일을 만들어줍니다. 이것은 mod_jk2.so 모듈을 컴파일 할 때 Apache Home Directory를 /usr 로 인식했기 때문에 workers2.properties 파일을 /usr/conf에서 찾기 때문입니다. 다음과 같이 실행합니다.

shell> cd /usr
shell> ln -s /etc/httpd/conf ./conf

모든 과정이 끝났으면 Tomcat과 Apache 웹서버를 실행시킵니다. ps 명령어로 현재 실행중인 process 목록을 확인해서 Tomcat과 Apache가 가동중인지 확인하고, 가동중이라면 실행을 중지시킵니다. 참고로 Tomcat의 Process CMD는 java입니다.

shell> ps -el

(프로세스가 존재하는지 확인)

shell> catalina.sh stop

(프로세스가 존재하면 실행중지)

shell> catalina.sh start

shell> /etc/init.d/httpd stop

(Apache 프로세스가 존재하면 실행중지)

shell> /etc/init.d/httpd start

또는 (Apache 프로세스가 존재할 경우)

shell> /etc/init.d/httpd restart

클라이언트에서 http://serverURL 로 연결해 봅니다. Apache Tomcat 웹페이지가 보이면 정상적으로 연동되어 작동하는 것입니다.

jk2.properties의 설정을 변경하였을 경우 이를 적용시키기 위해서는 Tomcat을 재가동 시켜주고 Apache 또한 다시 실행시켜주어야 합니다. workers2.properties의 설정을 변경한 경우에는 Apache 웹서버만 재가동시킵니다.


참고사항

- Apache Tomcat 연동에서 가장 중요한 부분은 자신의 시스템 또는 제공하려는 서비스에 알맞은 설정 파일을 작성하는 것입니다. 이 문서에서는 기본적인 설치만을 다루고 있기 때문에 자세한 사항은 Apache Jakarta 홈페이지를 방문해서 Tomcat 5.0 Document를 참고하기 바랍니다.


- 참고문서

http://jakarta.apache.org/tomcat/tomcat-5.0-doc/index.html Tomcat 5.0 Document

http://www.javamania.pe.kr/index2.html [자바이야기>자료실] 아파치와 톰캣 연동 및 로드 발란싱 구현 (장윤기 님)

2006년 4월 19일 수요일

MySQL 3.23.52 에서 4.0.17로 업그레이드 설치

[출처]. 네이버cafe

*** MySQL 3.23.52 에서 4.0.17로 업그레이드 설치

현재 가동중인 MySQL의 버전업을 통해 속도 향상과 버그 패치를 목적으로 업그레이드 한다.
기존 가동중인 서버와 상관없이 소스를 다운로드한 후 설치와 컴파일 한 후 덮어씌우는 형식으로 업그레이드 과정을 진행한다.

간단히 말하면 기존 버전의 작동은 그대로 두고
새 버전을 설치하여 업그레이드를 진행한다.
따라서 서비스의 중단이 없고 보안패치와 함께 속도향상을 꽤한다.

우선 기존의 자료를 만일을 대비하여 백업해 둔다.
# cp /etc/my.cnf my.cnf.3.23.52
(기존 버전의 옵션 설정파일을 백업해 둔다.)
# tar czvf mysql_data.3.23.52.tar.gz /usr/local/mysql
(기존의 데이터도 함께 백업해둔다.)

dump 명령의 경우 mysql예약어가 있을 수 있으므로 폴더째 백업하는 것이 좋다.

최신 버전의 소스를 다운로드 한다. : mysql-4.0.17.tar.gz (mysql.com에서 소스다운)

서버로 업로드 한 후 압축을 푼다.
# cd /usr/local/src
# tar zxvf ../downloaded_package/mysql-4.0.17.tar.gz

다음의 옵션으로 configure 하고 설치한다.
# cd /usr/local/src/mysql-4.0.17
# ./configure
--prefix=/usr/local/mysql (mysql이 설치될 디렉토리 지정)
--with-charset=euc_kr (문자 집합 지정. 한글 sort를 위해 필요)
# make
# make install
(컴퓨터 사양에 따라 5~20분이 소요된다.)
설치중 프로세스가 죽거나 에러가 발생하면 prefix와 my.cnf 의 위치를 변경하여 다시 설치한다. my.cnf 및 실행스크립트(mysql.server 등)의 설정 충돌에서 발생하는 문제로
자칫하면 기존의 DB가 죽는 수가 있다.


버전 업그레이드가 되면서 변경된 변수 내용을 옵션 설정파일에 적어둔다.
# vi /etc/my.cnf

long_query_time =5
로 수정한다. (4.0에서 변경된 변수명)

또한 쿼리 캐시를 추가하여 적용시킨다. (4.0 이후 버전의 속도패치 - 쿼리를 캐시에 저장하여
속도를 향상시킨다.)
set-variable = query_cache_limit=1M
set-variable = query_cache_size=2M
set-variable = query_cache_type=1

이제 기존 데몬을 재가동한다.
# /usr/local/mysql/bin/mysqladmin --password=’루트 패스워드’ shutdown (프로세스종료)
# /usr/local/mysql/libexec/mysqld -u root & (프로세스가동)

정상적인 작동을 확인한다.
# ps -aux | grep mysqld

버전이 업그레이드 되었는지 확인한다.
# /usr/local/mysql/bin/mysqladmin --version (Distrib 4.0.17을 확인)

기존 테이블들의 권한을 업그레이드 시켜준다.
# /usr/local/mysql/bin/mysql_fix_privilege_tables 루트패스워드

쿼리 캐시가 적용되어 select 문 쿼리와 쿼리 결과의 속도를 확인하는 방법
# /usr/local/mysql/mysql -u root -p DB명
> show variables like ‘query%’ ;
(쿼리 캐시의 변수와 적용 내용을 확인할 수 있다.)
> show status like ‘qcache%’ ;
(쿼리 캐시의 상태를 확인할 수 있다.
1. 캐시에 등록된 쿼리 수
2. 캐시에 추가된 쿼리 수
3. 캐시에 있는 쿼리를 사용한 수
4. 쿼리를 캐시에 저장하지 않는 수
5. 캐시가 남은 공간
6. 쿼리 캐시에서 남은 메모리 블록 (기본=1)
7. 쿼리 캐시가 사용하는 총 블록 수 (기본=1) )

2006년 4월 18일 화요일

PHP 확장모듈을 추가하는 방법

[PHP 확장모듈을 추가하는 방법]

- 작성자 : 김칠봉
- 작성일 : 2003.03.02
- 분 류 : PHP
- 수 준 : 초급
- 내 용 : PHP 확장모듈 mbstring.so을 추가하는 방법(예제)
- 키워드 : PHP, extension, modules, mbstring.so

*주)
이 문서에 대한 최신 내용은 아래 URL에서 확인할 수 있습니다.

http://www.linuxchannel.net/docs/php-ext.txt

---------------------------------------------------------
목차
1. PHP 확장 모듈과 추가하는 방법에 대해서
2. 확장 모듈 만들기
2-1. 기본 모듈의 컴파일 방식
2-2. phpize 를 이용한 컴파일 방식
3. 확장 모듈 로딩하기
3-1. root 권한일 경우
3-2. account 권한일 경우
---------------------------------------------------------


1. PHP 확장 모듈과 추가하는 방법에 대해서

PHP 확장 모듈은 제공 형태에 따라서 크게 두가지로 볼 수 있습니다.

- PHP 소스의 ext 디렉토리에 존재하는 모듈(기본 확장 모듈)
- 사용자 직접 만들거나 기타 다른 확장 모듈

전자의 경우는

# cd php-xxx/ext
# ls
aspell
...
dio
...
mbstring
...

이와 같이 확인할 수 있습니다.
(90개가 넘는 확장 모듈이 있음)

후자는
php-xxx/ext/ext_skel 를 이용하여 사용자가 직접 만든 확장모듈을
의미합니다. oops.org 에서 배포한 korean.so 확장 모듈이 이에
해당됩니다.

우선 웹서버가 이런 PHP 확장 모듈(예: mbstring.so)를 로딩해야 하는데
로딩하는 방법은 크게 두가지 정도가 있습니다.

- 아파치 코어에 PHP를 정적으로 컴파일하는 방법
- shared mbstring.so 모듈을 만드는 방법

전자의 방법은 처음부터 Apache + PHP를 다시 빌드함을 의미하고,
후자의 방법은 PHP 확장모듈을 현재 상태에서 추가하는 방법입니다.

후자의 경우에서 주의할 점이 있는데,
아파치에서는 mod_so.c 모듈이 정적으로 아파치 core 에 컴파일되어
있어야 합니다.

*확인예)

# httpd -l
...
mod_so.c
...

전자의 방법은 생략하고, 후자의 방법에도 서로 다른 방법이
있습니다. 즉,

- 첫번째, 기존 모듈의 컴파일 방식
- 두번째, phpize 를 이용한 컴파일 방식

결과는 동일하지만 두번째 방식은 주로 PHP에서 공식적으로
제공하지 않는 모듈을 추가할때 기존 php.net에서 제공한 PHP 소스
없이 컴파일하는 방법입니다.

mbstring.so 모듈은 PHP에서 제공하기 때문에 첫번째 방식을 사용하면
됩니다.

우선 PHP 확장 모듈을 정적으로 아파치코어에 넣지 않고, PHP의
shard 모듈로 빌드하기 위해서,

--enable-mbstring=shared

이와 같이 'shared'를 붙여줘야 mbstring.so 모듈을 만들수 있습니다.
PHP 4.3 버전은 --with-mbstring=kr,shared
이와 같이 하면 됩니다.(실제로 4.3은 직접 해보질않아서)


2. 확장 모듈 만들기

2-1. 기본 모듈의 컴파일 방식

우선 현재 아파치에서 사용하는 PHP 버전을 알아봅니다.
(phpinfo(), phpversion() 또는 HTTP 응답헤더에도 나옴)

만약 4.2.1 버전을 사용한다면,
php-4.2.1.tar.gz 버전을 받아서 임시 디렉토리에 풉니다.
만약 서로 다른 버전일 경우 잘 안될 경우가 있으므로
가능한 현재 사용하는 같은 버전으로 하는 것이 좋습니다.

# tar zxvf php-4.2.1.tar.gz
# cd php-4.2.1
# ./configure --enable-mbstring=shared
# cd ext/mbstring
# make

이렇게 컴파일하면

php-4.2.1/ext/mbstring/.libs/mbstring.so
or
php-4.2.1/modules/mbstring.so

파일이 만들어집니다.


2-2. phpize 를 이용한 컴파일 방식

이 방법은 앞서 얘기 했듯이 PHP에서 제공하지 않는 확장 모듈을
컴파일할 때, 즉 기존(php.net에서 제공한)의 PHP 소스가 없을
경우에 사용하는 방법입니다.

대부분 이런 모듈은,

# php-xxx/ext/ext_skel --extname=xxx

이와 같이 기본 layout을 만들고 확장 모듈 xxx를 C로 코딩하는
방법을 말합니다.

이에 대한 자세한 내용은,

- http://phpschool.com/classroom/phpext/phpext_1.html

앞의 URL을 방문하기 바랍니다.

*예: xxx 확장모듈)

# ls /usr/local/php/bin (or /usr/bin)
pear pearize php php-config phpextdist phpize phptar
#
# cd xxx
# /usr/local/php/bin/phpize (configure 파일이 만들어짐)
# ./configure \
--with-php-config=/usr/local/php/bin/php-config \
--enable-xxx
# make
# ls module/*.so
xxx.so
#


3. 확장 모듈 로딩하기

3-1. root 권한일 경우

만들어진 PHP 확장 mbstring.so 모듈을 아파치가 로딩하도록

php.ini 파일을 다음과 같이 수정합니다.

예)
-- php.ini ----------------
...
extension_dir = /usr/local/php/modules
...
extension = dba.so
extension = dio.so
extension = oci8.so
extension = mbstring.so ; <-- 추가
...
----------------------------

이렇게 수정했으면 mbstring.so 모듈을

/usr/local/php/modules/mbstring.so

으로 복사해야 합니다.

그리고 아파치를 재가동하고 phpinfo() 등으로
확인해 보세요.


3-2. account 권한일 경우

만약,
자신이 root 권한이 없는 계정 입장이라면,
만들어지 mbstring.so 모듈을 웹서버에 복사하고
php 파일에 직접 로딩하는 방법도 있습니다.

우선 php.ini 설정이 어떻게 되어 있는지 다음과 같이
확인해 봅니다.

PHP 4.2.0 이상이면 ini_get_all() 로도 가능

echo 'enable_dl : ' . ini_get('enable_dl') .'
';
echo 'extension_dir : ' . ini_get('extension_dir');
?>

만약 'enblae_dl : 1(or On)'이 아니면 dl() 함수를 사용하여
사용자가 직접 확장 모듈을 로딩하지 못하므로 1(or On)으로
설정되어 있어야 합니다.

또한 extension_dir 설정은 사용자가 직접 설정하지
못하는 상수 4의 값을 값습니다.
즉 이 설정은 php.ini 또는 httpd.conf 파일에서만
설정가능합니다.

따라서
관리자가 설정한 extension_dir 값을 보고 상대경로로
mbstring.so 모듈을 지정하여 해야 합니다.

만약 extension_dir : ./ 로 출력된다면 dl() 함수를
직접 호출 또는 이 함수를 포함하는 PHP 파일이 그 기준입니다.
(상당히 골치아픈 설정 T.T)

즉 모든 웹서버의 extension_dir 설정값이 모두 다르므로
반드시 확인해서 상대경로로 지정해야 합니다.

따라서 여러 시스템에서 호환성을 고려한다면
extension_dir 의 값을 / 로 거슬러 올라가 / 를 기준으로
mbstring.so 파일이 있는 경로를 지정해주는 것이 좋습니다.

*예)
function get_extdir()
{
$dir[e] = ini_get('extension_dir');
$dir[u] = dirname($_SERVER[PATH_TRANSLATED]).'/'; // script file directory
$dir[ut] = preg_replace(';[^/]+;','..',$dir[u]);

if(preg_match(';^/;',$dir[e])) {
$dir[e] = preg_replace(';[^/]+;','..',$dir[e]);
}
else $dir[e] = '';

return $dir; // array
}

function ext_load($dir, $mod)
{
if(preg_match(';^/;',$mod)) {
if(!$dir[e]) $file = $dir[ut] . $mod;
else $file = $dir[e] . $mod;
} else {
if(!$dir[e]) $file = $mod;
else $file = $dir[e] . $dir[u] . $mod;
}

if(is_file($file)) {
$ext = str_replace('.so','',basename($file));
if(!extension_loaded($ext)) @dl($file);
}

if(!extension_loaded($ext)) {
echo $file.' is not loaded';
}
}

// example
//
$extdir = get_extdir();
ext_load($extdir, '/any/path/to/mbstring.so');
phpinfo();

?>


좀더 자세한 디버깅과 여러 모듈을 한꺼번에 로딩하기를 원한다면
아래의 필자의 허접한 php class 를 사용해 보기 바랍니다.

http://ftp.linuxchannel.net/devel/php_dl/


EOF

유닉스의 표준 편집기 vi의 사용법

유닉스의 표준 편집기 vi의 사용법



vi 에는
  • 명령대기 상태
  • 글자입력 상태
  • 명령줄 상태
  • 가 있다.



    vi를 실행한 직후는 명령대기 상태이다.

    명령대기 상태에서 글자입력 상태로 바꿀려면 i, I, a, A, o, O 중 하나를 누른다.

    명령대기 상태에서 명령줄 상태로 바꾸려면 :, / 중 하나를 누른다.

    글자입력 상태에서 명령대기상태로 바꿀려면 ESC키를 누른다.

    명령줄 상태에서 명령대기상태로 바꿀려면 ESC키, ENTER키 중 하나를 누른다.


    명령대기 상태에서 현재 편집중인 파일을 저장할려면 :을 눌러 명령줄 상태가 되게한 후 w를 입력하고 ENTER키를 누른다.

    명령대기 상태에서 현재 편집중인 파일을 저장하고 vi를 빠져 나갈려면 :을 눌러 명령줄 상태가 되게한 후 wq!를 입력하고 ENTER키를 누른다.

    명령대기 상태에서 현재 편집중인 파일을 저장하지 않고 vi를 빠져 나갈려면 :을 눌러 명령줄 상태가 되게한 후 q!를 입력하고 ENTER키를 누른다.

    명령대기 상태에서 글자 찾기를 할려면 /를 눌러서 명령줄 상태가 되게한 후 찾고자 하는 글을 입력하고 ENTER키를 누른다.




    1. 명령대기 상태

    명령대기 상태에서는 커서의 이동, 빈줄의 추가, 삭제하기, 바꾸기, 메모리 복사붙여 넣기 등을 할 수 있으며, 이 들에 대한 명령 키와 설명은 다음 표에 열거되어 있다.


    커서의 이동
    명령키 설 명
    h
    커서를 한칸 왼쪽으로 이동한다.
    j
    커서를 한줄 아래로 이동한다.
    k
    커서를 한줄 위로 이동한다.
    l
    커서를 한칸 오른쪽으로 이동한다.
    ^
    커서를 현재 줄의 처음으로 이동한다.
    $
    커서를 현재 줄의 끝으로 이동한다.
    숫자G
    커서를 지정한 숫자의 줄로 이동한다.



    글자입력 상태로
    명령키 설 명
    i
    커서가 있는 위치에서 글자입력 상태가 된다.
    a
    커서의 오른쪽에서 글자입력 상태가 된다.
    I
    현재 줄의 왼쪽 끝에서 글자입력 상태가 된다.
    A
    현재 줄의 오른쪽 끝에서 글자입력 상태가 된다.



    빈 줄의 추가
    명령키 설 명
    o
    현재 줄의 아래쪽에 빈 줄이 생기면서 글자 입력상태가 된다.
    O
    현재 줄의 위쪽에 빈 줄이 생기면서 글자 입력상태가 된다.



    삭제하기
    명령키 설 명
    x
    커서가 있는 한 글자를 삭제한다.
    dd
    커서가 있는 한 줄을 삭제한다.
    dw
    커서가 있는 한 단어를 삭제한다.
    D
    현재 줄의 커서가 있는 곳 부터 줄의 끝까지 삭제한다.



    바꾸기
    명령키 설 명
    r
    커서가 있는 한 글자를 바꾼 후 다시 명령대기 상태가 된다.
    cw
    커서가 있는 한 단어를 바꾼 후 다시 명령대기 상태가 된다.



    메모리 복사(yank)와 붙여 넣기(put)
    명령키 설 명
    숫자yy
    커서가 있는 줄부터 지정된 숫자 만큼의 줄을 메모리에 복사한다.
    Y
    커서가 있는 한 줄을 메모리에 복사한다.
    p
    메모리에 복사되어 있는 내용을 커서가 있는 줄부터 붙여 넣는다.




    2. 명령줄 상태

    명령대기 상태에서 :을 누르면 :으로 시작하는 명령줄 상태가 되고, /를 누르면 /로 시작하는 명령줄 상태가 된다.


    :으로 시작하는 명령줄 상태
    입력 설 명
    :w
    현재 편집 중인 내용을 저장한다.
    :w 파일명
    현재 편집 중인 내용을 지정한 파일명으로 저장한다.
    :q
    vi를 빠져 나간다.
    :q!
    저장에 대한 경고 메세지가 나오지 않도록 하고 vi를 빠져 나간다.
    :wq!
    현재 편집 중인 내용을 저장하고 vi를 빠져 나간다.
    :set numbers
    행의 번호가 표시되게 한다.
    :set nonumbers
    행의 번호가 표시되지 않게 한다.



    /로 시작하는 명령줄 상태
    입력 설 명
    /문자열
    커서의 현재 위치부터 지정한 문자열을 찾아 준다.




    제공: 클루컴 (CLUECOM)

    리눅스 및 커널 버전확인방법

    ** 레드헷 리눅스 릴리즈 버전 확인
    # cat /etc/redhat-release

    ** 레드헷 리눅스 커널 버전 확인
    # uname -a

    ** 커널 2.6 으로 업그레이드 하기

    리눅스 커널의 최신 버전인 2.6.10 커널이 최근 리누스 토발즈에 의해 공개됐다. 토발즈가 ‘우지 눔바트(Woozy Numbat)’라고 이름지은 리눅스 2.6.10 커널은 운용체계에 대한 수정 목록을 포함하고 있다. 이번에 발표된 2.6.10 커널에는 몇가지 MMC와 USB 등을 비롯해 ARM 업데이트가 이뤄졌다. 한편 레드햇은 2005년 1분기에 내놓을 엔터프라이즈 리눅스 4에서 2.6으로 넘어갈 계획이지만 엔터프라이즈 에디션에 여전히 초기 커널을 사용하고 있다. 정소영기자@전자신문, syjung@


    ** 참고자료 : http://blog.naver.com/liger33?Redirect=Log&logNo=23167576

    2006년 4월 17일 월요일

    네임서버

    전체적인 네임서버 설정을 구성해보겠습니다.

    DNS(Domain Naming System) 서버

    보통 네임서버라고 하는데 네임서버의 역할은 아이피와 도메인의 다리역할을 한다고보면 됩니다.


    예)
    210.100.20.150 <--네임서버--> sample2.co.kr
    아이피와 도메인을 매핑(mapping) 즉, 연결시켜준다는거죠.

    목적 : IP주소를 별칭(도메인)으로 지정하여서 간편하게 사용

    =>아무래도 아이피를 외우는것보다는 도메인을 외우는게 쉽기때문이죠...


    DNS를 전체적인 세팅 절차를 적어보겠습니다.

    ① 도메인 명을 등록한다.


    ② 네임서버로 사용할 시스템의 /etc/hosts 파일에 등록한 네임 서버의 정보(호스트명과 도메인 어드레스)를 추가한다.

    /etc/hosts


    # Do not remove the following line, or various programs
    # that require network functionality will fail.
    127.0.0.1 localhost.localdomain localhost
    210.100.20.150 ns.sample2.co.kr ns // =>호스트명과 도메인명을 추가했다.


    ③ /etc/resolv.conf 파일에 1차 네임서버로 등록한 네임서버의 정보를 입력한다.

    ==>resolv.conf 는 네임서버를 지정해주는 파일이다.

    가장 기본이되는 네임서버 설정파일입니다.

    /etc/resolv.conf

    search ns.sample2.co.kr
    nameserver 210.100.20.150 // IP주소
    nameserver *.*.*...


    ④ /etc/sysconfig/network 파일에 hostname과 domainname 을 추가한다.

    hostname에는 보통 네임서버의 호스트이름인 ns를 사용하며,
    domainname에는 도메인 이름을 기입한다.

    /etc/sysconfig/network

    NETWORKING = yes
    HOSTNAME = ns
    DOMAINNAME = sample2.co.kr
    GATEWAY = 210.100.20.1

    =>HOSTNAME 과 DOMAINNAME 을 추가해주었습니다.
    =>변경된 내용을 적용하기 위해서 network 데몬을 재시작해줍니다.

    #/etc/rc.d/init.d/network restart

    또는

    #service network restart


    ☞ 여기에서 service 는

    #setup 치고 들어가면

    System Service 목록에 있는것들인데 체크가 되어있는것은 리눅스 부팅과 동시에 실행되는 데몬들이고 체크가 되지않은것은 실행되지 않은 데몬들입니다.

    (이러한 데몬들은 /etc/rc.d/init.d/ 디렉토리에 있습니다.)


    MS 윈도우의 서비스와 같은 개념인데...

    즉, MS 윈도우에서는 서비스라 부르고 리눅스에서는 데몬이라 부르죠...


    ⑤ /etc/named.conf 파일에 forward zone 파일과 reverse zone 파일에대한 정보를 추가한다.

    =>named.conf 는 네임서버 설정파일이다.


    ⑥ /var/named 디렉토리에 forward zone 파일과 reverse zone 파일을 생성한다.

    이때 존 파일은 /etc/named.conf 파일에서 지정한 파일 이름을 사용하여야 합니다.


    ⑦ named 데몬을 재실행하여 변경된 내용을 반영한다.

    #/etc/rc.d/init.d/named restart

    또는

    #service named restart


    ⑧ named 데몬이 살아있는지 확인한다.

    #ps aux | grep named

    named 641 0.0 0.8 29624 1056 ? S 17:52 0:00 [named]
    root 1428 0.0 0.4 3548 528 pts/0 S 20:33 0:00 grep named


    ⑨ nslookup 이나 host 또는 dig명령어를 사용하여 자신의 네임서버가 제대로 동작되는지 확인한다.

    #nslookup sample2.co.kr

    Note: nslookup is deprecated and may be removed from future releases.
    Consider using the `dig' or `host' programs instead. Run nslookup with
    the `-sil[ent]' option to prevent this message from appearing.
    Server: 210.100.20.150
    Address: 210.100.20.150#53

    Name: sample2.co.kr
    Address: 210.100.20.150

    #


    네임서버의 전체전인 설정은 대략 이렇습니다. ^^

    보니가 여러번 해보신 분이니 전체적인 설정을 정리해봤습니다.

    2006년 4월 3일 월요일

    플래시DB걸어보다[1]

    우선 DB내용을 플래시로 불러오는 방법입니다...

    this.init = new LoadVars();
    this.init.load("./DB_query.php");
    this.init.onLoad = function(){
    _global.Link_URL1 = this.init.Link_URL1;

    _global.Link_URL2 = this.init.Link_URL2;

    _global.Link_URL3 = this.init.Link_URL3;
    }

    위와 같은 부분을 추가 하신 후에 DB_query.php 파일을 만드시면 됩니다..

    DB_query.php 의 내용은 아래와 같은 형태로 출력이 되도록 만드시면 됩니다..

    &Link_URL1=링크주소1&

    &Link_URL2=링크주소2&

    &Link_URL3=링크주소3&

    위 내용에서 = 앞뒤에 공백없이 파일경로에 따옴표 없이 출력 되도록 프로그램 하시면 됩니다.

    그렇게 하신 후 링크는

    getURL(_global.Link_URL1);

    getURL(_global.Link_URL2);

    getURL(_global.Link_URL3);

    로 하시면 될 듯 합니다..

    두번째로 랜덤링크는 랜덤함수를 이용 하시면 될듯 하군요...

    예를들면
    Link_URL = new Array("링크1","링크2","링크3","링크4");
    numbers = random(4);
    getURL(Link_URL[numbers]);
    로 작업 하시면 될것 같습니다~