japanese site
온라인강좌책메일다운로드동아리쇼핑기술지원기업정보갤러리동영상 블로그
『신개념 4단계 리눅스기술지원 시스템 공개』

※ 『무료 리눅스 배포판 배송서비스』 ※

※ 게시판 용도에 맞지 않는 글(광고및 홍보 글 등)은 임의삭제될 수 있습니다.

 
작성일 : 08-07-05 14:26
PHP와 MySQL의 연계성과 조화, 편리성
 글쓴이 : 김흥수
조회 : 1,529  

게시판 작업과 CGI 작업의 구현을 해주는 PHP 프로그래밍은 SQL 과의 연계성으로 그 사용 능력이 확장됩니다.

 

PHP는 프로그래밍 언어와는 약간 차이가 있지만, PHP 자체적인 웹상의 프로그램을 구현해 낼 수 있습니다.

 

PHP는 사용자의 편의를 극대화 시켜 둔 툴이라고 생각하면 이해하기 쉽습니다.

 

이 글을 통해서 PHP에 대한 개념과 PHP와 MySQL의 연계성, PHP와 MySQL의 조화, PHP와 MySQL의 편리성에 대해서 설명드리겠습니다.

 

 

PHP란 무엇인가

 

우리가 WebSite를 돌아다니다 보면 흔히 보는 것 중 하나가 바로 게시판입니다.

 

이용자로부터 글을 입력받을 수 있게끔 장치가 되어 있는 것이지요.

 

Web문서인 html만으로는 사실 인터넷의 최대의 장점, 상호커뮤니케이션에 한계가 있습니다.

 

물론 hypertext를 이용하여 단순한 클릭만으로도 원하는 곳으로 이동할 수는 있지만 좀더 복잡한, 이를테면 위에 예를 든 게시판 같은 것은 hypertext만으로는 결코 성취하는 것이 불가능하지요.

 

그리하여 나온 것이 CGI라는 것입니다.

 

CGI는 Common Gateway InterfaCe의 약자로 프로그램 자체를 의미하는 건 아닙니다.

 

단순히 말하자면 프로그램을 돌려서 IE 같은 브라우져로 값을 전달하는 것을 말한다고 생각하시면 됩니다.

 

PHP는 이 CGI를 구현하기 위한 하나의 도구랍니다.

 

PHP 말고라도 ASP나 Perl 같은 CGI 스크립트, C, JAVA 같은 프로그램으로도 CGI를 구현할 수는 있습니다.

 

즉 PHP란 CGI를 구현하기 위한 수많은 프로그램 중 한 가지라고 할 수 있습니다.

 

 

 

PHP의 역사

 

PHP(당시는 Personal Home Page의 약자)는 처음 Rasmus Lerdorf가 고안했습니다.

 

PHP는 원래 간단한 몇 가지 Perl 스크립트로 만들어진 것이었는데, Rasmus Lerdorf는 이것으로 홈페이지에 오는 사용자의 자취를 추적하는 데 사용했습니다.

 

그러다가 이것이 스크립트 엔진으로 발전했고, 여기에 각종 폼 기능이 추가돼 PHP/FI가 됐습니다.

 

PHP가 점점 인기를 얻어감에 따라 개발자들이 여기서 사용할 API를 만들었고 이렇게 해서 PHP3가 탄생하게 된 것입니다.

 

현재는 PHP3에서 몇 가지 기능이 더 개선되고 스크립트 해석기가 완전히 새로 제작돼 훨씬 빨라진 PHP4(Zend)가 출시되었습니다.

 

그리고 현재의 PHP는 일반적으로 PHP Hypertext ProCessor를 의미합니다.

 

 

 

PHP가 좋은 이유

 

첫 번째, PHP는 거의 모든 운영체제에서 사용이 가능합니다.

 

리눅스, 유닉스, 매킨토시, 솔라리스 등 거의 모든 플랫폼에서 쓰입니다.

 

간단하게 MS사에서 야심작으로 내놓은 asp를 비교해보죠.

 

asp 또한 웹언어이며 프로그래머들이 쇼핑몰이나 커뮤티케이션 등을 구축할 때 많이 사용합니다.

 

그렇나 asp는 윈도우 운영체제 안에서만 작동됩니다.

 

MS사의 횡포인지 아님 어쩔 수 없었는지 하여튼 그렇게 만들어 놨습니다.

 

그렇다고 이 asp가 안 좋은 것은 아닙니다.

 

서두에서 말했듯이 모든 언어가 장단점이 있습니다.

 

두 번째,  PHP는 '무료'다.

 

