AWS의 인스턴스에서 SSH 설정하는 것부터 이어간다. 굳이 안 바꿔도 잘 동작하지만, 한 번 설정해두면 앞으로 따로 건드릴 일이 없을 것 같아서 인터넷으로 내용을 좀 찾아봤다.
Protocol, IP, Port Forwarding, Domain 등의 전반적인 네트워크 인프라 개념 구축
# 혹시 vim 에디터가 없으면 apt install vim으로 설치한다
$ sudo vim /etc/ssh/sshd_config
$ sudo vim /etc/services
$ sudo ufw enable
# 기존 SSH 프로토콜 포트 허용
$ sudo ufw allow 22/tcp
# 신규 SSH 프로토콜 포트 허용
$ sudo ufw allow ***/tcp
# HTTP 포트 허용
$ sudo ufw allow 80/tcp
# HTTPS 포트 허용
$ sudo ufw allow 443/tcp
# 허용된 포트 확인
$ sudo ufw status
# SSH 재시작
$ sudo systemctl restart sshd
$ sudo ufw deny 22/tcp
$ cd ~/.ssh
$ sudo vim config
$ ssh rising-server
이전에 소스설치할 때와 다르게 패키지 설치로 진행한다. apt로 패키지를 설치하기 전에 update와 upgrade 하는 것을 잊지 말자!
$ sudo apt install nginx
$ sudo service nginx start
$ sudo apt install mysql-server
$ sudo apt install php-fpm
$ sudo apt install php-mysql
$ sudo vim /etc/nginx/sites-available/default
$ sudo vim /etc/php/7.4/fpm/php.ini
$ vim /var/www/html/index.php
$ sudo mysql
# user_name에는 원하는 계정 이름을 입력한다. @ 뒤의 %는 모든 호스트에서의 접속을 허용한다.
mysql > CREATE USER 'user_name'@'%' IDENTIFIED BY 'password';
# 계정을 생성한 뒤 바로 권한 설정을 한다. *.*는 모든 데이터베이스와 테이블에 대한 접근 권한을 주는 것이다.
mysql > GRANT ALL PRIVILEGES ON *.* TO 'user_name'@'%' WITH GRANT OPTION;
# 권한 설정 후 테이블을 갱신한다.
mysql > FLUSH PRIVILEGES;
# 추가) root 계정의 비밀번호를 바꾸거나 재설정하려면 아래와 같이 한다. 다른 계정도 마찬가지로 바꿀 수 있다.
mysql > ALTER USER 'root'@'localhost' IDENTIFIED WITH caching_sha2_password BY 'password';
# 생성된 계정을 확인한다.
mysql > SELECT user, host, plugin FROM mysql.user;
$ sudo ufw allow 3306
$ sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf
$ sudo service mysql restart
$ sudo add-apt-repository ppa:phpmyadmin/ppa
# 실제로 삭제하는건 아니고 중지 시켰다가 다시 해제하는 것이다
mysql > UNINSTALL COMPONENT "file://component_validate_password";
# phpMyAdmin 설치가 다 끝나면 아래와 같이 Component를 다시 실행한다
mysql > INSTALL COMPONENT "file://component_validate_password";
$ cd /var/www/html
# myAuth는 심볼릭 링크명으로 임의로 설정한다
$ sudo ln -s /usr/share/phpmyadmin myAuth
$ sudo chown -h www-data:www-data myAuth
다음은 Domain과 HTTPS를 적용해보겠다.
[1] : 라이징캠프
[2] : AWS SSH 포트 변경하기
[3] : How to install MySQL on Ubuntu 20.04
[4] : How to install and secure phpMyAdmin
저도 MySQL과 LEMP 스택을 설정하는 비슷한 단계를 따라해봤는데, 잘 작동하긴 했습니다. 하지만 시간이 지나면서 AWS에서 Vultr로 전환했는데, 솔직히 몇 가지 이유로 완전히 게임 체인저였습니다:
간단함: AWS도 괜찮지만, 소규모 프로젝트에는 너무 복잡하게 느껴질 때가 많습니다. Vultr의 인터페이스는 훨씬 깔끔하고, 인스턴스, 방화벽, 설정 등을 관리하기가 훨씬 쉽습니다.
비용: AWS는 데이터 전송이나 대역폭 같은 항목들 때문에 예상치 못한 비용이 발생할 수 있습니다. Vultr의 가격은 훨씬 예측 가능해서 예산을 관리할 때 많은 도움이 됩니다.
성능: Vultr의 고주파수 컴퓨트(High Frequency Compute) 인스턴스에서 MySQL을 실행할 때 더 나은 성능을 느꼈습니다. 응답 시간이 더 빠르고, 전반적으로 다운타임이 적었습니다. 이런 설정에서는 밀리초 단위의 차이도 눈에 띄는데, Vultr에서 더 나았습니다.
만약 누군가 전환을 고려하거나 새로 시작하려고 한다면, 이 가이드를 추천합니다:
우분투 22.04에서 MySQL 설치 가이드
그리고, Vultr에서 phpMyAdmin을 설치하고 보안 설정을 하는 방법도 매우 간단합니다. LAMP 스택과 함께 phpMyAdmin을 설치하고 보호하려는 분들은 이 가이드를 참조해 보세요:
phpMyAdmin 설치 및 보안 설정 방법
간단하고, Vultr이 처음이라도 따라 하기 쉬운 단계로 구성되어 있습니다. AWS와 Vultr을 비슷한 설정에서 비교하려는 분들께 드리는 작은 팁입니다!