GD / ZLIB / PNG / JPEG / FREETYPE 라이브러리 설치

—————————————-

리눅스 시스템에서의 GD 라이브러리 설치법

—————————————-

검색으로 찾아낸 설치법들을 확인한결과… 상당히 번거로운 라이브러리로 보인다.

이것저것 부가적으로 설치해야되는 라이브러리가 4개나 된다.

1. 필요한 라이브러리 좌표

– zlib 다운로드 : http://www.zlib.net

– png 다운로드 : http://www.libpng.org/pub/png/libpng.html

– JPEG 다운로드 : http://www.ijg.org

– freetype 다운로드 : http://download.savannah.gnu.org/releases/freetype/

– GD 다운로드 : http://www.boutell.com/gd/http/gd-2.0.33.tar.gz

※ 첫 설치하면서 함께  포스팅중이다. 최신버전의 라이브러리를 받아서 진행중임!!

※ root 디렉토리에 다운 받음

2. zlib 설치

./configure -shared -prefix=/usr/local/zlib

make

make install

3. png 설치

./configure -prefix=/usr/local/libpng

make

make install

4. jpeg 설치

———————————————-

참고:

설치시 디렉토리 에러가 나는 경우가 있다고 한다.

버전 6b에서 일어나는 에러인 것으로 보인다.

8b를 받아 설치중이며 디렉토리 에러는 나타나지 않았다.

혹여라도 make install 중에 디렉토리 에러메시지가 보인다면 아래처럼 디렉토리를 생성한다.

mkdir -p /usr/man/man1/

———————————————-

./configure -prefix=/usr/local/jpeg -enable-shared -enable-statie

make

make install

5. freetype 설치

./configure -prefix=/usr/local/freetype

make setup

make install

6. GD 설치

./configure -prefix=/usr/local/gd

=================================================================

출력문 일부 참고:

Support for PNG library: yes

Support for JPEG library: yes

Support for Freetype 2.x library: yes // 무료 폰트 렌더링 라이브러리

Support for Fontconfig library: no

Support for Xpm library: no //unix의 이미지 포맷 라이브러리

Support for pthreads: yes

=================================================================

make

———————————————-

참고:

make시 에러가 나는 경우가 있다고 한다.

현재 설치중인 버전은 2.0.33 이다.

2.0.35 버전 설치중에 일어나는 현상인듯하다. 현재 설치버전엔 나타나지 않았다.

에러내용은 아래와 같다.

cd . && /bin/sh /usr/local/src/gd-2.0.35/config/missing –run aclocal-1.9 -I config

