라이트세일 서버리스 DB 기본설정 참고용
아래는 라이트세일 DB 테스트 하고 간단하게 정리한 내용입니다.
개인 저장용이며 이런 서버리스 관리형 DB 사용할때 메모리 크기에 따라서 어떻게 설정 되어 있는지(튜닝) 보면 도움이 됩니다.
GTID의 경우 모두 기본 설정이 약간 다릅니다.
라이트세일은 테스트 할때 유의깊게 보니 모두 전송량은 100G 이지만
가격에 따라 속도의 제한이 있다고 나와 있습니다.
스마일서브 서버리스 DBMS 서비스 하는데 이중화 서비스가 없습니다.
리노드는 옆나라(일본)에서 앞으로 할것 같은데요. 국내에 없는게 아쉽습니다.
필요하면 디지털오션이 일본에 있을 수 있으니 사용하면 되지만 가깝고도 먼 일본.
마스터 DB서버를 일본에 놔야 하다니??? 아무래도 좀 그래서 비용이 들어가도 AWS 이용하게 될듯 합니다.
다국적 서비스를 하고 있는 Vultr은 메뉴를 아무리 봐도 DBMS 서비스가 없습니다. 리노드는 지금 베타서비스 하나 본데
서버리스DBMS가 수요가 당연히 있을 터인데 서비스 하는것이 쉽지 않은가 봅니다.
SSD VPS Servers, Cloud Servers and Cloud Hosting by Vultr - Vultr.com
마스터의 현황을 확인해 보자
show variables like '%gtid%';
mysql 환경설정
gtid-mode=OFF_PERMISSIVE
# https://myinfrabox.tistory.com/30
# GTID 기반 복제에 문제가 생기는 명령문의 실행을 방지하려면 GTID를 사용할 때 모든 서버를 --enforce-gtid-consistency 옵션으로 시작해야합니다.
enforce-gtid-consistency=true
binlog_gtid_simple_recovery=true
master-verify-checksum=0
#
slave_parallel_type =LOGICAL_CLOCK
slave_preserve_commit_order=1
sql_require_primary_key=1
tls_version=TLSv1.2
# 1이 디폴트이며 이 방식이 더 완벽하다고 한다. 속도는 느림. 마스터와 맞춤
sync_binlog = 0
# 테이블명 대소문자는 구분
lower_case_table_names =0
autocommit =1
# 부분 취소를 사용하는 권한 제한
partial_revokes = 1
binlog-checksum=CRC32
slave-sql-verify-checksum=1
# 1007: 디비 만들려 하는데 이미 있어서 오류가 난것. 슬레이브에 있는데. 마스터에서 만들경우.
# 1008: Error 'Can't drop database 'defaultdb'; database doesn't exist' on query 슬레이브에 이 디비가 없을때
# 1396: Error 'Operation DROP USER failed for 'aws_rds_root'@'127.0.0.1' 슬레이브에 이 유저가 없을때.
# 1032: handler error HA_ERR_KEY_NOT_FOUND - 레코드를 찾을 수 없다.
# 1050: 존재하는 테이블이라서 새로 만들 수 없음.
# 1051: 슬레이브에 테이블이 없을때. 마스터에서 drop table 했을 경우. 슬레이브에는 없을때.
# 1052: 조인관련 오류. 건너뛰어도 문제 되지 않는다.
# 1053: 서비스가 적시에 시작 또는 제어 요청에 응답하지 않았습니다.
# 1060 : Duplicate column name 'app_id' 열 이름 중복
# ERROR 1061: Duplicate key name 'idx3' 인덱스명 중복
# ERROR 1062: Duplicate entry '1' for key 1 키 중복 오류
# Error 1136(21S01) : Columm count doesn`t match value count at row 1 / 인덱스 개수와 컬럼 갯수가 맞지 않을때?
# Error 1064(42000) : you have an error in your SQL Syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '' at Line 4
# 1146: 테이블이 없을때. 프로그램할때 흔하게 실 수 할 수 있는것으로 처리 하지 않도록 한다.
# ERROR 1072: Key column 'c1' doesn't exist in table 테이블이 없다
# ERROR 1054: Unknown column 'dream_qna' in 'where clause' 문자열일 때는 따음표로 비교해라
# slave-skip-errors = 1050,1051,1052,1053,1060,1146,1136
slave-skip-errors = 1146,1051,1396,1008,1007,1032
5.6 / 5.7 기본설정 비교
* PHP 슬레이브 디비 관련 처리 프로그램
- mysql 슬레이브 연결 끊어졌을때 자동으로 마스터 연결시켜 주는 프로그램