MYSQL安装

初始化安装

  1. 安装mysql5.7的rpm仓库
 sudo rpm -ivh https://dev.mysql.com/get/mysql57-community-release-el7-9.noarch.rpm

复制

修改仓库文件

vim /etc/yum.repos.d/mysql-community.repo

将[mysql57-community]修改为如下所示,也就是将gpgcheck改为0

[mysql57-community]
name=MySQL 5.7 Community Server
baseurl=http://repo.mysql.com/yum/mysql-5.7-community/el/7/$basearch/
enabled=1
gpgcheck=0
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-mysql

复制

2. 安装mysql-server

sudo yum install -y mysql-server

复制

3. 数据库设置utf-8,以及修改数据库最大连接数位1024

vi /etc/my.cnf

#添加

[mysqld]

character_set_server=utf8

init_connect='SET NAMES utf8'

max_connections=1024

复制

4. 设置开机启动mysql,并启动mysql

systemctl enable mysqld

systemctl start mysqld

复制

5. 查看初始随机密码

grep 'temporary password' /var/log/mysqld.log

复制

6. 使用刚刚查到的初始随机密码登陆mysql并修改密码(不修改无法操作)。修改的密码有严格要求,必须8位以上,并且至少包含字母、数字、特殊符号三种类型。

修改mysql默认的密码策略(使msq可以设置简单的密码)

set global validate_password_policy=0;

set global validate_password_length=1;

# 登陆
mysql -u root -p

# 修改密码
ALTER USER 'root'@'localhost' IDENTIFIED BY 'Pass-123-root';

复制

新增用户与用户授权

  1. 新增用户
# 该语句表示只能从本机登陆此用户
create user 'test'@'localhost' identified by 'Pass-123-test';

# 该语句表示可以从任意主机登陆此用户
create user 'test'@'%' identified by 'Pass-123-test';

# 如果你想指定可以登录的主机,可以将上述%换成对应主机ip或者hostname(如果在本地做了hosts映射,那么就用hostname)

复制

2. 用户授权

# 将任意库以及任意表授权给test用户,并且该用户可以从任意主机登陆
grant all privileges on *.* to 'root'@'%' identified by 'Pass-123-root' with grant option;

复制

使用自带mysql自带工具压测

压测命令:

mysqlslap --defaults-file=/etc/my.cnf --concurrency=100,200 --iterations=1 --number-int-cols=20 --number-char-cols=30 --auto-generate-sql --auto-generate-sql-add-autoincrement --auto-generate-sql-load-type=mixed --engine=myisam,innodb --number-of-queries=2000 -uroot -pPass-123-root --verbose

复制

上述压测命令表示:进行两次并发读写,第一次100,第二次200,自动生成SQL脚本,测试表包含20个init字段,30个char字段,每次执行2000查询请求。测试引擎分别是myisam,innodb。

测试结果示例:

Benchmark
        Running for engine myisam
        Average number of seconds to run all queries: 0.075 seconds
        Minimum number of seconds to run all queries: 0.075 seconds
        Maximum number of seconds to run all queries: 0.075 seconds
        Number of clients running queries: 100
        Average number of queries per client: 20

Benchmark
        Running for engine myisam
        Average number of seconds to run all queries: 0.186 seconds
        Minimum number of seconds to run all queries: 0.186 seconds
        Maximum number of seconds to run all queries: 0.186 seconds
        Number of clients running queries: 200
        Average number of queries per client: 10

Benchmark
        Running for engine innodb
        Average number of seconds to run all queries: 1.231 seconds
        Minimum number of seconds to run all queries: 1.231 seconds
        Maximum number of seconds to run all queries: 1.231 seconds
        Number of clients running queries: 100
        Average number of queries per client: 20

Benchmark
        Running for engine innodb
        Average number of seconds to run all queries: 1.586 seconds
        Minimum number of seconds to run all queries: 1.586 seconds
        Maximum number of seconds to run all queries: 1.586 seconds
        Number of clients running queries: 200
        Average number of queries per client: 10

复制

测试结果说明:

  • Myisam第一次100客户端同时发起增查用0.075/s,第二次200客户端同时发起增查用0.186/s
  • Innodb第一次100客户端同时发起增查用1.231/s,第二次200客户端同时发起增查用1.586/s

可以根据实际需求,一点点的加大并发数量进行压力测试。

本文为从大数据到人工智能博主「xiaozhch5」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。

原文链接:https://lrting.top/backend/2111/

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值