aclocal:configure.ac:64: warning: macro `AM_ICONV’ not found in library

cd . && /bin/sh /usr/local/src/gd-2.0.35/config/missing –run automake-1.9 –foreign

cd . && /bin/sh /usr/local/src/gd-2.0.35/config/missing –run autoconf

configure.ac:64: error: possibly undefined macro: AM_ICONV

If this token and others are legitimate, please use m4_pattern_allow.

See the Autoconf documentation.

make: *** [configure] 오류 1

———————————————-

make install
7. 끝으로
php에서 사용하는 분들이 많은 것 같다.
검색으로 나오는 웬만한 설치법들은 끝부분에 php설정도 함께 게시하고 있다.
그래서 나도 적어볼란다. ㅋㅋ
php 컴파일시
./configure 옵션에 아래사항 추가
–with-gd=/usr/local/gd \
–with-jpeg-dir=/usr/local/jpeg \
–with-freetype-dir=/usr/local/freetype \
–with-png-dir=/usr/local/libpng \
–with-zlib-dir=/usr/local/zlib
** 이 블러그 보시고 설치하신 분은 아래처럼
./configure –prefix=/usr/local/php –with-exec-dir=/usr/bin –with-apxs2=/usr/local/apache/bin/apxs –with-apache-install=/usr/local/apache –with-mysql=/usr/local/mysql –with-config-file-path=/etc –disable-debug –enable-track-vars –enable-sockets –with-png-dir=/usr/local/libpng –with-freetype-dir=/usr/local/freetype –with-mod_charset –with-charset=euc_kr –with-xml –with-language=korean –enable-mailparse –enable-calender –enable-sysvsem=yes –enable-sysvshm=yes –enable-ftp –enable-magic-quotes –enable-gd-native-ttf –enable-versioning –enable-url-includes –enable-trans-id –enable-inline-optimization –with-iconv –enable-mbstring –enable-mbregex –with-gd=/usr/local/gd –with-ttf –with-gettext –enable-sigchild –enable-module=so –enable-versioning –enable-url-includes –enable-trans-id –enable-inline-optimization –enable-bcmath –with-jpeg –with-png –with-zlib –with-jpeg-dir=/usr/local/jpeg –with-png-dir=/usr/local/libpng –with-zlib-dir=/usr/local/zlib
 

MYSQL 5.5.9 CMAKE 를 이용한 설치방법

 



1. Mysql5.5.9 소스 파일 다운로드를 합니다.

– 웹페이지에서 다운로드 링크를 복사하여


 #wget http://www.mysql.com/get/Downloads/MySQL-5.5/mysql-5.5.9.tar.gz/from/http://mirror.khlug.org/mysql/


* 필자 서버에서 MySQL 을 다운받는 방법

명령어 :
wget
http://www.lovecoco.net/dataout/userdata/mysql-5.5.9.tar.gz  [다운로드]


2. Mysql 을 서비스할 계정을 생성합니다.(보안을 위해서)


#groupadd mysql
#useradd -g mysql mysql


3. configure 를 진행합니다.


 – 여기서 5.1 때와 5.5.9 가 다른걸 알았는데요…
 ./configure 가 없다는거…5.5.9 부터는 cmake 라는 것을 통해 설치를 진행하게 됩니다.
cmake 를 다운로드 받습니다. ( http://www.cmake.org/ )
압축만 풀면 사용 가능합니다.



그럼 본격적으로 cmake 를 통해 설치 옵션을 부여해서 해볼까요?


#cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_EXTRA_CHARSETS=all -DMYSQL_DATADIR=/usr/local/mysql/data  -DENABLED_LOCAL_INFILE=1 DWITH_INNOBASE_STORAGE_ENGINE=1 .



– 전 오래전부터 EUCKR을 사용하여 왔고 해당 DB의 호환성을 위해
cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DDEFAULT_CHARSET=euckr -DDEFAULT_COLLATION=euckr_korean_ci -DWITH_EXTRA_CHARSETS=all -DMYSQL_DATADIR=/usr/local/mysql/data  -DENABLED_LOCAL_INFILE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.socket


를 사용했습니다이후 make all , make install 을 해줘야 합니다.



( cmake 설치 옵션 메뉴얼 :
http://dev.mysql.com/doc/refman/5.5/en/source-configuration-options.html#cmake-general-options )



이렇게 해서 설치를 하다보면 필요한 라이브러리가 필요하다며 중간에 실패가 떨어지기도 합니다.
그러면 해당 라이브러리를 설치 해주시면 됩니다. 설치방법은~~



#yum -y install zlib curl
#yum -y install gcc g++ cpp gcc-c++
#yum -y install openssl openssl-devel
#yum -y install libtermcap-devel ncurses-devel libc-client-devel bzip2-devel
#yum -y install bison


6. mysql 설치 디렉토리에 대한 mysql 권한 부여
#chown -R mysql:mysql /usr/local/mysql

7. 기본 DB 생성

설치 디렉토리로 이동하여서 실행하여야 합니다.(저는 /usr/local/mysql )
#./scripts/mysql_install_db –user=mysql –datadir=/usr/local/mysql/data



8. mysql 설정 파일 복사

#cp support-files/my-medium.cnf  /etc/my.cnf
또는
#cp support-files/my-medium.cnf my.cnf


저는 /usr/local/mysql 설치 디렉토리에 위치 시켰는데 mysql 를 여러개 설치할 경우에
각 mysql에 대한 설정값을 사용하기 위해 mysql설치디렉토리에 위치 시켰습니다.




다음으로 MySQL 서버와 프로그램을 연결해줄 소켓을 링크파일로 생성하야 한다.
ln -s /var/lib/mysql/mysql.sock /usr/local/mysql/mysql.socket
(여기 블러그 보시고 Apache 와 PHP 설정하실분 해당)


9. 서버 부팅시 mysql 실행을 위한 서비스 등록

#cp support-files/mysql.server /etc/init.d/mysqld
(기존에 mysqld 파일이 있을경우 해당서버에 설치된 mysql 이 있다는 뜻으므로, 이전 설치된 mysql을 사용하지 않을경우 overwite해도 무관)

10. mysql 실행시 생성되는 pid 파일이 /var/run/mysqld 에 생성됩니다.
이것때문에 mysql 이 뜨지 않아 로그파일을 보고 알았습니다.
#mkdir -P /var/run/mysqld  
#chown -R mysql:mysql /var/run/mysqld
(기존 mysql 이 설치되었을 경우 해당 디렉토리가 존재할 가능성이 높음. 존재하면 Step 10은 Skip)

11. 외부에서 mysql 에 대한 접근을 위해 서비스 포트를 오픈해야합니다.( 3306 포트 )
/etc/sysconfig/iptables 파일에
 -A RH-Firewall-1-INPUT -m state –state NEW -m tcp -p tcp –dport 3306 -j ACCEPT
 추가 후
#/etc/rc.d/init.d/iptables restart 로 갱신된 정보를 다시 서비스함.

12. Mysql 실행

#cd /usr/local/mysql/bin
#mysqld_safe –datadir=/usr/local/mysql/data &


이전버젼으로의 호환성을 위해 old-password 를 붙여줌
#/usr/local/mysql/bin/mysqld_safe –user=mysql –language=korean –old-passwords &

13. Mysql Root 비밀번호 생성

#mysqladmin -uroot password 신규비밀번호

14. Mysql 접속

#mysql -uroot -p
Mysql>



15. 재부팅시 자동 실행


마지막으로 부팅시 자동실행을 하도록 만드는 방법은 “/etc/rc.local”파일 재일 마지막 부분에 “/usr/local/mysql/bin/mysqld_safe –user=mysql –language=korean –old-passwords & “

을 추가하도록 한다.

그럼 모든 설치가 끝납니다~ ^^



[Linux를 사용해 보자 #4] PHP / Zend 설치하기

PHP를 다운받고 압축을 해제한후 해당 디렉토리로 이동한다.
PHP 다운 및 압축 해제 [
https://blog.lovecoco.net/116 ]


* PHP 설치하기


PHP 설치 파일이 위치한 곳으로 이동한 후, 다음의 명령어를 이용하여 설치를 위한 준비를 한다.


./configure –prefix=/usr/local/php –with-exec-dir=/usr/bin –with-apxs2=/usr/local/apache/bin/apxs –with-apache-install=/usr/local/apache –with-mysql=/usr/local/mysql –with-config-file-path=/etc –disable-debug –enable-safe-mode –enable-track-vars –enable-sockets –with-png-dir=/usr/lib –with-freetype-dir=/usr/include/freetype2 –with-mod_charset –with-charset=euc_kr –with-xml –with-language=korean –enable-mailparse –enable-calender –enable-sysvsem=yes –enable-sysvshm=yes –enable-ftp –enable-magic-quotes –enable-gd-native-ttf –enable-versioning –enable-url-includes –enable-trans-id –enable-inline-optimization –with-iconv –enable-mbstring –enable-mbregex –with-gd –with-ttf –with-gettext –enable-sigchild –enable-module=so   –enable-versioning –enable-url-includes –enable-trans-id –enable-inline-optimization –enable-bcmath –with-jpeg –with-png –with-zlib


make test 에서 오류나는 경우 safe_mode 가 활성화 되어서 그렇다. 이경우 –enable-safe-mode 를 제외한 옵션


./configure –prefix=/usr/local/php –with-exec-dir=/usr/bin –with-apxs2=/usr/local/apache/bin/apxs –with-apache-install=/usr/local/apache –with-mysql=/usr/local/mysql –with-config-file-path=/etc –disable-debug –enable-track-vars –enable-sockets –with-png-dir=/usr/lib –with-freetype-dir=/usr/include/freetype2 –with-mod_charset –with-charset=euc_kr –with-xml –with-language=korean –enable-mailparse –enable-calender –enable-sysvsem=yes –enable-sysvshm=yes –enable-ftp –enable-magic-quotes –enable-gd-native-ttf –enable-versioning –enable-url-includes –enable-trans-id –enable-inline-optimization –with-iconv –enable-mbstring –enable-mbregex –with-gd –with-ttf –with-gettext –enable-sigchild –enable-module=so   –enable-versioning –enable-url-includes –enable-trans-id –enable-inline-optimization –enable-bcmath –with-jpeg –with-png –with-zlib

으로 Configure 하면 된다.



사용자 삽입 이미지


설정 완료후 컴파일 명령 실행


make all


사용자 삽입 이미지


PHP의 명령어가 정상적으로 실행되는지 여부를 확인하기 위해 TEST를 해줘야 하며, 이때 명령어가 “make test”이다.


make test


사용자 삽입 이미지


일부 Failed가 나오더라도… 일단 설치가 완료되면, 해당 설치 디렉토리로 복사하는 명령어를 실행한다.


make install


사용자 삽입 이미지


이후, PHP의 SO파일(모듈)파일을 Apache 환경설정 파일에 추가한후, PHP 가 동작할 수 있도록 설정을 해야 한다.
이전에 설치한 Apache 의 환경설정 파일을 열어 PHP의 SO 파일이 추가가 되어 있는지 여부를 확인한다.
(PHP 설치시 자동으로 추가된다)


vi /usr/local/apache/conf/httpd.conf


세번째 페이지 뒤에..
“loadModule php5_module  modules/libphp5.so”
줄이 추가되어 있으면 일단 PHP의 SO파일 추가는 되어 있는 것이다.


사용자 삽입 이미지


그리고 12페이지쯤 뒤에… (Line 379줄  – VI에서 명령어 모드(:) 누른후 379를 입력하면 바로 이동) 다음의 내용을 추가한다.


# Apache Setting
# And for PHP 4.x, use:
AddType application/x-httpd-php .php .php3 .inc .ph .htm .html
AddType application/x-httpd-php-source .phps


이 내용은 웹페이지 php, php3, inc, ph, htm, html의 확장자를 PHP가 동작되도록 연결해주는 역할을 한다.


사용자 삽입 이미지


그리고 httpd.conf를 저장한 후 아파치를 재 시작 한다.


/usr/local/apache/bin/apachectl restart


사용자 삽입 이미지


마지막으로 PHP가 정상 동작하는지 여부를 확인하기 위하여,


Apache 의 웹 문서가 있는 /usr/local/apache/htdocs/index.html 파일을 열어 첫줄에 다음의 내용을 추가한다


<?
phpinfo();
?>


사용자 삽입 이미지


마지막으로 웹 브라우져를 열어.. 다음의 페이지가 보이면 설치가 완료된것이다.


사용자 삽입 이미지



# ZendOptimizer 의 설치

명령어 :
wget
http://www.lovecoco.net/dataout/userdata/ZendOptimizer-3.3.3-linux-glibc23-i386.tar.gz 
[다운로드]

압축 해제 및 설치
tar xvfz ZendOptimizer-3.3.3-linux-glibc23-i386.tar.gz 
cd ZendOptimizer-3.3.3-linux-glibc23-i386
./install


라고 입력한다.
나머지는 웬만해서.. Enter 키만 누르면 되는데.. 그래도 설정을 확인해보자.. 입력전에!~!

[Linux를 사용해 보자 #3] MySQL, Apache 설치하기

다음의 S/W를 리눅스 계정으로 다운로드 받는다.


MySQL 5.1.34.rc  (MySQL 5.5.9)
Apache 2.2.17
libmcrypt 2.5.8
PHP 5.3.5
WebDB

* 추가 MySQL을 5.5.9 버전 설치는 : https://blog.lovecoco.net/128 참고 하세요.

* 아래 이미지와 버젼이 조금 다르나, wget 명령어에 나와있는데로 진행하면 에러없이 진행된다.


* MySQL 을 다운받는 방법


명령어 :
wget
http://www.lovecoco.net/dataout/userdata/mysql-5.1.34.tar.gz  [다운로드]


사용자 삽입 이미지
* Apache 를 다운받는 방법


명령어 :
wget
http://www.lovecoco.net/dataout/userdata/http-2.2.17.tar.gz  [다운로드]


사용자 삽입 이미지

* PHP 를 다운받는 방법


명령어 :
wget
http://www.lovecoco.net/dataout/userdata/php-5.3.5.tar.gz   [다운로드]


사용자 삽입 이미지


* WebDB 를 다운받는 방법


명령어 :
wget
http://www.lovecoco.net/dataout/userdata/webdb.tar   [다운로드]


사용자 삽입 이미지




* libmcrypt 를 다운받는 방법


명령어 :
wget
http://www.lovecoco.net/dataout/userdata/libmcrypt-2.5.8.tar.gz   [다운로드]




다운받고 tar로 압축된 파일을 풀어줍니다.


tar xvfz mysql-5.1.34.tar.gz
tar xvfz http-2.2.11.tar.gz
tar xvfz php-5.2.14.tar.gz
tar -xvf webdb.tar


압축을 풀면 다음과 같이 tar파일과 디렉토리가 같이 보입니다.

사용자 삽입 이미지



* MySQL 설치하기


MySQL 설치 파일이 위치한 곳으로 이동한후, 다음의 명령어를 이용하여 설치를 위한 준비를 한다.


./configure –prefix=/usr/local/mysql –with-charset=euckr –with-unix-socket-path=/usr/local/mysql/mysql.socket –with-mysqld-user=mysql


사용자 삽입 이미지


설정 완료 후 컴파일 명령어 실행


make all


사용자 삽입 이미지


다음의 화면이 나오면.. 컴파일이 완료된것이다. 그리고 컴파일 된 파일을 실제 설치할 장소 (/usr/local/mysql)로 이동하는 명령어를 입력한다.


make install


사용자 삽입 이미지


여기까지 완료했다면, 이제 설치는 완료된 것이며,


이제~ MySQL을 실행해야 하는데, 설정시 MySQL은 mysql 유져(–with-mysqld-user=mysql)로 실행하로도록 설정하였기 때문에 mysql 유져가 없다면 다음의 명령어로 유져를 추가해야 한다.


adduser mysql


실행은 설치된 디렉토리 (/usr/local/mysql/)로 이동후, 실행파일이 있는 bin 디렉토리로 이동 한다.


MySQL을 실행하기에 앞서..가장 먼저 데이터베이스의 데이터 파일을 처음 만들어야 하며, 다음의 명령어를 이용하여 만들 수 있다.


./mysql_install_db


이후, MySQL의 데이터가 만들어진 데이터 디렉토리는 현제 root의 권한으로 설정되어 있다.
mysql_install_db를 실행할 때, root의 권한으로 실행했기 때문이다. (정확하게는 mysql 계정으로 실행해야 한다.)
따라서 MySQL의 데이터가 위치한 디렉토리 (/var/lib/mysql)의 권한을 mysql 사용자로 다음의 명령어를 이용하여 변경해야 한다.


chown -R mysql:mysql /var/lib/mysql


다음으로 MySQL이 실행되면 실행정보를 담고 있는 파일이 저장될 디렉토리 (/var/run/mysqld)를 만들고 권한을 mysql로 변경해야 한다.


mkdir /var/run/mysqld
chown -R mysql:mysql /var/run/mysqld


다음으로 MySQL 서버와 프로그램을 연결해줄 소켓을 링크파일로 생성하야 한다.


ln -s /var/lib/mysql/mysql.sock /usr/local/mysql/mysql.socket


이제 MySQL 서버를 실행해야 하며, 다음의 명령어로 실행한다.
/usr/local/mysql/bin/mysqld_safe –user=mysql –language=korean –old-passwords &


이후, MySQL의 root 계정의 암호를 초기화 해야 하며, 다음의 명령어로 초기화 한다.
/usr/local/mysql/bin/mysqladmin -u root password ‘암호’
/usr/local/mysql/bin/mysqladmin -u root -p -h localhost.localdomain passowrd ‘암호’


마지막 명령어는 “Enter Passowrd:” 나오며 암호를 입력 요청을 하는데, 이때, 좀전에 설정한 암호를 입력하면 된다.
위의 ‘암호’에 설정하고자 하는 암호를 입력하면 되며, 암호를 잊을 경우 MySQL의 정상적인 운영이 불가능하므로 꼭 기억을 하도록 한다.


사용자 삽입 이미지


정상적인 접속이 되는지를 확인하는 방법은


/usr/local/mysql/bin/mysql -u root -p


라고 입력하면 다음의 화면이 나오면 정상적으로 실행되는 것이다.


사용자 삽입 이미지


마지막으로 부팅시 자동실행을 하도록 만드는 방법은 “/etc/rc.local”파일 재일 마지막 부분에 “/usr/local/mysql/bin/mysqld_safe –user=mysql –language=korean –old-passwords & “을 추가하도록 한다. [이미지는 조금 다름]


vi /etc/rc.local


사용자 삽입 이미지


이것으로 MySQL은 모두 설치가 완료 되었다.



* Apache 설치 방법


Apache(HTTPD) 설치 파일이 위치한 곳으로 이동한후, 다음의 명령어를 이용하여 설치를 위한 준비를 한다.


./configure –prefix=/usr/local/apache –enable-mods-shared=most –enable-modules=so –with-mpm=worker –enable-rewrite –enable-ssl –with-ssl


사용자 삽입 이미지


설정 완료 후 컴파일 명령어 실행


make all


사용자 삽입 이미지


다음의 화면이 나오면.. 컴파일이 완료된것이다. 그리고 컴파일 된 파일을 실제 설치할 장소 (/usr/local/apache)로 이동하는 명령어를 입력한다.


make install


사용자 삽입 이미지


여기까지 완료했다면, 이제 설치는 완료된 것이며, Apache의 설치디렉토리 (/usr/local/apache)의 bin 디렉토리로 이동하여 apachectl 명령어를 이용하여 apache 를 실행한다.


/usr/local/apache/bin/apachectl start


사용자 삽입 이미지 


확인하는 방법으로는 인터넷 익스플로러로 리눅스의 IP로.. 웹페이지가 뜨는지 확인하면 된다.


이제 마지막으로 부팅시 자동실행을 위하여 “/etc/rc.local”파일 제일 마지막 부분에 “/usr/local/apache/bin/apachectl start” 항목을 추가하면 된다.

vi /etc/rc.local

사용자 삽입 이미지



[Linux를 사용해 보자 #2] ProFtpd 설치 방법

우선 FTP를 설치하기 위해서는 “root” 계정이 필요합니다. 이유는 소스를 직접 컴파일해서 실행파일로 만들어야 하기 때문입니다.
따라서 “su -” 명령어를 이용하여 사용자 계정에서 “root” 계정으로 로그인 합니다.


사용자 삽입 이미지\"사용자


root 계정으로 로그인하였다면, FTP를 설치하기 위해 FTP 서버 프로그램을 다운로드 받아야 합니다.
FTP서버로는 아직까지 많은 사용자를 확보하고 있으며 사용과 설정이 간편한 “ProFTPd”를 이용합니다.
직접 인터넷으로 접속하여 다운로드 받을 수 있으며 wget 명령어를 이용합니다.


wget http://www.lovecoco.net/dataout/userdata/proftpd-1.3.3d.tar.gz  [다운로드]


사용자 삽입 이미지


다운로드 받은후 “ls” 명령어로 확인하면 “proftpd-1.3.3a.tar.gz” 파일이 다운로드 된것을 확인할 수 있다.
.gz 파일은 zip으로 압축되어 있다는 뜻이며, 압축을 해제하기 위해서는 “gzip” 명령에를 사용하고 압축을 해제하는 “-d” 옵션을 사용한다.


gzip -d proftpd-1.3.3a.tar.gz

사용자 삽입 이미지

압축 해제후 “ls” 명령어로 확인하면 “proftpd-1.3.3a.tar.gz” -> “proftpd-1.3.3a.tar” 로 변경된 것을 확인할 수 있다.
다음은 “tar”로 묶은 파일을 풀어야 한다.
“tar” 명령에서 묶은 파일을 푸는 명령어는 “tar”에 옵션 “-xvf”를 사용한다.


tar -xvf proftpd-1.3.3a.tar


사용자 삽입 이미지


위의 명령어를 입력하면 파일이 쭈욱 풀리는 것을 볼수 있으며 “ls -al” 명령어로 확인하면, 파란색의 폴더 “proftpd-1.3.3a”가 생성된것을 확인할 수 있다.


해당 디렉토리로 이동한다.


cd proftpd-1.3.3a


사용자 삽입 이미지


이동후 ProFtpd의 설치를 위해 컴파일 준비를 한다. 컴파일은 “configure” 명령어를 일반적으로 이용하며, 옵션으로는 “–prefix”를 사용하여 설치하고자 하는 곳의 위치를 설정해준다.


./configure –prefix=/usr/local/proftpd


명령어를 입력한다.


사용자 삽입 이미지

명령어를 입력하면 여려 옵션을 스스로 체크하는 화면이 쭈욱 올라간다. 별도의 오류가 없이 종료되면, 위의 화면과 같이 나온다. 이제 실제 실행파일을 만드는 명령어를 입력한다.


make all


사용자 삽입 이미지

명령어를 입력하면 컴파일되는 화면이 쭈욱~~~ 지나가며 약 몇분후 종료 되면, 위의 화면처럼 나왔다면 실행파일을 만드는데 성공한것이다.


다음로는 실행파일을 실제 설정한 디렉토리로 설치하는 과정이 남았다. 설치하는 명령어는 다음과 같다.


make install


사용자 삽입 이미지

명령어를 입력하면 실제 복사되는 화면이 나오며, 위와 같은 화면이 나오면 모든 설치가 완료 된것이다.


이제 남은 일은 Proftpd의 설정파일을 확인하여 익명접속 (누구나 FTP에 접속할 수 있는 권한)을 빼고 인증된 사용자만 접속가능하도록 수정하는 일과 함께 FTP의 실행권한을 설정하는 일이 남았다.
Proftpd의 설정파일은 위와 같이 설치했을 경우 “/usr/local/proftpd/etc/proftpd.conf”에 있으며 해당 파일을 편집해야 한다.
편집은 vi 편집기를 이용하여 편집한다.


vi /usr/local/proftpd/etc/proftpd.conf


사용자 삽입 이미지


위의 명령어를 입력하면, 위의 화면이 나오는데, 29번째 줄과 30번째 줄을 다음과 같이 변경해야 한다.


user              ftp
Group             ftp


또한 다음 페이지의 (Ctrl+F) 항목중..


<Anonymous ~ftp>
  user          ftp
  Group         ftp
  .
  .
  .
  .
</Anonymous>


부분을 아래의 그림처럼 모두 주석처리 한다.

사용자 삽입 이미지


#<Anonymous ~ftp>
#  user          ftp
#  Group         ftp
#  .
#  .
#  .
#  .
#</Anonymous>


vi의 파일을 저장하고 종료한다. (vi 사용법은 꼭 인터넷등을 통하여 습득해둘것!)


proftpd의 실행파일이 있는 위치로 이동한다.


cd /usr/local/proftpd/sbin


사용자 삽입 이미지


이동후 “ls -al” 명령어를 확인하면 3개의 명령어가 보이는데 이중 “proftpd” FTP의 실행파일이다.
다음과 같이 실행한다.


./proftpd &


실행후 “ps -aux | grep ftp”로 확인하면 proftpd 가 첫번째 행에 실행중인것을 알수 있다.


사용자 삽입 이미지


이제 제대로 접속된는지 확인해야 한다.


우선 현재 Linux의 IP를 확인해야하는데 IP 확인은 “ifconfig -a” 명령어를 통하여 확인할 수 있다.


사용자 삽입 이미지


위의 그림처럼 eth0 부분 2번째 줄, “inet addr : 192.168.41.130” 에서 192.168.41.130 이 IP 주소가 된다.
이제 본인의 컴퓨터 (윈도우)에서 시작 실행 “ftp IP주소”를 입력해야 하는데 현재 Linux의 IP는 ifconfig 명령어 실행결과 “192.168.41.130”이므로 “ftp 192.168.41.130″와 같이 입력하면 FTP에 접속되었다는 메시지와 함께 사용자 아이디를 묻는 화면이 뜬다.


사용자 삽입 이미지


위의 그림처럼 본인의 사용자 ID와 암호를 입력하면 “220 User coco logged in” 이라는 행이 정상적으로 출력되면 FTP의 설정은 완료 된것이다.


이제 마지막으로 리눅스 부팅시 자동으로 실행되도록 하기 위해서는 “/etc/rd.local” 파일에 실행파일을 추가등록만 해주면 된다.


vi /etc/rc.local


위의 명령어를 입력한후 제일 마지막 줄에


/usr/local/proftpd/sbin/proftpd &


을 추가해주면 모두 완료 된다.


사용자 삽입 이미지




 

[Linux를 사용해 보자 #1] Linux 를 VmWare에 설치하기

일단 VmWare WorkStation 6.02버젼을 설치후 다음을 진행한다.

준비물 : RedHat Fedora Core 7 (DVD버젼) ISO파일 (이미지파일)


VMWare에서.. 가상 시스템 설정 방법


1. VMWare Workstation 설치후, “File” – “NEW” – “Virtual Machine” 선택
2. “Welcome to the New Virtual Mcahine Wizard” 에서 “다음”
3. “Select the Appropriate Configuration” 에서 “Typical” 선택
4. “Select a Guest Operation System”에서 Linux 선택, Version 은 “Red Hat Linux” 선택
5. “Name the Virtual Machine”에서 이름과 경로는 적당한 곳을 지정 – 실습실의 경우 하드보안관으로 인하여 C드라이버에 저장시 컴퓨터 재부팅시 삭제되므로 D드라어버에 설치.
6. “Network Type”에서 “Use Network address translation(NAT)” 선택
7. “Specify Disk Capacity” 에서 크기는 적당히 지정 . (기본값 사용 무관)
8. 만들어진 가상머신에서 “Edit virtual machine setting” 항목 선택
9. CD-ROM 항목 선택후 “Connection” 항목에서 “USE ISO image” 선택후 다운로드 받은 RedHat Fedora Core 7 파일 지정
사용자 삽입 이미지
10. “Start this virtual machine” 선택하여 부팅


Linux 인스톨 하기.


1. 부팅화면에서 “Install or uprade an existing system”선택 하여 설치 시작
사용자 삽입 이미지
2. CD를 찾았다고 하며 “Choose Skip to skip the media test and start the installation” 에서 “Skip”선택
사용자 삽입 이미지
3. 언어선택에서 “Koream(한국어)” 선택
사용자 삽입 이미지
4. 키보드 타입은 “U.S 영어” 선택   
사용자 삽입 이미지
5. 첫 설치일 경우 sda 드라이버를 초기화 할것이냐고 묻는데 “예”를 선택
6. 하드디스크 설치시 파티션 설정에 대한 항목이 나오는데, 처음 설치일 경우 “Remove all partitions on selected drivers and create default latout”을 선택한다.
   * 차후 고급설치시 파티션을 사용자가 스스로 설치 할 수 있어야 한다^^
사용자 삽입 이미지
7. 파티션 초기화시 하드디스크의 모든 내용이 삭제된다는 경고문이 발생. 계속진행~
8. “메모리 부족” 메시지와 함께 스왑 파티션을 사용할 것이냐는 질문에 “예-스왑파티션 사용”
9. 네트웍 설치는 차후 설정 할 수 있으니 일단 NEXT (설정해도 무관)
10. 시간 설정에서는 “아시아/서울”로 선택후 NEXT
사용자 삽입 이미지
11. 암호 설정이 나오는데 “root” 아이디의 암호를 설정하는 것이다. 설정하도록 하고, 차후 분실시는 초기화하기 무척 어려우므로(거의 재설치가 편함) 잊지 않도록 한다
사용자 삽입 이미지
12. 소프트웨어의 지원에 대해서 묻는데, 웹서버를 직접 다운로드 받아 필요한 것만 설치할 예정이므로 “소프트웨어 갤발”, “웹 서버”에만 체크하고 다음
사용자 삽입 이미지
13. 이후~ 포맷부터 패키지까지 주욱~~~ 설치한다 (대략 소요시간 20~40분)
14. 완료 후 재부팅

* Fedora 부팅 후 설치
1. 재부팅 후 환영합니다 ^^ 메뉴에서 “앞으로” 클릭, License 동의 ^^ 후 앞으로
사용자 삽입 이미지
2. 방화벽 설치에서 FTP, SSH, WWW(HTTP)의 항목을 Open 하고 다음을 선택하면 경고메시지가 나오는데 가볍게 “Yes”를 클릭
   (사용하고자 하는 포트를 Open하면 되고, 설치 후에도 설정변경 가능)
사용자 삽입 이미지
3. SELinux는 강화된 Linux 보안 프로그램인데, 이것을 “강제”로 할경우 이후 PHP등의 설치에 문제가 될수 있다. 따라서 “비화성화”로 선택후 다음을 클릭하면 경고 메시지 나오는데 그냥 가볍게 “Yes”클릭
사용자 삽입 이미지
4. 날짜 및 시간을 조절하고 다음~을 클릭^^
5. Hardware Profile을 보낼것이냐고 묻는데 초기값 그냥 두고 다음
사용자 삽입 이미지
6. 사용자 생성 메뉴에서 이전에 입력한 root의 암호가 아닌 다른 사용자를 하나 더 추가. ^^ “root”는 모든 권한을 갖는 시스템 관리자이며, 이 것이 아닌 다른 사용자를 ID와 암호를 맞게 조절하여 추가하면 됨.
  사용자 아이디는 개인아이디와 암호임!!~
사용자 삽입 이미지
7. 사운드 카드설정은 별다른 조정을 할 필요없음^^.. “완료” 클릭
사용자 삽입 이미지
8. 마지막으로 재부팅되면 모든 설치가 완료
9. 재부팅 후 사용자 ID를 입력 (좀전에 추가로 만든 개인 아이디)
사용자 삽입 이미지
10. 사용자 암호를 입력.
사용자 삽입 이미지
11 그럼~~~ 다음의 화면이 나오면 설치는 일단 완료!
사용자 삽입 이미지


* VMWare에서 Linux 를 설치했을 경우에만 다음 사항을 진행합니다.
1. VMWare 메뉴 “VM” – “Install VMWare Tools”를 선택후 확인!
사용자 삽입 이미지
2. 두개의 파일중 확장자가 RPM인것을 클릭.
사용자 삽입 이미지
3. root의 암호를 입력하라고 하는데, 이때 초기에 Linux 설치전에 입력했던 암호를 입력~!
사용자 삽입 이미지
4, 다음과 같은 화면에서 패키지가 설치됨
사용자 삽입 이미지
5. 검증되지 않았다는 메시지가 나오는데 “무조건 설치”를 누름
사용자 삽입 이미지

6. 설치 완료
사용자 삽입 이미지

Linux BackUp Scrpit ~~~

Linux 백업 스크립트~

난 아래 내용의 파일을 ~~ /etc/cron.weekly 에 복사해서 실행 권한을 주고~ 일주일에 한번식 실행하도록 한다.


[#M_펼치기|접기|#!/bin/sh

echo “## ect Backup ##”
tar -czf ~backup/backup/etc.tar.gz /etc/


# Mysql Backup
echo “## Mysql Backup ##”
/usr/local/mysql/bin/mysqldump –all-databases -uroot -pROOT암호 > ~backup/backup/mysql_backup_all.sql
killall mysqld
tar -czf ~backup/backup/mysql.tar.gz /var/lib/mysql/
/usr/local/mysql/bin/mysqld_safe –user=mysql –language=korean –old-passwords &


# Named ZONE Backup
echo “## Nmaed ZONE Backup ##”
tar -czf ~backup/backup/named.tar.gz /var/named/


# HTML Backup
echo “## HTML Backup ##”
tar -czf ~backup/backup/var_html.tar.gz /var/www/html/


# 디렉토리 설정하실때 끝에 꼭 / 넣어주세요.
# home_root 는 사용자 계정이 있는 디렉토리
# backup_home_root 는 백업된 파일이 저장될 위치이다.
home_root=”/home/”
backup_home_root=”/home/backup/backup/”


cd $home_root


echo “백업 중입니다”
for home_name in $(ls)
do
if [ -d “$home_root/$home_name” ] ; then
echo “tar -cvzf $backup_home_root$home_name.tar.gz $home_name”
tar -czf “$backup_home_root$home_name.tar.gz” “$home_name”
fi
done

_M#]



 

APACHE의 Virtual Host 셋팅

설정파일 위치 : /usr/local/apache/conf/extra/httpd-vhosts.conf


[#M_더보기(펼치기)|닫기|


# machine you can setup VirtualHost containers for them. Most configurations
# use only name-based virtual hosts so the server doesn’t need to worry about
# IP addresses. This is indicated by the asterisks in the directives below.
#
# Please see the documentation at
# <URL:http://httpd.apache.org/docs/2.2/vhosts/>
# for further details before you try to setup virtual hosts.
#
# You may use the command line option ‘-S’ to verify your virtual host
# configuration.


#
# Use name-based virtual hosting.
#
NameVirtualHost 210.119.104.85


#
# VirtualHost example:
# Almost any Apache directive may go into a VirtualHost container.
# The first VirtualHost section is used for all requests that do not
# match a ServerName or ServerAlias in any <VirtualHost> block.
#
<VirtualHost 210.119.104.85>
    ServerAdmin
root@localhost
    DocumentRoot /home/coco/html
    ServerName neococo.net
    ServerAlias
www.neococo.net
    ErrorLog logs/error_log
    CustomLog logs/access_log combined env=!not_log
</VirtualHost>
<VirtualHost 210.119.104.85>
    ServerName
www.lovecoco.net
    ServerAlias lovecoco.net
    #ResinConfigServer 127.0.0.1 6802
    DocumentRoot /home/html01/html
    ErrorLog logs/error_log
    CustomLog logs/access_log combined env=!not_log
</VirtualHost>
<VirtualHost 210.119.104.85>
    ServerAdmin
blog@localhost
    DocumentRoot /home/blog/html
    ServerName blog.lovecoco.net
    ServerAlias blog.neococo.net
    ErrorLog logs/user-blog-error_log
    CustomLog logs/user-blog-access_log combined env=!not_log
</VirtualHost>
<VirtualHost 210.119.104.85>
    ServerAdmin
root@localhost
    DocumentRoot /home/gate/html
    ServerName www01.clubgate.co.kr
    ErrorLog logs/user-clubgate-error_log
    CustomLog logs/user-clubgate-access_log combined env=!not_log
</VirtualHost>
<VirtualHost 210.119.104.85>
    ServerAdmin
root@localhost
    DocumentRoot /home/gate01/html/webdisk
    ServerName webhard.clubgate.co.kr
    ErrorLog logs/user-clubgate-error_log
    CustomLog logs/user-clubgate-access_log combined env=!not_log
</VirtualHost>

_M#]

BIND 셋팅

* /etc/named.conf 설정


[#M_ more.. | less.. |/ named.caching-nameserver.conf
//
// Provided by Red Hat caching-nameserver package to configure the
// ISC BIND named(8) DNS server as a caching only nameserver
// (as a localhost DNS resolver only).
//
// See /usr/share/doc/bind*/sample/ for example named configuration files.
//
// DO NOT EDIT THIS FILE – use system-config-bind or an editor
// to create named.conf – edits to this file will be lost on
// caching-nameserver package upgrade.
//

options {
        listen-on port 53 { 127.0.0.1; };
        listen-on port 53 { xxx.xxx.xxx.xxx; };
        listen-on-v6 port 53 { ::1; };
        directory       “/var/named”;
        dump-file       “/var/named/data/cache_dump.db”;
        statistics-file “/var/named/data/named_stats.txt”;
        memstatistics-file “/var/named/data/named_mem_stats.txt”;
        query-source port 53;
        query-source-v6 port 53;
        allow-query     { any; };
        allow-transfer  { xxx.xxx.xxx.xxx; };
        recursion yes;
};


logging {
        channel default_debug {
                file “data/named.run”;
                severity dynamic;
        };
};


zone “.” IN {
        type hint;
        file “named.ca”;
};


include “/etc/named.rfc1912.zones”;

_M#]



##################################################################
/etc/named.rfc1912.zones 설정
##################################################################


[#M_ more.. | less.. |// named.rfc1912.zones:
//
// Provided by Red Hat caching-nameserver package
//
// ISC BIND named zone configuration for zones recommended by
// RFC 1912 section 4.1 : localhost TLDs and address zones
// and http://www.ietf.org/internet-drafts/draft-ietf-dnsop-default-local-zones-02.txt
// (c)2007 R W Franks
//
// See /usr/share/doc/bind*/sample/ for example named configuration files.
//

zone “.” IN {
        type hint;
        file “named.ca”;
};


zone “localdomain” IN {
        type master;
        file “localdomain.zone”;
        allow-update { none; };
};


zone “localhost” IN {
        type master;
        file “localhost.zone”;
        allow-update { none; };
};


zone “0.0.127.in-addr.arpa” IN {
        type master;
        file “named.local”;
        allow-update { none; };
};


zone “0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.ip6.arpa” IN {
        type master;
        file “named.ip6.local”;
        allow-update { none; };
};
zone “255.in-addr.arpa” IN {
        type master;
        file “named.broadcast”;
        allow-update { none; };
};


zone “0.in-addr.arpa” IN {
        type master;
        file “named.zero”;
        allow-update { none; };
};
zone “lovecoco.net” IN {
        type master;
        file “zone-lovecoco.net”;
        allow-update { none; };
};



_M#]



##################################################################
/var/named/chroot/var/named/zone-lovecoco.net 설정
##################################################################


[#M_ more.. | less.. |$TTL 360
@       IN      SOA     ns1.lovecoco.net. root.lovecoco.net. (
                                 2008070904  ;Serial
                                 21600       ;Refresh ( 6 hours)
                                 1800        ;Retry   (30 minutes)
                                 1209600     ;Expire  (14 days)
                                 360)          ;Minimum ( 0 Seconed)
                    IN    A      xxx.xxx.xxx.xxx
                    IN    NS     ns1.lovecoco.net.
;ns1.lovecoco.net.    IN   NS     ns1.lovecoco.net.
                    IN    MX  0  mail
mail                IN    A  xxx.xxx.xxx.xxx

; Host addresses
ns1                 IN    A      xxx.xxx.xxx.xxx
ftp                 IN    A      xxx.xxx.xxx.xxx
www01   IN    CNAME 
www.lovecoco.net.
www                 IN    A      xxx.xxx.xxx.xxx

_M#]

Fedora 7 이상 버젼을 DVD 없이 CD로만 설치하는 방법

DVD는 2.5G가 넘지만.. CD한장 100메가도 안되는 용량만 가지고 설치할수 있다. 이때 당연히 그 외의 파일은 인터넷에서 가져온다~ 즉 인터넷이 연결되야 한다^^

우선 다음의 주소에서 “
F-7-i386-rescuecd.iso” 이 파일을 받아 CD로 굽는다.
http://ftp.kaist.ac.kr/pub/fedora/linux/releases/7/Fedora/i386/iso/

구운  CD를 넣고 부팅한후,

“Install or upgrade an existing system”선택
사용자 삽입 이미지

그리고 그 후에는 적당히 넘어간다.
한국어 선택후.. 적당이 넘어가다가

Installation Method 항목에서 “FTP”를 선택한다.

사용자 삽입 이미지
이후 자신의 네트웍 환경에 맞게 셋팅한다.
나는 고정아이피에 IPV4를 사용하기 때문에 다음과 같이 했당.

사용자 삽입 이미지
이후 내 PC에 IP와 게이트웨이, 도메인 서버등을 설정해준다.

(IP는 보안상 이유로 블럭처리)
이렇게 인터넷이 가능하게끔 네트웍을 설정해주고
사용자 삽입 이미지
이후 FTP주소와 폴더를 입력하라고 하는데..
FTP Site name  : ftp.kaist.ac.kr
Fedora Directory : pub/fedora/linux/releases/7/Fedora/i386/os/

사용자 삽입 이미지

다음 넘어가면 CD 찾았다고 하는데;
CD는 SKIP 하고 ~~~ 넘어간다.

그다음은 평소 설치대로 설치하면 된다.
설치하다보면 “설치를 준비중입니다. 이 단계는 수분에서 수십분이 걸릴 수 있습니다” 라는 메세지가 나오는데;;; 거의 1-2시간 걸린답;; –^

인터넷에서 다운받아 설치해서 그런지 속도는 DVD로 할때보다 훨씬 더 걸리지만 (3시간?).. DVD가 없는 사람한테는 어째튼  편리하다.
DVD 드라이버를 떼서 연결했다 설치하고 다시 떼서 원래데로 붙여놓는 그 노력보다.. 는 간단하기 때문이다.