CentOS phpMyAdmin 설치 (yum)

1 개요

리눅스 phpMyAdmin 설치

2 사전 작업


2.1 ===============================================================================
Package                  Arch            Version                   Repository        Size
2.2 ===============================================================================

Installing:

libjpeg-turbo -27.el6_5            updates          1.1 M
php-gd                   x86_64          5.3.3-27.el6_5            updates          107 k
php-mbstring             x86_64          5.3.3-27.el6_5            updates          455 k
php-mcrypt               x86_64          5.3.3-3.el6               epel              19 k
php-mysql                x86_64          5.3.3-27.el6_5            updates           81 k
php-pdo                  x86_64          5.3.3-27.el6_5            updates           75 k
php-php-gettext          noarch          1.0.11-3.el6              epel              21 k

Updating for dependencies:

php-cli                  x86_64          5.3.3-27.el6_5            updates          2.2 M
php-common               x86_64          5.3.3-27.el6_5            updates          525 k

Transaction Summary

2.3 ===============================================================================

Install 11 Package(s) Upgrade 2 Package(s)

Total download size: 9.2 M Is this ok [y/N]: y </source>

... (생략)
Installed:
  libjpeg-turbo.x86_64 0:1.2.1-3.el6_5          phpMyAdmin.noarch 0:3.5.8.2-1.el6         

Dependency Installed:
  libXpm.x86_64 0:3.5.10-2.el6                    libmcrypt.x86_64 0:2.5.8-9.el6           
  php.x86_64 0:5.3.3-27.el6_5                     php-gd.x86_64 0:5.3.3-27.el6_5           
  php-mbstring.x86_64 0:5.3.3-27.el6_5            php-mcrypt.x86_64 0:5.3.3-3.el6          
  php-mysql.x86_64 0:5.3.3-27.el6_5               php-pdo.x86_64 0:5.3.3-27.el6_5          
  php-php-gettext.noarch 0:1.0.11-3.el6          

Dependency Updated:
  php-cli.x86_64 0:5.3.3-27.el6_5            php-common.x86_64 0:5.3.3-27.el6_5           

Replaced:
  libjpeg.x86_64 0:6b-46.el6                                                               

Complete!

3 아파치 reload 및 로컬접속확인

[root@zetawiki ~]# service httpd reload
Reloading httpd:
[root@zetawiki ~]# curl -s -I http://localhost/phpMyAdmin/ | head -3
HTTP/1.1 200 OK
Date: Sat, 14 May 2016 19:26:52 GMT
Server: Apache

4 (Optional) 외부접속 허용 및 확인

  • phpMyAdmin은 보안상 이유로 로컬호스트(127.0.0.1)만 접속 가능하게 제한되어 있다.
  • 외부에서 접속하려면 설정을 변경해야 한다.
[root@zetawiki ~]# cd /etc/httpd/conf.d/
[root@zetawiki conf.d]# grep 127.0.0.1 phpMyAdmin.conf
       Require ip 127.0.0.1
     Allow from 127.0.0.1
       Require ip 127.0.0.1
     Allow from 127.0.0.1
  • 기존 설정을 보존해두고, 접속하고자 하는 곳(아마도 PC)의 IP(예: 135.79.246.80)[1]로 바꿔주자.
[root@zetawiki conf.d]# cp -a phpMyAdmin.conf phpMyAdmin.conf.origin
[root@zetawiki conf.d]# sed -i 's/127.0.0.1/135.79.246.80/g' phpMyAdmin.conf
[root@zetawiki conf.d]# grep 135.79.246.80 phpMyAdmin.conf
       Require ip 135.79.246.80
     Allow from 135.79.246.80
       Require ip 135.79.246.80
     Allow from 135.79.246.80
[root@zetawiki conf.d]# service httpd reload
Reloading httpd:

5 설정파일 생성 및 확인

여기까지 하면 /var/lib/phpMyAdmin/config/config.inc.php 파일이 생성된다.

[root@zetawiki ~]# ll /var/lib/phpMyAdmin/config/config.inc.php
-rw-r--r-- 1 apache apache 757 Aug 31 00:01 /var/lib/phpMyAdmin/config/config.inc.php

그런데 실제로 사용되는 파일은 /etc/phpMyAdmin/config.inc.php 이다[10] 설정파일을 바꿔치기해준다...

[root@zetawiki ~]# mv /etc/phpMyAdmin/config.inc.php /etc/phpMyAdmin/config.inc.php.old
[root@zetawiki ~]# cp /var/lib/phpMyAdmin/config/config.inc.php /etc/phpMyAdmin/config.inc.php

6 최종 확인

로그인이 잘되면 OK
만약 #2002 MySQL 서버에 로그인할 수 없습니다가 나오면 config.inc.php가 제대로 연동되지 않은 것
만약 #1045 MySQL 서버에 로그인할 수 없습니다가 나오면 사용자명 또는 암호가 틀린 것
MySQL ERROR 1045 접근 거부 문서 참고

7 같이 보기

8 주석

  1. IP 대신 'All'을 넣어도 되는데, 누구나 phpMyAdmin 페이지에 접근가능하므로 취약
  2. New server
  3. Add a new server
  4. Server hostname, Server port
  5. localhost 3306 포트라면 입력하지 않아도 됨
  6. Save
  7. Configuration file
  8. Default language
  9. Save
  10. 기존 설정을 날려먹게 될까봐 별도의 위치에 생성하는 듯...
문서 댓글 ({{ doc_comments.length }})
{{ comment.name }} {{ comment.created | snstime }}