公司配置是12C 24G的机器,以往mysql的mem_limit 是512M 初始化脚本中有一张表初始化需要导入55万条数据,单表大小70MB 放在docker-entrypoint-initdb.d 目录下 现在greatsql每次初始化导入sql的语句执行到这张表的时候就会中断,请问怎么配置合适?核心参数是什么?? 现在的配置是参照128c256g等比例缩小的,如下: # 服务器可用总内存为12c24g [client] socket = /data/GreatSQL/mysql.sock [mysql] loose-skip-binary-as-hex prompt="(\\D)[\\u@GreatSQL][\\d]>" no-auto-rehash [mysqld] user = mysql port = 3306 server_id = 1 basedir = /usr/ datadir = /data/GreatSQL socket = /data/GreatSQL/mysql.sock pid-file = mysql.pid character-set-server = UTF8MB4 skip_name_resolve = ON #掽运行在境外,根据实际情况调整本参数 default_time_zone = "+8:00" bind_address = "0.0.0.0" secure_file_priv = /data/GreatSQL lower_case_table_names = 0 #performance setttings # 锁等待超时时间(s) lock_wait_timeout = 3600 # 系统允许的最大打开文件数,调低至适合小内存的值 open_files_limit = 10240 # 连接排队等待的最大请求数 back_log = 512 # 最大连接数 max_connections = 1024 # 最大连接错误数 max_connect_errors = 10000 # 表缓存和表定义缓存 table_open_cache = 512 table_definition_cache = 512 # 排序和连接缓存大小 sort_buffer_size = 2M join_buffer_size = 2M # 读取缓存 read_buffer_size = 4M read_rnd_buffer_size = 4M # 批量插入缓存大小 bulk_insert_buffer_size = 32M # 线程缓存 thread_cache_size = 50 # # 交互式超时时间 interactive_timeout = 600 wait_timeout = 600 # 临时表大小和最大堆表大小 tmp_table_size = 16M max_heap_table_size = 32M #log settings # 时间戳设置 log_timestamps = SYSTEM # 错误日志路径 log_error = error.log # 错误日志详细等级 log_error_verbosity = 3 # 慢查询日志开关 slow_query_log = ON # 慢查询日志增加额外信息 log_slow_extra = ON # 慢查询日志文件路径 slow_query_log_file = slow.log # 慢查询的时间阈值 long_query_time = 0.1 # 记录未使用索引的查询 log_queries_not_using_indexes = ON # 对未使用索引查询的日志写入进行限流 log_throttle_queries_not_using_indexes = 6000 # 设置记录慢查询的最低检查行数 min_examined_row_limit = 1000 # 记录慢速管理语句 log_slow_admin_statements = ON # 记录慢速的从库语句 log_slow_slave_statements = ON # 慢查询日志详细级别,保留为FULL log_slow_verbosity = FULL # 启用二进制日志并设置文件路径 log_bin = /data/GreatSQL/binlog # 二进制日志格式设置为 ROW 格式 binlog_format = ROW # 同步二进制日志的频率(s),设置为较低值以降低写频率 sync_binlog = 1 # 二进制日志缓存大小,保持为小值G binlog_cache_size = 2M # 二进制日志缓存的最大大小,减小上限以适应内存 max_binlog_cache_size = 2G # 单个二进制日志文件的最大大小 max_binlog_size = 1G # 记录行查询日志事件 binlog_rows_query_log_events = 1 # 二进制日志过期时间 binlog_expire_logs_seconds = 604800 # 二进制日志的校验方式 binlog_checksum = CRC32 # 二进制日志提交顺序,关闭有助于提升写入性能 binlog_order_commits = OFF # 启用 GTID 并确保一致性,保留原值 gtid_mode = ON enforce_gtid_consistency = TRUE #myisam settings key_buffer_size = 32M myisam_sort_buffer_size = 128M relay_log_recovery = 1 # 并行复制类型, slave_parallel_type = LOGICAL_CLOCK #并行复制线程数可以设置为逻辑CPU数量的1或2倍 slave_parallel_workers = 6 # 二进制日志事务依赖跟踪 binlog_transaction_dependency_tracking = WRITESET # 保持提交顺序, slave_preserve_commit_order = 1 # 从库检查点周期 slave_checkpoint_period = 2 #启用InnoDB并行查询优化功能 loose-force_parallel_execute = OFF #设置每个SQL语句的并行查询最大并发度 loose-parallel_default_dop = 4 #设置系统中总的并行查询线程数,可以和最大逻辑CPU数量一样 loose-parallel_max_threads = 8 #并行执行时leader线程和worker线程使用的总内存大小上限,可以设置物理内存的5-10%左右 loose-parallel_memory_limit = 1G #mgr settings # MGR 插件加载 loose-plugin_load_add = 'mysql_clone.so' loose-plugin_load_add = 'group_replication.so' # MGR组名 loose-group_replication_group_name = "aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaa1" loose-group_replication_local_address = "172.16.0.3:33051" loose-group_replication_group_seeds = '172.16.0.2:33051,172.16.0.3:33051' # 设置为随服务器启动时自动加入集群 loose-group_replication_start_on_boot = ON # 初次启动时不自动引导群集 loose-group_replication_bootstrap_group = OFF # 如果发生故障,将节点设置为只读模式 loose-group_replication_exit_state_action = READ_ONLY # 关闭流量控制模式以减少延迟 loose-group_replication_flow_control_mode = "DISABLED" # 启用单主模式 loose-group_replication_single_primary_mode = ON # 设置MGR多数决 loose-group_replication_majority_after_mode = ON # 最大消息大小,适应小内存服务器 loose-group_replication_communication_max_message_size = 6M # 禁用仲裁节点 loose-group_replication_arbitrator = 0 # 单主快速切换 loose-group_replication_single_primary_fast_mode = 1 # 请求的时间阈值 loose-group_replication_request_time_threshold = 100 # 主节点选举模式 loose-group_replication_primary_election_mode = GTID_FIRST # 超时设置 loose-group_replication_unreachable_majority_timeout = 0 loose-group_replication_member_expel_timeout = 5 loose-group_replication_autorejoin_tries = 288 loose-group_replication_recovery_get_public_key = ON # 设置报告 IP report_host = "172.16.0.3" #innodb settings # InnoDB 缓冲池大小:建议设为内存的 50%-70%,如 1.5G innodb_buffer_pool_size = 512M # 缓冲池实例数量,设置为 1 因为内存较小,多个实例会造成内存开销 innodb_buffer_pool_instances = 3 # InnoDB 数据文件路径,保持自动扩展 innodb_data_file_path = ibdata1:12M:autoextend # 日志刷新设置 innodb_flush_log_at_trx_commit = 1 # 日志缓冲大小,减小至 8M 以节省内存 innodb_log_buffer_size = 24M # 日志文件大小,设置为较小的 128M,减少内存占用 innodb_log_file_size = 512M # 日志文件组数量 innodb_log_files_in_group = 2 # doublewrite 文件数量 innodb_doublewrite_files = 1 # 最大撤销日志文件大小,适当减小为 512M innodb_max_undo_log_size = 1G # 根据服务器IOPS能力适当调整 # 一般配普通SSD盘的话,可以调整到 10000 - 20000 # 配置高端PCIe SSD卡的话,则可以调整的更高,比如 50000 - 80000 # IOPS 能力,根据小服务器设置为较低值 innodb_io_capacity = 10000 innodb_io_capacity_max = 20000 # InnoDB 打开的文件数量,适当减小以节省资源 innodb_open_files = 10000 # 日志刷新方法,保留为 O_DIRECT innodb_flush_method = O_DIRECT # LRU 扫描深度 innodb_lru_scan_depth = 1024 # 锁等待超时时间,保留原值 innodb_lock_wait_timeout = 10 # 超时回滚事务 innodb_rollback_on_timeout = 1 # 打印死锁日志 innodb_print_all_deadlocks = 1 # 在线 DDL 日志最大大小,减小到 512M 以节省内存 innodb_online_alter_log_max_size = 2G # 打印 DDL 日志 innodb_print_ddl_logs = ON # 启用 InnoDB 状态文件 innodb_status_file = ON # 关闭 InnoDB 状态输出 innodb_status_output = OFF # 打印锁信息 innodb_status_output_locks = ON # 排序缓存,减小为 8M innodb_sort_buffer_size = 24M # 自适应哈希索引,关闭以减少内存占用 innodb_adaptive_hash_index = OFF # NUMA 内存互交,保持关闭 innodb_numa_interleave = OFF # 自旋等待延迟,保留原值 innodb_spin_wait_delay = 20 |
yejr
2024-12-10 10:45:56
| ||
Jnu2021
2024-12-11 17:11:35
| ||
yejr
2024-12-12 11:03:54
| ||
Jnu2021
2024-12-12 15:37:25
| ||
yejr
2024-12-12 15:41:49
| ||
DB架构师:曾凡坤
2024-12-30 01:38:07
| ||
公众号 求关注 https://mp.weixin.qq.com/s/8aYQ6HN_uNKLObJuIliNvg
|
||
DB架构师:曾凡坤
2024-12-30 01:38:57
| ||
公众号 求关注 https://mp.weixin.qq.com/s/8aYQ6HN_uNKLObJuIliNvg
|
||
合作电话:010-64087828
社区邮箱:greatsql@greatdb.com