PHP란 언어는 한 개인에 의해서 만들어 졌으며, 자유 소프트웨어의 철학인 오픈소스 및 GNU 정신을 따르고 있습니다.

 

한마디로 PHP를 하고 싶은데 돈이 없어서 다운을 못받는 일은 없다는 거죠.

 

모든 소프트웨어는 웹상에서 공개되어 있습니다.

 

세 번째, 속도가 빠르다.

 

cgi로 짜여진 게시판이나 방명록을 많이 보셨을겁니다.

 

cgi 프로그램은 처리하는값이 사용자 수만큼 증가하기 때문에 그만큼 프로세스가 증가합니다.

 

그렇기 때문에 서버에 과부하가 걸리죠.

 

하지만 PHP는 해석엔진이 아파치에 탑재되어 있기 때문에 오직 하나만의 프로세스만 작동하며 그만큼 서버에 부하를 줄일 수 있습니다.

 

결국 웹상의 속도는 엄청 빠르겠죠..

 

네 번째, 함수가 많다.

 

언어를 처음 접하는 분들이라면 이것이 뭐가 좋은 것인가 하고 생각하는 분들이 있을 겁니다.

 

함수가 많다는 것은 그만큼 프로그래머들을 편하게 해줍니다.

 

예를 들어 C언어로 20줄 짜야 할 프로그램이 있다면 PHP는 5줄로 끝낼 수가 있습니다.

 

다섯 번째, 100% 서버스크립트 언어이다.

 

PHP는 100% 웹상에서만 쓸 수 있도록 되어 있습니다.

 

C언어나 JAVA는 웹 전용이 아니기 때문에 PHP 코드의 몇 배에 해당하는 코드를 써야 동일한 코드를 만들 수 있습니다.

 

여섯 번째, 많은 데이터베이스를 지원한다.

 

데이터베이스라 함은 한 마디로 많은 자료를 저장하는 창고라고 할 수 있습니다.

 

PHP 프로그램이 수행되면서 데이터베이스에 자료를 집어 넣기도 하고 꺼내기도 합니다.

 

그럼 PHP에서 지원하는 데이터베이스가 얼마나 많은데 여기에 이런 내용을 쓸까요?

 

Oracle, Adabas D, Sybase, Filepro, mSQL, Mysql, VeloCis, Informix, Solid, DBase 등등등...

 

정말 많은 데이터베이스가 PHP에서 지원됩니다.

 

하지만 이 중에서 PHP와 궁합이 가장 잘 맞는 DB가 Mysql이랍니다.

 

MySQL은 가장 대중적인 SQL입니다.

 

자료를 저장하고 보다 수월하게 관리하기 위하여 등장한 개념이지요.

 

MySQL 말고도 MSQL 같은 소규모 DB, 또 ASP와 연동하여 쓰이는 MSSQL 등 많은 다른 SQL이 있긴 하지만 MySQL에는 다른 SQL들을 압도하는 매력이 있습니다.

 

우선 MySQL은 Linux, ApaChe, PHP와 환상적인 조화를 이룬답니다.

 

인터넷 상에서 가장 많은 비중을 차지하는 서버는 Linux고, 그 중 PHP와 MySQL의 연동은 Linux 서버의 근간을 이루고 있습니다.

 

또한 MySQL은 상용을 능가하는 기능에도 불구하고 무료입니다.

 

이는 Linux로부터 비롯된 인터넷상의 청년정신인데, Linux이외에도 ApaChe, PHP 또한 무료이기에 개인적인 용도로 학습을 위해서라면 최적의 조건이죠.

 

뿐만 아니라 MySQL은 상용으로 쓰인다 하더라도 완벽한 기능을 나타냅니다.

 

자, 어떠신가요?

 

PHP와 MySQL을 알고 나니 세계의 많은 젊은이들이 힘을 모아 이룩한 Linux+ApaChe+PHP+MySQL의 세계에 한 번 푹 빠지고 싶지 않으신가요?

 

MySQL를 발음하는 공식의 길은 “나의 Ess Que Ell”(MY-SEQUEL가 아니라) 입니다.

 

 

 

왜 PHP + MySQL이어야만 하는가?

 

CGI를 구현하기 위한 프로그램은 상당히 많습니다.

 

Win2k의 등장과 함께 더욱 인기가 많아진 asp가 그렇고, 최근 가장 각광 받는 jsp도 참 좋으며, 전통의 C 또한 요즘 다시 많이 쓰이고 있는 추세입니다.

 

그 외 JAVA나 perl 등도 빠뜨릴 수 없는 CGI 프로그램이긴 합니다.

 

