웹사이트 검색

CentOS 7에 워드프레스를 설치하는 방법


소개

WordPress는 PHP와 MySQL을 사용하는 무료 오픈 소스 웹사이트이자 블로깅 도구입니다. WordPress는 현재 인터넷에서 가장 인기 있는 CMS(콘텐츠 관리 시스템)이며 기능을 확장하기 위해 20,000개 이상의 플러그인이 있습니다. 따라서 WordPress는 웹 사이트를 빠르고 쉽게 시작하고 실행할 수 있는 훌륭한 선택입니다.

이 가이드에서는 CentOS 7에서 Apache 웹 서버로 WordPress 인스턴스를 설정하는 방법을 보여줍니다.

전제 조건

이 가이드를 시작하기 전에 먼저 완료해야 하는 몇 가지 단계가 있습니다.

sudo 권한이 있는 루트가 아닌 사용자로 CentOS 7 서버를 설치 및 구성해야 합니다. 아직 이 작업을 수행하지 않은 경우 CentOS 7 초기 서버 설정 가이드의 1-4단계를 실행하여 이 계정을 만들 수 있습니다.

또한 CentOS 7 서버에 LAMP(Linux, Apache, MySQL 및 PHP) 스택이 설치되어 있어야 합니다. 이러한 구성 요소를 아직 설치하거나 구성하지 않은 경우 이 가이드를 사용하여 CentOS 7에 LAMP를 설치하는 방법을 알아볼 수 있습니다.

이 단계를 마치면 WordPress 설치를 계속할 수 있습니다.

1단계 — WordPress용 MySQL 데이터베이스 및 사용자 생성

우리가 취할 첫 번째 단계는 준비 중입니다. WordPress는 관계형 데이터베이스를 사용하여 사이트 및 해당 사용자에 대한 정보를 관리합니다. 이 기능을 제공할 수 있는 MariaDB(MySQL의 포크)가 이미 설치되어 있지만 WordPress에서 사용할 데이터베이스와 사용자를 만들어야 합니다.

시작하려면 다음 명령을 실행하여 MySQL의 root(관리자) 계정에 로그인합니다.

mysql -u root -p

MySQL을 설치할 때 루트 계정에 대해 설정한 암호를 입력하라는 메시지가 표시됩니다. 비밀번호를 제출하면 MySQL 명령 프롬프트가 표시됩니다.

먼저 WordPress에서 제어할 수 있는 새 데이터베이스를 만듭니다. 이것을 원하는 대로 호출할 수 있지만 이 예제에서는 wordpress라고 하겠습니다.

CREATE DATABASE wordpress;

참고: 모든 MySQL 문 또는 명령은 세미콜론(;)으로 끝나야 하므로 문제가 발생할 경우 세미콜론이 있는지 확인하십시오.

다음으로 WordPress의 새 데이터베이스에서 독점적으로 사용할 새 MySQL 사용자 계정을 만들 것입니다. 단일 기능 데이터베이스 및 계정을 만드는 것은 권한 및 기타 보안 요구 사항을 더 잘 제어할 수 있으므로 좋은 생각입니다.

새 계정 wordpressuser를 호출하고 암호 password를 할당하겠습니다. 이러한 예는 그다지 안전하지 않으므로 반드시 다른 사용자 이름과 암호를 사용해야 합니다.

CREATE USER wordpressuser@localhost IDENTIFIED BY 'password';

이 시점에서 WordPress용으로 특별히 만들어진 데이터베이스와 사용자 계정이 있습니다. 그러나 사용자는 데이터베이스에 액세스할 수 없습니다. 데이터베이스에 대한 사용자 액세스 권한을 부여하여 두 구성 요소를 함께 연결해야 합니다.

GRANT ALL PRIVILEGES ON wordpress.* TO wordpressuser@localhost IDENTIFIED BY 'password';

이제 사용자가 데이터베이스에 액세스할 수 있으므로 MySQL이 우리가 만든 최근 권한 변경 사항을 알 수 있도록 권한을 플러시해야 합니다.

FLUSH PRIVILEGES;

이러한 명령이 모두 실행되면 다음을 입력하여 MySQL 명령 프롬프트를 종료할 수 있습니다.

exit

이제 일반 SSH 명령 프롬프트로 돌아갑니다.

2단계 — WordPress 설치

WordPress를 다운로드하기 전에 제대로 작동하는지 확인하기 위해 설치해야 하는 PHP 모듈이 하나 있습니다. 이 모듈이 없으면 WordPress는 축소판을 만들기 위해 이미지 크기를 조정할 수 없습니다. yum을 사용하여 CentOS의 기본 리포지토리에서 직접 해당 패키지를 가져올 수 있습니다.

sudo yum install php-gd

이제 새 모듈을 인식하도록 Apache를 다시 시작해야 합니다.

sudo service httpd restart

이제 프로젝트 웹 사이트에서 WordPress를 다운로드하고 설치할 준비가 되었습니다. 운 좋게도 WordPress 팀은 항상 최신 안정 버전의 소프트웨어를 동일한 URL에 연결하므로 다음을 입력하여 최신 버전의 WordPress를 얻을 수 있습니다.

