mysql8.0 malloc,MySQL 5.7/8.0 优化

vi /etc/my.cnf

[mysqld]

...

performance_schema=off

ssl=off

关闭performance_schema和ssl可以降低cpu占用

MySQL 8.0 降低内存占用:

查看原始值:

show global variables like "performance_schema_max_table_instances";

-1

show global variables like "table_definition_cache";

2000

show global variables like "table_open_cache";

4000

vi /etc/my.cnf

performance_schema_max_table_instances=600

table_definition_cache=400

table_open_cache=256

查看密码安全验证级别:

mysql > SHOW VARIABLES LIKE '%validate_password_policy%';

临时修改:

mysql > SET GLOBAL validate_password_policy=0;

永久修改:

vi /etc/my.cnf

[mysqld]

validate_password_policy=0

或者卸载密码安全验证插件:

mysql > UNINSTALL PLUGIN validate_password;

如需重新安装此插件:

mysql > INSTALL PLUGIN validate_password SONAME 'validate_password.so';

tail -f /var/log/mysqld.log

发现错误:

[ERROR] Incorrect definition of table performance_schema.replication_connection_status: expected column 'RECEIVED_TRANSACTION_SET' at position 7 to have type longtext, found type text.

[ERROR] Incorrect definition of table performance_schema.replication_group_member_stats: expected column 'COUNT_TRANSACTIONS_ROWS_VALIDATING' at position 6, found 'COUNT_TRANSACTIONS_VALIDATING'.

解决方法:

mysql_upgrade -uroot -p

开启查询日志,性能开销极大,建议仅调试时临时开启:

SHOW GLOBAL VARIABLES LIKE 'general_%';

SET GLOBAL general_log=ON;

永久修改:

vi /etc/my.cnf

general_log=1

log_output=TABLE

参数说明:

log_output=[none|file|table|file,table] #通用查询日志输出格式

general_log=[on|off] #是否启用通用查询日志

general_log_file[=filename] #通用查询日志位置及名字

Restart MySQL databases.

systemctl restart mysqld

Change the definition of "mysql.general_log" table.

Switch the engine from CSV to MyISAM. To switch the engine from CSV to MyISAM, execute the following commands (the default is ENGINE=CSV).

mysql> SET GLOBAL general_log = 'OFF';

mysql> ALTER TABLE mysql.general_log ENGINE = MyISAM;

mysql> SET GLOBAL general_log = 'ON';

Check the definition of "mysql.general_log" table. Execute the following SQL command:

mysql> show create table mysql.general_log\G;

开启慢查询日志:

查看状态:

SHOW GLOBAL VARIABLES LIKE 'slow_%';

临时开启:

SET GLOBAL slow_launch_time=2;

SET GLOBAL slow_query_log=ON;

永久开启:

mkdir /var/log/mysql/

touch /var/log/mysql/error.log

touch /var/log/mysql/slow.log

chmod 777 /var/log/mysql/*

vi /etc/my.cnf

[mysqld]

slow_launch_time=2

slow_query_log=on

slow_query_log_file=/var/log/mysql/slow.log

...

log-error=/var/log/mysql/error.log

systemctl restart mysqld

rm /var/log/mysqld.log

使用jemalloc:

wget https://github.com/jemalloc/jemalloc/releases/download/4.4.0/jemalloc-4.4.0.tar.bz2

yum install bzip2

tar xjf jemalloc-4.4.0.tar.bz2

cd jemalloc-4.4.0

./configure

make && make install

cat /usr/lib/systemd/system/mysqld.service

文件中指定了环境变量值如下:

# Use this to switch malloc implementation

EnvironmentFile=-/etc/sysconfig/mysql

vi /etc/sysconfig/mysql

LD_PRELOAD=/usr/local/lib/libjemalloc.so

systemctl restart mysqld

验证jemalloc优化是否生效:

yum install lsof

lsof -n | grep jemalloc

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: malloc/free 和 new/delete 都是C/C++中的内存管理函数。malloc/free 是C语言的内存管理函数,它们用于申请和释放内存空间,它们没有构造函数和析构函数,只能用于普通的内存管理。而new/delete是C++中的内存管理函数,它们用于申请和释放内存空间,它们有构造函数和析构函数,可以用于类的内存管理。 ### 回答2: malloc/free和new/delete是两种动态内存分配和释放的方式。 首先,malloc/free是C语言的标准库函数,而new/delete是C++中的操作符。 其次,malloc和free是通过调用标准库函数来分配和释放内存,而new和delete是通过调用运算符来完成。 此外,malloc和free只能用于分配和释放内存,它们并不能调用对象的构造函数和析构函数。而new和delete不仅可以分配和释放内存,还可以调用对象的构造函数和析构函数。 另外,malloc分配的内存空间的大小是以字节为单位的,而new分配的内存空间的大小是以对象为单位的。因此,使用malloc分配内存时,需要手动计算所需的空间大小并进行类型转换;而使用new分配内存时,会自动计算所需的空间大小,并进行类型检查。 最后,malloc/free返回的是void指针,需要进行类型转换后才能使用;而new返回的是对象的指针,不需要进行类型转换。 综上所述,malloc/free和new/delete的区别在于语法和功能上的不同。对于C语言来说,只能使用malloc和free来进行动态内存分配和释放;而对于C++来说,则推荐使用new和delete来进行动态内存分配和释放,并能够调用对象的构造函数和析构函数。 ### 回答3: malloc/free和new/delete是两种在C和C++中用于内存分配和释放的方法。 首先,malloc和free是C语言中的函数,而new和delete是C++中的操作符。 malloc和free是库函数,用于动态分配和释放内存。它们需要手动指定要分配的内存大小,并且返回的是一个void指针。由于返回的是void指针,因此必须进行类型转换,以便使用分配的内存。此外,malloc分配的内存大小可以是0,而free不能接受空指针作为参数。 而new和delete是C++中的操作符。new操作符用于在堆上分配内存,并且会自动调用相应类型的构造函数进行对象的初始化。在使用new操作符时,不需要手动指定内存大小,而是需要指定要分配的类型。delete操作符用于释放new操作符分配的内存,并且会自动调用相应类型的析构函数进行对象的清理。同时,delete操作符还可以正确处理数组类型的对象的释放。 综上所述,malloc/free和new/delete的区别包括以下几个方面: - 使用场景:malloc/free适用于C语言,而new/delete适用于C++语言。 - 操作符与函数:malloc/free是函数,需要手动指定内存大小,返回的是void指针;而new/delete是操作符,不需要指定内存大小,可以自动调用构造函数和析构函数。 - 初始化和清理:new操作符可以自动调用构造函数进行对象初始化,而delete操作符可以自动调用析构函数进行对象清理。 - 处理数组:delete操作符可以正确处理数组类型的对象的释放。 因此,在使用C++编程时,推荐使用new/delete来替代malloc/free,可以更方便地进行内存管理和对象的初始化和清理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值