기본 설정
서버의 기본 동작 방식과 안정성을 보장하기 위한 설정입니다.
[mysqld]
user = mysql
sql_mode = STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION,NO_ZERO_DATE,NO_ZERO_IN_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER
autocommit = 1
character_set_server = utf8mb4
transaction_isolation = READ-COMMITTED
explicit_defaults_for_timestamp = 1
max_allowed_packet = 64M
event_scheduler = 1
연결 관리
클라이언트 연결에 대한 제한과 타임아웃 설정을 통해 시스템 리소스를 효율적으로 관리합니다.
interactive_timeout = 1800
wait_timeout = 1800
lock_wait_timeout = 1800
skip_name_resolve = 1
max_connections = 1024
max_user_connections = 256
max_connect_errors = 1000000
테이블 캐시 성능
열린 테이블 및 정의 정보의 캐시 크기를 조정하여 동시성 처리 능력을 향상시킵니다.
table_open_cache = 4096
table_definition_cache = 4096
table_open_cache_instances = 64
세션 메모리 설정
쿼리 실행 중 사용되는 버퍼 크기를 조절하여 성능을 최적화합니다.
read_buffer_size = 16M
read_rnd_buffer_size = 32M
sort_buffer_size = 32M
tmp_table_size = 64M
join_buffer_size = 128M
thread_cache_size = 64
로그 설정
오류, 느린 쿼리, 인덱스 미사용 등 중요한 운영 정보를 기록합니다.
log_error = error.log
log_bin = binlog
log_error_verbosity = 2
general_log_file = general.log
slow_query_log = 1
slow_query_log_file = slow.log
log_queries_not_using_indexes = 1
log_slow_admin_statements = 1
log_slow_slave_statements = 1
log_throttle_queries_not_using_indexes = 10
expire_logs_days = 90
long_query_time = 2
min_examined_row_limit = 100
binlog-rows-query-log-events = 1
log-bin-trust-function-creators = 1
log-slave-updates = 1
InnoDB 전용 설정
데이터베이스의 핵심 저장 엔진인 InnoDB의 성능과 안정성을 극대화하는 설정입니다.
innodb_page_size = 16384
innodb_buffer_pool_size = 160G
innodb_buffer_pool_instances = 16
innodb_buffer_pool_load_at_startup = 1
innodb_buffer_pool_dump_at_shutdown = 1
innodb_lru_scan_depth = 4096
innodb_lock_wait_timeout = 5
innodb_io_capacity = 10000
innodb_io_capacity_max = 20000
innodb_flush_method = O_DIRECT
innodb_undo_logs = 128
innodb_undo_tablespaces = 3
innodb_flush_neighbors = 0
innodb_log_file_size = 16G
innodb_log_files_in_group = 2
innodb_log_buffer_size = 64M
innodb_purge_threads = 4
innodb_large_prefix = 1
innodb_thread_concurrency = 64
innodb_print_all_deadlocks = 1
innodb_strict_mode = 1
innodb_sort_buffer_size = 128M
innodb_write_io_threads = 16
innodb_read_io_threads = 16
innodb_file_per_table = 1
innodb_stats_persistent_sample_pages = 64
innodb_autoinc_lock_mode = 2
innodb_online_alter_log_max_size = 1G
innodb_open_files = 4096
복제 설정
주-부 복제 환경에서의 일관성과 성능을 보장하기 위한 구성입니다.
master_info_repository = TABLE
relay_log_info_repository = TABLE
sync_binlog = 1
gtid_mode = ON
enforce_gtid_consistency = 1
binlog_format = ROW
relay_log = relay.log
relay_log_recovery = 1
slave_skip_errors = ddl_exist_errors
slave-rows-search-algorithms = 'INDEX_SCAN,HASH_SCAN'
반응형 복제 활성화
반응형 복제 기능을 사용할 경우 필요한 플러그인 로드 및 옵션 설정입니다.
plugin-load = "semisync_master.so;semisync_slave.so"
loose_rpl_semi_sync_master_enabled = 1
loose_rpl_semi_sync_master_timeout = 3000
loose_rpl_semi_sync_slave_enabled = 1
비밀번호 정책 강화
사용자 계정의 보안 수준을 높이기 위한 정책 설정입니다.
validate_password_policy = STRONG
validate-password = FORCE_PLUS_PERMANENT
Performance Schema 최적화
성능 모니터링을 위한 스키마의 메모리 사용량 및 크기를 조절합니다.
performance-schema-instrument = 'memory/%=COUNTED'
performance_schema_digests_size = 40000
performance_schema_max_table_instances = 40000
performance_schema_max_sql_text_length = 4096
performance_schema_max_digest_length = 4096
MySQL 5.7 고유 설정
5.7 버전에서 도입된 새로운 기능 및 개선 사항에 대한 설정입니다.
loose_innodb_numa_interleave = 1
innodb_buffer_pool_dump_pct = 40
innodb_page_cleaners = 16
innodb_undo_log_truncate = 1
innodb_max_undo_log_size = 2G
innodb_purge_rseg_truncate_frequency = 128
slave-parallel-type = LOGICAL_CLOCK
slave-parallel-workers = 16
slave_preserve_commit_order = 1
slave_transaction_retries = 128
binlog_gtid_simple_recovery = 1
log_timestamps = system
show_compatibility_56 = ON
그룹 복제 설정 (선택적)
다중 노드 그룹 복제 환경을 구축할 때 필요한 추가 설정입니다.
plugin-load = "group_replication.so;semisync_master.so;semisync_slave.so"
transaction-write-set-extraction = XXHASH64
loose_group_replication = FORCE_PLUS_PERMANENT
loose_group_replication_group_name = "aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa"
loose_group_replication_compression_threshold = 100
loose_group_replication_flow_control_mode = 0
loose_group_replication_single_primary_mode = 0
loose_group_replication_enforce_update_everywhere_checks = 1
loose_group_replication_transaction_size_limit = 10485760
loose_group_replication_unreachable_majority_timeout = 120
loose_group_replication_start_on_boot = 0