그럼에도 굳이 PHP와 MySQL을 선택해야 하는 까닭은 그 용이성에 있습니다.

 

프로그램이나 스크립트 언어가 거기서 거기인 면이 많아 왠만한 프로그래머라면 프로그램에 관계없이 필요에 따라 툴을 선택할 수 있는 것도 사실입니다.

 

그렇지만 각 프로그램의 유사성이라고 해봤자 구조적인 면에서나 존재할 뿐이지, 사실 세부적으로 따지고 들자면 그 어느 프로그램도 PHP 보다 쉬울 수는 없어 보입니다.

 

C나 JAVA 같이 전문적인 프로그램을 이용한다면 개발자가 일일히 많은 부분의 설정을 담당해야 할 것입니다.

 

그렇지만 PHP는 그런 골치 아픈 부분들을 대충 뭉뚱그려 놨기에 초보자로서는 훨씬 쉽게 원하는 프로그램을 짤 수 있는 것이지요.

 

물론 여기에는 장단점이 있습니다.

 

PHP의 그런 뭉뚱그림 때문에 어쩌면 꼭 필요한 세부사항을 개발자가 선택하기에 어려움이 있을 지도 모르겠습니다.

 

그렇지만 그런 일이야 인터넷에서 돌아가는 간단한 프로그램을 짜는 데에는 특별히 영향을 미치지 않을 거라 확신합니다.

 

그리고 PHP는 MySQL과 아주 조화를 잘 이룹니다.

 

다른 언어에 비하여 MySQL의 접속이나 제어가 용이하기 때문이죠.

 

물론 PHP가 Linux를 근본으로 개발되었긴 했지만 처음 PHP를 접하시는 분들도 Windows 환경에서 특별한 문제 없이 이용할 수 있습니다.

 

PHP 자체가 IIS나 PWS와도 잘 호환되긴 하지만 Windows용 Apache, 그리고 MySQL이 이미 개발되었기에 Windows 유저들도 Linux에 관한 전문적인 지식 없이 Apache+PHP+MySQL을 사용할 수 있다는 것은 초보자들에게 큰 힘이 되기도 하겠죠^^

 

아, 그리고 이들은 모두 무료라는 것.

 

Windows용 MySQL은 쉐어웨어가 되긴 했지만 개인 유저라면 과거와 똑같이 이용할 수 있습니다.

 

곧 아무런 비용없이Apache+PHP+MySQL의 환상적인 효과를 경험할 수 있을 것입니다.


이 글을 트위터로 보내기 이 글을 페이스북으로 보내기

 
   
 


『신개념 4단계 리눅스기술지원 시스템 공개』

CentOS 리눅스 전문서적 국내최초출시

 
회사소개 | 보도기사 | 채용안내 | 광고안내 | 이용약관 | 개인정보취급방침 | 책임한계와 법적고지 | 불편사항 신고하기 | 사이트맵
ㅇ 서울 : 서울특별시 강남구 노현로79길 66, 402호(역삼동,청송빌딩)  ㅇ 부산 : 부산광역시 해운대구 우동 1470 에이스하이테크21 914호
ㅇ 대표 : 1544-8128 ㅇ부산직통 : 051-744-0077 ㅇ서울직통 : 02-856-0055 ㅇ FAX : 02-6280-2663
ㅇ 사업자번호 : 128-86-68239 ㅇ 통신판매업 신고번호 : 2013-부산금정-0035호 ㅇ 개인정보책임자 : 이재석
ㅇ 상호명 : (주) 수퍼유저 ㅇ 대표자 : 박성수
Copyright ⓒ (주)수퍼유저. All rights reserved.

 아 이 디
 비밀번호
회원 가입 | 비밀번호 찾기

블로그~
 
▷ 질문과 답변
리눅스
서버해킹/보안
네트워크
아파치
메일서버
DNS
PHP
JSP
MySQL
큐브리드
Oracle
MRTG
SMS
Weblog
Domain
S/W
하드웨어
책제목
리눅스서버관리실무바이블v3.0


저자 박성수
페이지수 2,032 pages
펴낸곳(주)수퍼유저

리눅스 서버 구축 및 관리에 필요한 거의 모든 부분과 전반적인 실무 기법들을 다루고 있음
책제목
리눅스보안관리실무(2/E)


저자홍석범
페이지수 820 pages
펴낸곳(주)수퍼유저

리눅스 보안에 관련된 내용을 종합적으로 쓴 책. 저자의 명성 그대로 보안관련의 모든 내용이 그대로 담겨져 있다.