cd ~
wget http://wordpress.org/latest.tar.gz

그러면 필요한 모든 WordPress 파일이 포함된 압축된 아카이브 파일이 다운로드됩니다. 보관된 파일을 추출하여 tar를 사용하여 WordPress 디렉토리를 다시 빌드할 수 있습니다.

tar xzvf latest.tar.gz

이제 홈 디렉토리에 wordpress라는 디렉토리가 생겼습니다. 압축을 푼 파일을 Apache의 문서 루트로 전송하여 설치를 완료하면 웹 사이트 방문자에게 제공될 수 있습니다. 파일의 기본 권한을 유지하는 rsync를 사용하여 WordPress 파일을 전송할 수 있습니다.

sudo rsync -avP ~/wordpress/ /var/www/html/

rysnc는 압축을 푼 디렉토리의 모든 내용을 /var/www/html/의 문서 루트로 안전하게 복사합니다. 그러나 업로드된 파일을 저장하려면 WordPress용 폴더를 추가해야 합니다. mkdir 명령으로 그렇게 할 수 있습니다:

mkdir /var/www/html/wp-content/uploads

이제 WordPress 파일 및 폴더에 올바른 소유권과 권한을 할당해야 합니다. 이렇게 하면 WordPress가 의도한 대로 작동하면서 보안이 강화됩니다. 이를 위해 chown을 사용하여 Apache의 사용자 및 그룹에 소유권을 부여합니다.

sudo chown -R apache:apache /var/www/html/*

이 변경으로 웹 서버는 WordPress 파일을 만들고 수정할 수 있으며 콘텐츠를 서버에 업로드할 수도 있습니다.

3단계 - WordPress 구성

WordPress를 사용하는 데 필요한 대부분의 구성은 나중에 웹 인터페이스를 통해 완료됩니다. 그러나 WordPress가 생성한 MySQL 데이터베이스에 연결할 수 있도록 명령줄에서 몇 가지 작업을 수행해야 합니다.

WordPress를 설치한 Apache 루트 디렉터리로 이동하여 시작합니다.

cd /var/www/html

WordPress가 의존하는 기본 구성 파일은 wp-config.php입니다. 필요한 설정과 거의 일치하는 샘플 구성 파일이 기본적으로 포함되어 있습니다. 워드프레스가 파일을 인식하고 사용할 수 있도록 기본 구성 파일 위치에 복사하기만 하면 됩니다.

cp wp-config-sample.php wp-config.php

이제 작업할 구성 파일이 있으므로 텍스트 편집기에서 열어 보겠습니다.

nano wp-config.php

이 파일에 필요한 유일한 수정 사항은 데이터베이스 정보를 보유하는 매개변수입니다. MySQL 설정 섹션을 찾아 DB_NAME, DB_USERDB_PASSWORD 변수를 순서대로 변경해야 합니다. WordPress가 우리가 만든 데이터베이스에 올바르게 연결하고 인증할 수 있도록 합니다.

생성한 데이터베이스에 대한 정보로 이러한 매개변수의 값을 입력합니다. 다음과 같아야 합니다.

// ** MySQL settings - You can get this info from your web host ** //
/** The name of the database for WordPress */
define('DB_NAME', 'wordpress');

/** MySQL database username */
define('DB_USER', 'wordpressuser');

/** MySQL database password */
define('DB_PASSWORD', 'password');

이 값만 변경해야 하므로 완료되면 파일을 저장하고 닫습니다.

4단계 - 웹 인터페이스를 통해 설치 완료

이제 파일이 준비되고 소프트웨어가 구성되었으므로 웹 인터페이스를 통해 WordPress 설치를 완료할 수 있습니다. 웹 브라우저에서 서버의 도메인 이름 또는 공용 IP 주소로 이동합니다.

http://server_domain_name_or_IP

먼저 워드프레스를 설치할 언어를 선택해야 합니다. 언어를 선택하고 계속을 클릭하면 초기 관리자 계정을 생성할 WordPress 초기 구성 페이지가 표시됩니다.

만들고자 하는 사이트 및 관리 계정에 대한 정보를 입력합니다. 작업이 완료되면 하단의 WordPress 설치 버튼을 클릭하여 계속 진행합니다.

WordPress는 설치를 확인한 다음 방금 만든 계정으로 로그인하라는 메시지를 표시합니다.

계속하려면 하단의 로그인 버튼을 누른 다음 관리자 계정 정보를 입력하십시오.

로그인을 누르면 새로운 WordPress 대시보드가 표시됩니다.

결론

이제 CentOS 7 서버에서 WordPress 인스턴스를 실행해야 합니다. 여기에서 취할 수 있는 많은 길이 있습니다. 아래에 몇 가지 일반적인 옵션이 나열되어 있습니다.

  • 멀티사이트를 사용하여 여러 WordPress 사이트 설정
  • WPScan을 사용하여 취약한 플러그인 및 테마 테스트
  • 명령줄에서 WordPress 관리